-- Hoogle documentation, generated by Haddock
-- See Hoogle, http://www.haskell.org/hoogle/
-- | Bindings to the Vulkan graphics API.
--
-- Please see readme.md
@package vulkan
@version 2.0.0.0
module Graphics.Vulkan.Core10.Constants
-- | VK_NULL_HANDLE - Reserved non-valid object handle
--
--
Description
--
-- See Also
--
-- No cross-references are available
-- | VkPipelineCacheHeaderVersion - Encode pipeline cache version
--
-- See Also
--
-- vkCreatePipelineCache, vkGetPipelineCacheData
newtype VkPipelineCacheHeaderVersion
VkPipelineCacheHeaderVersion :: Int32 -> VkPipelineCacheHeaderVersion
-- | VK_PIPELINE_CACHE_HEADER_VERSION_ONE specifies version one of
-- the pipeline cache.
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Constants.VkPipelineCacheHeaderVersion
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Constants.VkPipelineCacheHeaderVersion
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Constants.VkPipelineCacheHeaderVersion
instance GHC.Show.Show Graphics.Vulkan.Core10.Constants.VkPipelineCacheHeaderVersion
instance GHC.Read.Read Graphics.Vulkan.Core10.Constants.VkPipelineCacheHeaderVersion
module Graphics.Vulkan.Core10.Core
-- | VkBool32 - Vulkan boolean type
--
-- Description
--
-- VK_TRUE represents a boolean True (integer 1) value,
-- and VK_FALSE a boolean False (integer 0) value.
--
-- All values returned from a Vulkan implementation in a
-- VkBool32 will be either VK_TRUE or
-- VK_FALSE.
--
-- Applications must not pass any other values than
-- VK_TRUE or VK_FALSE into a Vulkan implementation
-- where a VkBool32 is expected.
--
-- See Also
--
-- VkCommandBufferInheritanceInfo,
-- VkDedicatedAllocationBufferCreateInfoNV,
-- VkDedicatedAllocationImageCreateInfoNV,
-- VkDescriptorSetLayoutSupport,
-- VkDeviceGeneratedCommandsFeaturesNVX,
-- VkDisplayPresentInfoKHR, VkDisplayPropertiesKHR,
-- VkMemoryDedicatedRequirements,
-- VkPhysicalDevice16BitStorageFeatures,
-- VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT,
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT,
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT,
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT,
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT,
-- VkPhysicalDeviceFeatures,
-- VkPhysicalDeviceGroupProperties,
-- VkPhysicalDeviceIDProperties, VkPhysicalDeviceLimits,
-- VkPhysicalDeviceMultiviewFeatures,
-- VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX,
-- VkPhysicalDeviceProtectedMemoryFeatures,
-- VkPhysicalDeviceProtectedMemoryProperties,
-- VkPhysicalDeviceSampleLocationsPropertiesEXT,
-- VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT,
-- VkPhysicalDeviceSamplerYcbcrConversionFeatures,
-- VkPhysicalDeviceShaderDrawParameterFeatures,
-- VkPhysicalDeviceSparseProperties,
-- VkPhysicalDeviceSubgroupProperties,
-- VkPhysicalDeviceVariablePointerFeatures,
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT,
-- VkPipelineColorBlendAttachmentState,
-- VkPipelineColorBlendStateCreateInfo,
-- VkPipelineCoverageModulationStateCreateInfoNV,
-- VkPipelineCoverageToColorStateCreateInfoNV,
-- VkPipelineDepthStencilStateCreateInfo,
-- VkPipelineInputAssemblyStateCreateInfo,
-- VkPipelineMultisampleStateCreateInfo,
-- VkPipelineRasterizationStateCreateInfo,
-- VkPipelineSampleLocationsStateCreateInfoEXT,
-- VkPipelineViewportWScalingStateCreateInfoNV,
-- VkProtectedSubmitInfo, VkSamplerCreateInfo,
-- VkSamplerYcbcrConversionCreateInfo,
-- VkSwapchainCreateInfoKHR,
-- VkTextureLODGatherFormatPropertiesAMD,
-- vkGetPhysicalDeviceSurfaceSupportKHR, vkWaitForFences
newtype VkBool32
VkBool32 :: Int32 -> VkBool32
-- | VkFormat - Available image formats
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkAttachmentDescription, VkBufferViewCreateInfo,
-- VkImageCreateInfo, VkImageFormatListCreateInfoKHR,
-- VkImageViewCreateInfo, VkPhysicalDeviceImageFormatInfo2,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- VkSamplerYcbcrConversionCreateInfo, VkSurfaceFormatKHR,
-- VkSwapchainCreateInfoKHR,
-- VkVertexInputAttributeDescription,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceFormatProperties,
-- vkGetPhysicalDeviceFormatProperties2,
-- vkGetPhysicalDeviceFormatProperties2KHR,
-- vkGetPhysicalDeviceImageFormatProperties,
-- vkGetPhysicalDeviceSparseImageFormatProperties
newtype VkFormat
VkFormat :: Int32 -> VkFormat
-- | VK_FORMAT_UNDEFINED specifies that the format is not
-- specified.
-- | VK_FORMAT_R4G4_UNORM_PACK8 specifies a two-component, 8-bit
-- packed unsigned normalized format that has a 4-bit R component in bits
-- 4..7, and a 4-bit G component in bits 0..3.
-- | VK_FORMAT_R4G4B4A4_UNORM_PACK16 specifies a four-component,
-- 16-bit packed unsigned normalized format that has a 4-bit R component
-- in bits 12..15, a 4-bit G component in bits 8..11, a 4-bit B component
-- in bits 4..7, and a 4-bit A component in bits 0..3.
-- | VK_FORMAT_B4G4R4A4_UNORM_PACK16 specifies a four-component,
-- 16-bit packed unsigned normalized format that has a 4-bit B component
-- in bits 12..15, a 4-bit G component in bits 8..11, a 4-bit R component
-- in bits 4..7, and a 4-bit A component in bits 0..3.
-- | VK_FORMAT_R5G6B5_UNORM_PACK16 specifies a three-component,
-- 16-bit packed unsigned normalized format that has a 5-bit R component
-- in bits 11..15, a 6-bit G component in bits 5..10, and a 5-bit B
-- component in bits 0..4.
-- | VK_FORMAT_B5G6R5_UNORM_PACK16 specifies a three-component,
-- 16-bit packed unsigned normalized format that has a 5-bit B component
-- in bits 11..15, a 6-bit G component in bits 5..10, and a 5-bit R
-- component in bits 0..4.
-- | VK_FORMAT_R5G5B5A1_UNORM_PACK16 specifies a four-component,
-- 16-bit packed unsigned normalized format that has a 5-bit R component
-- in bits 11..15, a 5-bit G component in bits 6..10, a 5-bit B component
-- in bits 1..5, and a 1-bit A component in bit 0.
-- | VK_FORMAT_B5G5R5A1_UNORM_PACK16 specifies a four-component,
-- 16-bit packed unsigned normalized format that has a 5-bit B component
-- in bits 11..15, a 5-bit G component in bits 6..10, a 5-bit R component
-- in bits 1..5, and a 1-bit A component in bit 0.
-- | VK_FORMAT_A1R5G5B5_UNORM_PACK16 specifies a four-component,
-- 16-bit packed unsigned normalized format that has a 1-bit A component
-- in bit 15, a 5-bit R component in bits 10..14, a 5-bit G component in
-- bits 5..9, and a 5-bit B component in bits 0..4.
-- | VK_FORMAT_R8_UNORM specifies a one-component, 8-bit unsigned
-- normalized format that has a single 8-bit R component.
-- | VK_FORMAT_R8_SNORM specifies a one-component, 8-bit signed
-- normalized format that has a single 8-bit R component.
-- | VK_FORMAT_R8_USCALED specifies a one-component, 8-bit
-- unsigned scaled integer format that has a single 8-bit R component.
-- | VK_FORMAT_R8_SSCALED specifies a one-component, 8-bit signed
-- scaled integer format that has a single 8-bit R component.
-- | VK_FORMAT_R8_UINT specifies a one-component, 8-bit unsigned
-- integer format that has a single 8-bit R component.
-- | VK_FORMAT_R8_SINT specifies a one-component, 8-bit signed
-- integer format that has a single 8-bit R component.
-- | VK_FORMAT_R8_SRGB specifies a one-component, 8-bit unsigned
-- normalized format that has a single 8-bit R component stored with sRGB
-- nonlinear encoding.
-- | VK_FORMAT_R8G8_UNORM specifies a two-component, 16-bit
-- unsigned normalized format that has an 8-bit R component in byte 0,
-- and an 8-bit G component in byte 1.
-- | VK_FORMAT_R8G8_SNORM specifies a two-component, 16-bit signed
-- normalized format that has an 8-bit R component in byte 0, and an
-- 8-bit G component in byte 1.
-- | VK_FORMAT_R8G8_USCALED specifies a two-component, 16-bit
-- unsigned scaled integer format that has an 8-bit R component in byte
-- 0, and an 8-bit G component in byte 1.
-- | VK_FORMAT_R8G8_SSCALED specifies a two-component, 16-bit
-- signed scaled integer format that has an 8-bit R component in byte 0,
-- and an 8-bit G component in byte 1.
-- | VK_FORMAT_R8G8_UINT specifies a two-component, 16-bit
-- unsigned integer format that has an 8-bit R component in byte 0, and
-- an 8-bit G component in byte 1.
-- | VK_FORMAT_R8G8_SINT specifies a two-component, 16-bit signed
-- integer format that has an 8-bit R component in byte 0, and an 8-bit G
-- component in byte 1.
-- | VK_FORMAT_R8G8_SRGB specifies a two-component, 16-bit
-- unsigned normalized format that has an 8-bit R component stored with
-- sRGB nonlinear encoding in byte 0, and an 8-bit G component stored
-- with sRGB nonlinear encoding in byte 1.
-- | VK_FORMAT_R8G8B8_UNORM specifies a three-component, 24-bit
-- unsigned normalized format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_SNORM specifies a three-component, 24-bit
-- signed normalized format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_USCALED specifies a three-component, 24-bit
-- unsigned scaled format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_SSCALED specifies a three-component, 24-bit
-- signed scaled format that has an 8-bit R component in byte 0, an 8-bit
-- G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_UINT specifies a three-component, 24-bit
-- unsigned integer format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_SINT specifies a three-component, 24-bit
-- signed integer format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit B component in byte 2.
-- | VK_FORMAT_R8G8B8_SRGB specifies a three-component, 24-bit
-- unsigned normalized format that has an 8-bit R component stored with
-- sRGB nonlinear encoding in byte 0, an 8-bit G component stored with
-- sRGB nonlinear encoding in byte 1, and an 8-bit B component stored
-- with sRGB nonlinear encoding in byte 2.
-- | VK_FORMAT_B8G8R8_UNORM specifies a three-component, 24-bit
-- unsigned normalized format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_SNORM specifies a three-component, 24-bit
-- signed normalized format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_USCALED specifies a three-component, 24-bit
-- unsigned scaled format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_SSCALED specifies a three-component, 24-bit
-- signed scaled format that has an 8-bit B component in byte 0, an 8-bit
-- G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_UINT specifies a three-component, 24-bit
-- unsigned integer format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_SINT specifies a three-component, 24-bit
-- signed integer format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, and an 8-bit R component in byte 2.
-- | VK_FORMAT_B8G8R8_SRGB specifies a three-component, 24-bit
-- unsigned normalized format that has an 8-bit B component stored with
-- sRGB nonlinear encoding in byte 0, an 8-bit G component stored with
-- sRGB nonlinear encoding in byte 1, and an 8-bit R component stored
-- with sRGB nonlinear encoding in byte 2.
-- | VK_FORMAT_R8G8B8A8_UNORM specifies a four-component, 32-bit
-- unsigned normalized format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit B component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_R8G8B8A8_SNORM specifies a four-component, 32-bit
-- signed normalized format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit B component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_R8G8B8A8_USCALED specifies a four-component, 32-bit
-- unsigned scaled format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit B component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_R8G8B8A8_SSCALED specifies a four-component, 32-bit
-- signed scaled format that has an 8-bit R component in byte 0, an 8-bit
-- G component in byte 1, an 8-bit B component in byte 2, and an 8-bit A
-- component in byte 3.
-- | VK_FORMAT_R8G8B8A8_UINT specifies a four-component, 32-bit
-- unsigned integer format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit B component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_R8G8B8A8_SINT specifies a four-component, 32-bit
-- signed integer format that has an 8-bit R component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit B component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_R8G8B8A8_SRGB specifies a four-component, 32-bit
-- unsigned normalized format that has an 8-bit R component stored with
-- sRGB nonlinear encoding in byte 0, an 8-bit G component stored with
-- sRGB nonlinear encoding in byte 1, an 8-bit B component stored with
-- sRGB nonlinear encoding in byte 2, and an 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_UNORM specifies a four-component, 32-bit
-- unsigned normalized format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit R component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_SNORM specifies a four-component, 32-bit
-- signed normalized format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit R component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_USCALED specifies a four-component, 32-bit
-- unsigned scaled format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit R component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_SSCALED specifies a four-component, 32-bit
-- signed scaled format that has an 8-bit B component in byte 0, an 8-bit
-- G component in byte 1, an 8-bit R component in byte 2, and an 8-bit A
-- component in byte 3.
-- | VK_FORMAT_B8G8R8A8_UINT specifies a four-component, 32-bit
-- unsigned integer format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit R component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_SINT specifies a four-component, 32-bit
-- signed integer format that has an 8-bit B component in byte 0, an
-- 8-bit G component in byte 1, an 8-bit R component in byte 2, and an
-- 8-bit A component in byte 3.
-- | VK_FORMAT_B8G8R8A8_SRGB specifies a four-component, 32-bit
-- unsigned normalized format that has an 8-bit B component stored with
-- sRGB nonlinear encoding in byte 0, an 8-bit G component stored with
-- sRGB nonlinear encoding in byte 1, an 8-bit R component stored with
-- sRGB nonlinear encoding in byte 2, and an 8-bit A component in byte 3.
-- | VK_FORMAT_A8B8G8R8_UNORM_PACK32 specifies a four-component,
-- 32-bit packed unsigned normalized format that has an 8-bit A component
-- in bits 24..31, an 8-bit B component in bits 16..23, an 8-bit G
-- component in bits 8..15, and an 8-bit R component in bits 0..7.
-- | VK_FORMAT_A8B8G8R8_SNORM_PACK32 specifies a four-component,
-- 32-bit packed signed normalized format that has an 8-bit A component
-- in bits 24..31, an 8-bit B component in bits 16..23, an 8-bit G
-- component in bits 8..15, and an 8-bit R component in bits 0..7.
-- | VK_FORMAT_A8B8G8R8_USCALED_PACK32 specifies a four-component,
-- 32-bit packed unsigned scaled integer format that has an 8-bit A
-- component in bits 24..31, an 8-bit B component in bits 16..23, an
-- 8-bit G component in bits 8..15, and an 8-bit R component in bits
-- 0..7.
-- | VK_FORMAT_A8B8G8R8_SSCALED_PACK32 specifies a four-component,
-- 32-bit packed signed scaled integer format that has an 8-bit A
-- component in bits 24..31, an 8-bit B component in bits 16..23, an
-- 8-bit G component in bits 8..15, and an 8-bit R component in bits
-- 0..7.
-- | VK_FORMAT_A8B8G8R8_UINT_PACK32 specifies a four-component,
-- 32-bit packed unsigned integer format that has an 8-bit A component in
-- bits 24..31, an 8-bit B component in bits 16..23, an 8-bit G component
-- in bits 8..15, and an 8-bit R component in bits 0..7.
-- | VK_FORMAT_A8B8G8R8_SINT_PACK32 specifies a four-component,
-- 32-bit packed signed integer format that has an 8-bit A component in
-- bits 24..31, an 8-bit B component in bits 16..23, an 8-bit G component
-- in bits 8..15, and an 8-bit R component in bits 0..7.
-- | VK_FORMAT_A8B8G8R8_SRGB_PACK32 specifies a four-component,
-- 32-bit packed unsigned normalized format that has an 8-bit A component
-- in bits 24..31, an 8-bit B component stored with sRGB nonlinear
-- encoding in bits 16..23, an 8-bit G component stored with sRGB
-- nonlinear encoding in bits 8..15, and an 8-bit R component stored with
-- sRGB nonlinear encoding in bits 0..7.
-- | VK_FORMAT_A2R10G10B10_UNORM_PACK32 specifies a
-- four-component, 32-bit packed unsigned normalized format that has a
-- 2-bit A component in bits 30..31, a 10-bit R component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit B component in bits
-- 0..9.
-- | VK_FORMAT_A2R10G10B10_SNORM_PACK32 specifies a
-- four-component, 32-bit packed signed normalized format that has a
-- 2-bit A component in bits 30..31, a 10-bit R component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit B component in bits
-- 0..9.
-- | VK_FORMAT_A2R10G10B10_USCALED_PACK32 specifies a
-- four-component, 32-bit packed unsigned scaled integer format that has
-- a 2-bit A component in bits 30..31, a 10-bit R component in bits
-- 20..29, a 10-bit G component in bits 10..19, and a 10-bit B component
-- in bits 0..9.
-- | VK_FORMAT_A2R10G10B10_SSCALED_PACK32 specifies a
-- four-component, 32-bit packed signed scaled integer format that has a
-- 2-bit A component in bits 30..31, a 10-bit R component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit B component in bits
-- 0..9.
-- | VK_FORMAT_A2R10G10B10_UINT_PACK32 specifies a four-component,
-- 32-bit packed unsigned integer format that has a 2-bit A component in
-- bits 30..31, a 10-bit R component in bits 20..29, a 10-bit G component
-- in bits 10..19, and a 10-bit B component in bits 0..9.
-- | VK_FORMAT_A2R10G10B10_SINT_PACK32 specifies a four-component,
-- 32-bit packed signed integer format that has a 2-bit A component in
-- bits 30..31, a 10-bit R component in bits 20..29, a 10-bit G component
-- in bits 10..19, and a 10-bit B component in bits 0..9.
-- | VK_FORMAT_A2B10G10R10_UNORM_PACK32 specifies a
-- four-component, 32-bit packed unsigned normalized format that has a
-- 2-bit A component in bits 30..31, a 10-bit B component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit R component in bits
-- 0..9.
-- | VK_FORMAT_A2B10G10R10_SNORM_PACK32 specifies a
-- four-component, 32-bit packed signed normalized format that has a
-- 2-bit A component in bits 30..31, a 10-bit B component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit R component in bits
-- 0..9.
-- | VK_FORMAT_A2B10G10R10_USCALED_PACK32 specifies a
-- four-component, 32-bit packed unsigned scaled integer format that has
-- a 2-bit A component in bits 30..31, a 10-bit B component in bits
-- 20..29, a 10-bit G component in bits 10..19, and a 10-bit R component
-- in bits 0..9.
-- | VK_FORMAT_A2B10G10R10_SSCALED_PACK32 specifies a
-- four-component, 32-bit packed signed scaled integer format that has a
-- 2-bit A component in bits 30..31, a 10-bit B component in bits 20..29,
-- a 10-bit G component in bits 10..19, and a 10-bit R component in bits
-- 0..9.
-- | VK_FORMAT_A2B10G10R10_UINT_PACK32 specifies a four-component,
-- 32-bit packed unsigned integer format that has a 2-bit A component in
-- bits 30..31, a 10-bit B component in bits 20..29, a 10-bit G component
-- in bits 10..19, and a 10-bit R component in bits 0..9.
-- | VK_FORMAT_A2B10G10R10_SINT_PACK32 specifies a four-component,
-- 32-bit packed signed integer format that has a 2-bit A component in
-- bits 30..31, a 10-bit B component in bits 20..29, a 10-bit G component
-- in bits 10..19, and a 10-bit R component in bits 0..9.
-- | VK_FORMAT_R16_UNORM specifies a one-component, 16-bit
-- unsigned normalized format that has a single 16-bit R component.
-- | VK_FORMAT_R16_SNORM specifies a one-component, 16-bit signed
-- normalized format that has a single 16-bit R component.
-- | VK_FORMAT_R16_USCALED specifies a one-component, 16-bit
-- unsigned scaled integer format that has a single 16-bit R component.
-- | VK_FORMAT_R16_SSCALED specifies a one-component, 16-bit
-- signed scaled integer format that has a single 16-bit R component.
-- | VK_FORMAT_R16_UINT specifies a one-component, 16-bit unsigned
-- integer format that has a single 16-bit R component.
-- | VK_FORMAT_R16_SINT specifies a one-component, 16-bit signed
-- integer format that has a single 16-bit R component.
-- | VK_FORMAT_R16_SFLOAT specifies a one-component, 16-bit signed
-- floating-point format that has a single 16-bit R component.
-- | VK_FORMAT_R16G16_UNORM specifies a two-component, 32-bit
-- unsigned normalized format that has a 16-bit R component in bytes
-- 0..1, and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_SNORM specifies a two-component, 32-bit
-- signed normalized format that has a 16-bit R component in bytes 0..1,
-- and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_USCALED specifies a two-component, 32-bit
-- unsigned scaled integer format that has a 16-bit R component in bytes
-- 0..1, and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_SSCALED specifies a two-component, 32-bit
-- signed scaled integer format that has a 16-bit R component in bytes
-- 0..1, and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_UINT specifies a two-component, 32-bit
-- unsigned integer format that has a 16-bit R component in bytes 0..1,
-- and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_SINT specifies a two-component, 32-bit
-- signed integer format that has a 16-bit R component in bytes 0..1, and
-- a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16_SFLOAT specifies a two-component, 32-bit
-- signed floating-point format that has a 16-bit R component in bytes
-- 0..1, and a 16-bit G component in bytes 2..3.
-- | VK_FORMAT_R16G16B16_UNORM specifies a three-component, 48-bit
-- unsigned normalized format that has a 16-bit R component in bytes
-- 0..1, a 16-bit G component in bytes 2..3, and a 16-bit B component in
-- bytes 4..5.
-- | VK_FORMAT_R16G16B16_SNORM specifies a three-component, 48-bit
-- signed normalized format that has a 16-bit R component in bytes 0..1,
-- a 16-bit G component in bytes 2..3, and a 16-bit B component in bytes
-- 4..5.
-- | VK_FORMAT_R16G16B16_USCALED specifies a three-component,
-- 48-bit unsigned scaled integer format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, and a 16-bit B
-- component in bytes 4..5.
-- | VK_FORMAT_R16G16B16_SSCALED specifies a three-component,
-- 48-bit signed scaled integer format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, and a 16-bit B
-- component in bytes 4..5.
-- | VK_FORMAT_R16G16B16_UINT specifies a three-component, 48-bit
-- unsigned integer format that has a 16-bit R component in bytes 0..1, a
-- 16-bit G component in bytes 2..3, and a 16-bit B component in bytes
-- 4..5.
-- | VK_FORMAT_R16G16B16_SINT specifies a three-component, 48-bit
-- signed integer format that has a 16-bit R component in bytes 0..1, a
-- 16-bit G component in bytes 2..3, and a 16-bit B component in bytes
-- 4..5.
-- | VK_FORMAT_R16G16B16_SFLOAT specifies a three-component,
-- 48-bit signed floating-point format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, and a 16-bit B
-- component in bytes 4..5.
-- | VK_FORMAT_R16G16B16A16_UNORM specifies a four-component,
-- 64-bit unsigned normalized format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component
-- in bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_SNORM specifies a four-component,
-- 64-bit signed normalized format that has a 16-bit R component in bytes
-- 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component in
-- bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_USCALED specifies a four-component,
-- 64-bit unsigned scaled integer format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component
-- in bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_SSCALED specifies a four-component,
-- 64-bit signed scaled integer format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component
-- in bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_UINT specifies a four-component,
-- 64-bit unsigned integer format that has a 16-bit R component in bytes
-- 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component in
-- bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_SINT specifies a four-component,
-- 64-bit signed integer format that has a 16-bit R component in bytes
-- 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component in
-- bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R16G16B16A16_SFLOAT specifies a four-component,
-- 64-bit signed floating-point format that has a 16-bit R component in
-- bytes 0..1, a 16-bit G component in bytes 2..3, a 16-bit B component
-- in bytes 4..5, and a 16-bit A component in bytes 6..7.
-- | VK_FORMAT_R32_UINT specifies a one-component, 32-bit unsigned
-- integer format that has a single 32-bit R component.
-- | VK_FORMAT_R32_SINT specifies a one-component, 32-bit signed
-- integer format that has a single 32-bit R component.
-- | VK_FORMAT_R32_SFLOAT specifies a one-component, 32-bit signed
-- floating-point format that has a single 32-bit R component.
-- | VK_FORMAT_R32G32_UINT specifies a two-component, 64-bit
-- unsigned integer format that has a 32-bit R component in bytes 0..3,
-- and a 32-bit G component in bytes 4..7.
-- | VK_FORMAT_R32G32_SINT specifies a two-component, 64-bit
-- signed integer format that has a 32-bit R component in bytes 0..3, and
-- a 32-bit G component in bytes 4..7.
-- | VK_FORMAT_R32G32_SFLOAT specifies a two-component, 64-bit
-- signed floating-point format that has a 32-bit R component in bytes
-- 0..3, and a 32-bit G component in bytes 4..7.
-- | VK_FORMAT_R32G32B32_UINT specifies a three-component, 96-bit
-- unsigned integer format that has a 32-bit R component in bytes 0..3, a
-- 32-bit G component in bytes 4..7, and a 32-bit B component in bytes
-- 8..11.
-- | VK_FORMAT_R32G32B32_SINT specifies a three-component, 96-bit
-- signed integer format that has a 32-bit R component in bytes 0..3, a
-- 32-bit G component in bytes 4..7, and a 32-bit B component in bytes
-- 8..11.
-- | VK_FORMAT_R32G32B32_SFLOAT specifies a three-component,
-- 96-bit signed floating-point format that has a 32-bit R component in
-- bytes 0..3, a 32-bit G component in bytes 4..7, and a 32-bit B
-- component in bytes 8..11.
-- | VK_FORMAT_R32G32B32A32_UINT specifies a four-component,
-- 128-bit unsigned integer format that has a 32-bit R component in bytes
-- 0..3, a 32-bit G component in bytes 4..7, a 32-bit B component in
-- bytes 8..11, and a 32-bit A component in bytes 12..15.
-- | VK_FORMAT_R32G32B32A32_SINT specifies a four-component,
-- 128-bit signed integer format that has a 32-bit R component in bytes
-- 0..3, a 32-bit G component in bytes 4..7, a 32-bit B component in
-- bytes 8..11, and a 32-bit A component in bytes 12..15.
-- | VK_FORMAT_R32G32B32A32_SFLOAT specifies a four-component,
-- 128-bit signed floating-point format that has a 32-bit R component in
-- bytes 0..3, a 32-bit G component in bytes 4..7, a 32-bit B component
-- in bytes 8..11, and a 32-bit A component in bytes 12..15.
-- | VK_FORMAT_R64_UINT specifies a one-component, 64-bit unsigned
-- integer format that has a single 64-bit R component.
-- | VK_FORMAT_R64_SINT specifies a one-component, 64-bit signed
-- integer format that has a single 64-bit R component.
-- | VK_FORMAT_R64_SFLOAT specifies a one-component, 64-bit signed
-- floating-point format that has a single 64-bit R component.
-- | VK_FORMAT_R64G64_UINT specifies a two-component, 128-bit
-- unsigned integer format that has a 64-bit R component in bytes 0..7,
-- and a 64-bit G component in bytes 8..15.
-- | VK_FORMAT_R64G64_SINT specifies a two-component, 128-bit
-- signed integer format that has a 64-bit R component in bytes 0..7, and
-- a 64-bit G component in bytes 8..15.
-- | VK_FORMAT_R64G64_SFLOAT specifies a two-component, 128-bit
-- signed floating-point format that has a 64-bit R component in bytes
-- 0..7, and a 64-bit G component in bytes 8..15.
-- | VK_FORMAT_R64G64B64_UINT specifies a three-component, 192-bit
-- unsigned integer format that has a 64-bit R component in bytes 0..7, a
-- 64-bit G component in bytes 8..15, and a 64-bit B component in bytes
-- 16..23.
-- | VK_FORMAT_R64G64B64_SINT specifies a three-component, 192-bit
-- signed integer format that has a 64-bit R component in bytes 0..7, a
-- 64-bit G component in bytes 8..15, and a 64-bit B component in bytes
-- 16..23.
-- | VK_FORMAT_R64G64B64_SFLOAT specifies a three-component,
-- 192-bit signed floating-point format that has a 64-bit R component in
-- bytes 0..7, a 64-bit G component in bytes 8..15, and a 64-bit B
-- component in bytes 16..23.
-- | VK_FORMAT_R64G64B64A64_UINT specifies a four-component,
-- 256-bit unsigned integer format that has a 64-bit R component in bytes
-- 0..7, a 64-bit G component in bytes 8..15, a 64-bit B component in
-- bytes 16..23, and a 64-bit A component in bytes 24..31.
-- | VK_FORMAT_R64G64B64A64_SINT specifies a four-component,
-- 256-bit signed integer format that has a 64-bit R component in bytes
-- 0..7, a 64-bit G component in bytes 8..15, a 64-bit B component in
-- bytes 16..23, and a 64-bit A component in bytes 24..31.
-- | VK_FORMAT_R64G64B64A64_SFLOAT specifies a four-component,
-- 256-bit signed floating-point format that has a 64-bit R component in
-- bytes 0..7, a 64-bit G component in bytes 8..15, a 64-bit B component
-- in bytes 16..23, and a 64-bit A component in bytes 24..31.
-- | VK_FORMAT_B10G11R11_UFLOAT_PACK32 specifies a
-- three-component, 32-bit packed unsigned floating-point format that has
-- a 10-bit B component in bits 22..31, an 11-bit G component in bits
-- 11..21, an 11-bit R component in bits 0..10. See
-- {html_spec_relative}#fundamentals-fp10 and
-- {html_spec_relative}#fundamentals-fp11.
-- | VK_FORMAT_E5B9G9R9_UFLOAT_PACK32 specifies a three-component,
-- 32-bit packed unsigned floating-point format that has a 5-bit shared
-- exponent in bits 27..31, a 9-bit B component mantissa in bits 18..26,
-- a 9-bit G component mantissa in bits 9..17, and a 9-bit R component
-- mantissa in bits 0..8.
-- | VK_FORMAT_D16_UNORM specifies a one-component, 16-bit
-- unsigned normalized format that has a single 16-bit depth component.
-- | VK_FORMAT_X8_D24_UNORM_PACK32 specifies a two-component,
-- 32-bit format that has 24 unsigned normalized bits in the depth
-- component and, optionally:, 8 bits that are unused.
-- | VK_FORMAT_D32_SFLOAT specifies a one-component, 32-bit signed
-- floating-point format that has 32-bits in the depth component.
-- | VK_FORMAT_S8_UINT specifies a one-component, 8-bit unsigned
-- integer format that has 8-bits in the stencil component.
-- | VK_FORMAT_D16_UNORM_S8_UINT specifies a two-component, 24-bit
-- format that has 16 unsigned normalized bits in the depth component and
-- 8 unsigned integer bits in the stencil component.
-- | VK_FORMAT_D24_UNORM_S8_UINT specifies a two-component, 32-bit
-- packed format that has 8 unsigned integer bits in the stencil
-- component, and 24 unsigned normalized bits in the depth component.
-- | VK_FORMAT_D32_SFLOAT_S8_UINT specifies a two-component format
-- that has 32 signed float bits in the depth component and 8 unsigned
-- integer bits in the stencil component. There are optionally: 24-bits
-- that are unused.
-- | VK_FORMAT_BC1_RGB_UNORM_BLOCK specifies a three-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGB texel data. This
-- format has no alpha and is considered opaque.
-- | VK_FORMAT_BC1_RGB_SRGB_BLOCK specifies a three-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGB texel data with
-- sRGB nonlinear encoding. This format has no alpha and is considered
-- opaque.
-- | VK_FORMAT_BC1_RGBA_UNORM_BLOCK specifies a four-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGB texel data, and
-- provides 1 bit of alpha.
-- | VK_FORMAT_BC1_RGBA_SRGB_BLOCK specifies a four-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGB texel data with
-- sRGB nonlinear encoding, and provides 1 bit of alpha.
-- | VK_FORMAT_BC2_UNORM_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- the first 64 bits encoding alpha values followed by 64 bits encoding
-- RGB values.
-- | VK_FORMAT_BC2_SRGB_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- the first 64 bits encoding alpha values followed by 64 bits encoding
-- RGB values with sRGB nonlinear encoding.
-- | VK_FORMAT_BC3_UNORM_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- the first 64 bits encoding alpha values followed by 64 bits encoding
-- RGB values.
-- | VK_FORMAT_BC3_SRGB_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- the first 64 bits encoding alpha values followed by 64 bits encoding
-- RGB values with sRGB nonlinear encoding.
-- | VK_FORMAT_BC4_UNORM_BLOCK specifies a one-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized red texel data.
-- | VK_FORMAT_BC4_SNORM_BLOCK specifies a one-component,
-- block-compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of signed normalized red texel data.
-- | VK_FORMAT_BC5_UNORM_BLOCK specifies a two-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RG texel data with the
-- first 64 bits encoding red values followed by 64 bits encoding green
-- values.
-- | VK_FORMAT_BC5_SNORM_BLOCK specifies a two-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of signed normalized RG texel data with the
-- first 64 bits encoding red values followed by 64 bits encoding green
-- values.
-- | VK_FORMAT_BC6H_UFLOAT_BLOCK specifies a three-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned floating-point RGB texel data.
-- | VK_FORMAT_BC6H_SFLOAT_BLOCK specifies a three-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of signed floating-point RGB texel data.
-- | VK_FORMAT_BC7_UNORM_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_BC7_SRGB_BLOCK specifies a four-component,
-- block-compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK specifies a
-- three-component, ETC2 compressed format where each 64-bit compressed
-- texel block encodes a 4×4 rectangle of unsigned normalized RGB texel
-- data. This format has no alpha and is considered opaque.
-- | VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK specifies a three-component,
-- ETC2 compressed format where each 64-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGB texel data with
-- sRGB nonlinear encoding. This format has no alpha and is considered
-- opaque.
-- | VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK specifies a
-- four-component, ETC2 compressed format where each 64-bit compressed
-- texel block encodes a 4×4 rectangle of unsigned normalized RGB texel
-- data, and provides 1 bit of alpha.
-- | VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK specifies a
-- four-component, ETC2 compressed format where each 64-bit compressed
-- texel block encodes a 4×4 rectangle of unsigned normalized RGB texel
-- data with sRGB nonlinear encoding, and provides 1 bit of alpha.
-- | VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK specifies a
-- four-component, ETC2 compressed format where each 128-bit compressed
-- texel block encodes a 4×4 rectangle of unsigned normalized RGBA texel
-- data with the first 64 bits encoding alpha values followed by 64 bits
-- encoding RGB values.
-- | VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK specifies a
-- four-component, ETC2 compressed format where each 128-bit compressed
-- texel block encodes a 4×4 rectangle of unsigned normalized RGBA texel
-- data with the first 64 bits encoding alpha values followed by 64 bits
-- encoding RGB values with sRGB nonlinear encoding applied.
-- | VK_FORMAT_EAC_R11_UNORM_BLOCK specifies a one-component, ETC2
-- compressed format where each 64-bit compressed texel block encodes a
-- 4×4 rectangle of unsigned normalized red texel data.
-- | VK_FORMAT_EAC_R11_SNORM_BLOCK specifies a one-component, ETC2
-- compressed format where each 64-bit compressed texel block encodes a
-- 4×4 rectangle of signed normalized red texel data.
-- | VK_FORMAT_EAC_R11G11_UNORM_BLOCK specifies a two-component,
-- ETC2 compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RG texel data with the
-- first 64 bits encoding red values followed by 64 bits encoding green
-- values.
-- | VK_FORMAT_EAC_R11G11_SNORM_BLOCK specifies a two-component,
-- ETC2 compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of signed normalized RG texel data with the
-- first 64 bits encoding red values followed by 64 bits encoding green
-- values.
-- | VK_FORMAT_ASTC_4x4_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_4x4_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 4×4 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_5x4_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 5×4 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_5x4_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 5×4 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_5x5_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 5×5 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_5x5_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 5×5 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_6x5_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 6×5 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_6x5_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 6×5 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_6x6_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 6×6 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_6x6_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 6×6 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_8x5_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×5 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_8x5_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×5 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_8x6_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×6 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_8x6_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×6 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_8x8_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×8 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_8x8_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes an 8×8 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_10x5_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×5 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_10x5_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×5 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_10x6_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×6 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_10x6_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×6 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_10x8_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×8 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_10x8_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×8 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_10x10_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×10 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_10x10_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 10×10 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_12x10_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 12×10 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_12x10_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 12×10 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VK_FORMAT_ASTC_12x12_UNORM_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 12×12 rectangle of unsigned normalized RGBA texel data.
-- | VK_FORMAT_ASTC_12x12_SRGB_BLOCK specifies a four-component,
-- ASTC compressed format where each 128-bit compressed texel block
-- encodes a 12×12 rectangle of unsigned normalized RGBA texel data with
-- sRGB nonlinear encoding applied to the RGB components.
-- | VkResult - Vulkan command return codes
--
-- Description
--
--
-- - VK_SUCCESS Command successfully completed
--
--
--
-- - VK_NOT_READY A fence or query has not yet completed
-- - VK_TIMEOUT A wait operation has not completed in the
-- specified time
-- - VK_EVENT_SET An event is signaled
-- - VK_EVENT_RESET An event is unsignaled
-- - VK_INCOMPLETE A return array was too small for the
-- result
-- - VK_SUBOPTIMAL_KHR A swapchain no longer matches the
-- surface properties exactly, but can still be used to present to
-- the surface successfully.
-- - VK_ERROR_OUT_OF_HOST_MEMORY A host memory allocation has
-- failed.
-- - VK_ERROR_OUT_OF_DEVICE_MEMORY A device memory allocation
-- has failed.
-- - VK_ERROR_INITIALIZATION_FAILED Initialization of an
-- object could not be completed for implementation-specific
-- reasons.
-- - VK_ERROR_DEVICE_LOST The logical or physical device has
-- been lost. See Lost Device
-- - VK_ERROR_MEMORY_MAP_FAILED Mapping of a memory object has
-- failed.
-- - VK_ERROR_LAYER_NOT_PRESENT A requested layer is not
-- present or could not be loaded.
-- - VK_ERROR_EXTENSION_NOT_PRESENT A requested extension is
-- not supported.
-- - VK_ERROR_FEATURE_NOT_PRESENT A requested feature is not
-- supported.
-- - VK_ERROR_INCOMPATIBLE_DRIVER The requested version of
-- Vulkan is not supported by the driver or is otherwise incompatible for
-- implementation-specific reasons.
-- - VK_ERROR_TOO_MANY_OBJECTS Too many objects of the type
-- have already been created.
-- - VK_ERROR_FORMAT_NOT_SUPPORTED A requested format is not
-- supported on this device.
-- - VK_ERROR_FRAGMENTED_POOL A pool allocation has failed due
-- to fragmentation of the pool’s memory. This must only be
-- returned if no attempt to allocate host or device memory was made to
-- accomodate the new allocation. This should be returned in
-- preference to VK_ERROR_OUT_OF_POOL_MEMORY, but only if the
-- implementation is certain that the pool allocation failure was due to
-- fragmentation.
-- - VK_ERROR_SURFACE_LOST_KHR A surface is no longer
-- available.
-- - VK_ERROR_NATIVE_WINDOW_IN_USE_KHR The requested window is
-- already in use by Vulkan or another API in a manner which prevents it
-- from being used again.
-- - VK_ERROR_OUT_OF_DATE_KHR A surface has changed in such a
-- way that it is no longer compatible with the swapchain, and further
-- presentation requests using the swapchain will fail. Applications
-- must query the new surface properties and recreate their
-- swapchain if they wish to continue presenting to the surface.
-- - VK_ERROR_INCOMPATIBLE_DISPLAY_KHR The display used by a
-- swapchain does not use the same presentable image layout, or is
-- incompatible in a way that prevents sharing an image.
-- - VK_ERROR_INVALID_SHADER_NV One or more shaders failed to
-- compile or link. More details are reported back to the application via
-- {html_spec_relative}#VK_EXT_debug_report if enabled.
-- - VK_ERROR_OUT_OF_POOL_MEMORY A pool memory allocation has
-- failed. This must only be returned if no attempt to allocate
-- host or device memory was made to accomodate the new allocation. If
-- the failure was definitely due to fragmentation of the pool,
-- VK_ERROR_FRAGMENTED_POOL should be returned
-- instead.
-- - VK_ERROR_INVALID_EXTERNAL_HANDLE An external handle is
-- not a valid handle of the specified type.
-- - VK_ERROR_FRAGMENTATION_EXT A descriptor pool creation has
-- failed due to fragmentation.
--
--
-- If a command returns a run time error, unless otherwise specified any
-- output parameters will have undefined contents, except that if the
-- output parameter is a structure with sType and pNext
-- fields, those fields will be unmodified. Any structures chained from
-- pNext will also have undefined contents, except that
-- sType and pNext will be unmodified.
--
-- Out of memory errors do not damage any currently existing Vulkan
-- objects. Objects that have already been successfully created
-- can still be used by the application.
--
-- Performance-critical commands generally do not have return codes. If a
-- run time error occurs in such commands, the implementation will defer
-- reporting the error until a specified point. For commands that record
-- into command buffers (vkCmd*) run time errors are reported by
-- vkEndCommandBuffer.
--
-- See Also
--
-- No cross-references are available, VkPresentInfoKHR
newtype VkResult
VkResult :: Int32 -> VkResult
-- | VkStructureType - Vulkan structure types (stype)
--
-- Description
--
-- Each value corresponds to a particular structure with a sType
-- member with a matching name. As a general rule, the name of each
-- VkStructureType value is obtained by taking the name of the
-- structure, stripping the leading Vk, prefixing each capital
-- letter with _, converting the entire resulting string to
-- upper case, and prefixing it with VK_STRUCTURE_TYPE_. For
-- example, structures of type VkImageCreateInfo correspond to a
-- VkStructureType of
-- VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO, and thus its
-- sType member must equal that when it is passed to the
-- API.
--
-- The values VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO and
-- VK_STRUCTURE_TYPE_LOADER_DEVICE_CREATE_INFO are reserved for
-- internal use by the loader, and do not have corresponding Vulkan
-- structures in this Specification.
--
-- See Also
--
-- VkAcquireNextImageInfoKHR,
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkAndroidHardwareBufferPropertiesANDROID,
-- VkAndroidHardwareBufferUsageANDROID,
-- VkAndroidSurfaceCreateInfoKHR, VkApplicationInfo,
-- VkBindBufferMemoryDeviceGroupInfo,
-- VkBindBufferMemoryInfo,
-- VkBindImageMemoryDeviceGroupInfo, VkBindImageMemoryInfo,
-- VkBindImageMemorySwapchainInfoKHR,
-- VkBindImagePlaneMemoryInfo, VkBindSparseInfo,
-- VkBufferCreateInfo, VkBufferMemoryBarrier,
-- VkBufferMemoryRequirementsInfo2, VkBufferViewCreateInfo,
-- VkCmdProcessCommandsInfoNVX,
-- VkCmdReserveSpaceForCommandsInfoNVX,
-- VkCommandBufferAllocateInfo, VkCommandBufferBeginInfo,
-- VkCommandBufferInheritanceInfo, VkCommandPoolCreateInfo,
-- VkComputePipelineCreateInfo, VkCopyDescriptorSet,
-- VkD3D12FenceSubmitInfoKHR, VkDebugMarkerMarkerInfoEXT,
-- VkDebugMarkerObjectNameInfoEXT,
-- VkDebugMarkerObjectTagInfoEXT,
-- VkDebugReportCallbackCreateInfoEXT,
-- VkDebugUtilsLabelEXT,
-- VkDebugUtilsMessengerCallbackDataEXT,
-- VkDebugUtilsMessengerCreateInfoEXT,
-- VkDebugUtilsObjectNameInfoEXT,
-- VkDebugUtilsObjectTagInfoEXT,
-- VkDedicatedAllocationBufferCreateInfoNV,
-- VkDedicatedAllocationImageCreateInfoNV,
-- VkDedicatedAllocationMemoryAllocateInfoNV,
-- VkDescriptorPoolCreateInfo, VkDescriptorSetAllocateInfo,
-- VkDescriptorSetLayoutBindingFlagsCreateInfoEXT,
-- VkDescriptorSetLayoutCreateInfo,
-- VkDescriptorSetLayoutSupport,
-- VkDescriptorSetVariableDescriptorCountAllocateInfoEXT,
-- VkDescriptorSetVariableDescriptorCountLayoutSupportEXT,
-- VkDescriptorUpdateTemplateCreateInfo,
-- VkDeviceCreateInfo, VkDeviceEventInfoEXT,
-- VkDeviceGeneratedCommandsFeaturesNVX,
-- VkDeviceGeneratedCommandsLimitsNVX,
-- VkDeviceGroupBindSparseInfo,
-- VkDeviceGroupCommandBufferBeginInfo,
-- VkDeviceGroupDeviceCreateInfo,
-- VkDeviceGroupPresentCapabilitiesKHR,
-- VkDeviceGroupPresentInfoKHR,
-- VkDeviceGroupRenderPassBeginInfo,
-- VkDeviceGroupSubmitInfo,
-- VkDeviceGroupSwapchainCreateInfoKHR,
-- VkDeviceQueueCreateInfo,
-- VkDeviceQueueGlobalPriorityCreateInfoEXT,
-- VkDeviceQueueInfo2, VkDisplayEventInfoEXT,
-- VkDisplayModeCreateInfoKHR, VkDisplayPowerInfoEXT,
-- VkDisplayPresentInfoKHR, VkDisplaySurfaceCreateInfoKHR,
-- VkEventCreateInfo, VkExportFenceCreateInfo,
-- VkExportFenceWin32HandleInfoKHR,
-- VkExportMemoryAllocateInfo,
-- VkExportMemoryAllocateInfoNV,
-- VkExportMemoryWin32HandleInfoKHR,
-- VkExportMemoryWin32HandleInfoNV,
-- VkExportSemaphoreCreateInfo,
-- VkExportSemaphoreWin32HandleInfoKHR,
-- VkExternalBufferProperties, VkExternalFenceProperties,
-- VkExternalFormatANDROID,
-- VkExternalImageFormatProperties,
-- VkExternalMemoryBufferCreateInfo,
-- VkExternalMemoryImageCreateInfo,
-- VkExternalMemoryImageCreateInfoNV,
-- VkExternalSemaphoreProperties, VkFenceCreateInfo,
-- VkFenceGetFdInfoKHR, VkFenceGetWin32HandleInfoKHR,
-- VkFormatProperties2, VkFramebufferCreateInfo,
-- VkGraphicsPipelineCreateInfo, VkHdrMetadataEXT,
-- VkIOSSurfaceCreateInfoMVK, VkImageCreateInfo,
-- VkImageFormatListCreateInfoKHR,
-- VkImageFormatProperties2, VkImageMemoryBarrier,
-- VkImageMemoryRequirementsInfo2,
-- VkImagePlaneMemoryRequirementsInfo,
-- VkImageSparseMemoryRequirementsInfo2,
-- VkImageSwapchainCreateInfoKHR, VkImageViewCreateInfo,
-- VkImageViewUsageCreateInfo,
-- VkImportAndroidHardwareBufferInfoANDROID,
-- VkImportFenceFdInfoKHR, VkImportFenceWin32HandleInfoKHR,
-- VkImportMemoryFdInfoKHR,
-- VkImportMemoryHostPointerInfoEXT,
-- VkImportMemoryWin32HandleInfoKHR,
-- VkImportMemoryWin32HandleInfoNV,
-- VkImportSemaphoreFdInfoKHR,
-- VkImportSemaphoreWin32HandleInfoKHR,
-- VkIndirectCommandsLayoutCreateInfoNVX,
-- VkInstanceCreateInfo, VkMacOSSurfaceCreateInfoMVK,
-- VkMappedMemoryRange, VkMemoryAllocateFlagsInfo,
-- VkMemoryAllocateInfo, VkMemoryBarrier,
-- VkMemoryDedicatedAllocateInfo,
-- VkMemoryDedicatedRequirements, VkMemoryFdPropertiesKHR,
-- VkMemoryGetAndroidHardwareBufferInfoANDROID,
-- VkMemoryGetFdInfoKHR, VkMemoryGetWin32HandleInfoKHR,
-- VkMemoryHostPointerPropertiesEXT, VkMemoryRequirements2,
-- VkMemoryWin32HandlePropertiesKHR,
-- VkMirSurfaceCreateInfoKHR, VkMultisamplePropertiesEXT,
-- VkObjectTableCreateInfoNVX,
-- VkPhysicalDevice16BitStorageFeatures,
-- VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT,
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT,
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT,
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT,
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT,
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT,
-- VkPhysicalDeviceExternalBufferInfo,
-- VkPhysicalDeviceExternalFenceInfo,
-- VkPhysicalDeviceExternalImageFormatInfo,
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT,
-- VkPhysicalDeviceExternalSemaphoreInfo,
-- VkPhysicalDeviceFeatures2,
-- VkPhysicalDeviceGroupProperties,
-- VkPhysicalDeviceIDProperties,
-- VkPhysicalDeviceImageFormatInfo2,
-- VkPhysicalDeviceMaintenance3Properties,
-- VkPhysicalDeviceMemoryProperties2,
-- VkPhysicalDeviceMultiviewFeatures,
-- VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX,
-- VkPhysicalDeviceMultiviewProperties,
-- VkPhysicalDevicePointClippingProperties,
-- VkPhysicalDeviceProperties2,
-- VkPhysicalDeviceProtectedMemoryFeatures,
-- VkPhysicalDeviceProtectedMemoryProperties,
-- VkPhysicalDevicePushDescriptorPropertiesKHR,
-- VkPhysicalDeviceSampleLocationsPropertiesEXT,
-- VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT,
-- VkPhysicalDeviceSamplerYcbcrConversionFeatures,
-- VkPhysicalDeviceShaderCorePropertiesAMD,
-- VkPhysicalDeviceShaderDrawParameterFeatures,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- VkPhysicalDeviceSubgroupProperties,
-- VkPhysicalDeviceSurfaceInfo2KHR,
-- VkPhysicalDeviceVariablePointerFeatures,
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT,
-- VkPipelineCacheCreateInfo,
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT,
-- VkPipelineColorBlendStateCreateInfo,
-- VkPipelineCoverageModulationStateCreateInfoNV,
-- VkPipelineCoverageToColorStateCreateInfoNV,
-- VkPipelineDepthStencilStateCreateInfo,
-- VkPipelineDiscardRectangleStateCreateInfoEXT,
-- VkPipelineDynamicStateCreateInfo,
-- VkPipelineInputAssemblyStateCreateInfo,
-- VkPipelineLayoutCreateInfo,
-- VkPipelineMultisampleStateCreateInfo,
-- VkPipelineRasterizationConservativeStateCreateInfoEXT,
-- VkPipelineRasterizationStateCreateInfo,
-- VkPipelineRasterizationStateRasterizationOrderAMD,
-- VkPipelineSampleLocationsStateCreateInfoEXT,
-- VkPipelineShaderStageCreateInfo,
-- VkPipelineTessellationDomainOriginStateCreateInfo,
-- VkPipelineTessellationStateCreateInfo,
-- VkPipelineVertexInputDivisorStateCreateInfoEXT,
-- VkPipelineVertexInputStateCreateInfo,
-- VkPipelineViewportStateCreateInfo,
-- VkPipelineViewportSwizzleStateCreateInfoNV,
-- VkPipelineViewportWScalingStateCreateInfoNV,
-- VkPresentInfoKHR, VkPresentRegionsKHR,
-- VkPresentTimesInfoGOOGLE, VkProtectedSubmitInfo,
-- VkQueryPoolCreateInfo, VkQueueFamilyProperties2,
-- VkRenderPassBeginInfo, VkRenderPassCreateInfo,
-- VkRenderPassInputAttachmentAspectCreateInfo,
-- VkRenderPassMultiviewCreateInfo,
-- VkRenderPassSampleLocationsBeginInfoEXT,
-- VkSampleLocationsInfoEXT, VkSamplerCreateInfo,
-- VkSamplerReductionModeCreateInfoEXT,
-- VkSamplerYcbcrConversionCreateInfo,
-- VkSamplerYcbcrConversionImageFormatProperties,
-- VkSamplerYcbcrConversionInfo, VkSemaphoreCreateInfo,
-- VkSemaphoreGetFdInfoKHR,
-- VkSemaphoreGetWin32HandleInfoKHR,
-- VkShaderModuleCreateInfo,
-- VkShaderModuleValidationCacheCreateInfoEXT,
-- VkSharedPresentSurfaceCapabilitiesKHR,
-- VkSparseImageFormatProperties2,
-- VkSparseImageMemoryRequirements2, VkSubmitInfo,
-- VkSurfaceCapabilities2EXT, VkSurfaceCapabilities2KHR,
-- VkSurfaceFormat2KHR, VkSwapchainCounterCreateInfoEXT,
-- VkSwapchainCreateInfoKHR,
-- VkTextureLODGatherFormatPropertiesAMD,
-- VkValidationCacheCreateInfoEXT, VkValidationFlagsEXT,
-- VkViSurfaceCreateInfoNN, VkWaylandSurfaceCreateInfoKHR,
-- VkWin32KeyedMutexAcquireReleaseInfoKHR,
-- VkWin32KeyedMutexAcquireReleaseInfoNV,
-- VkWin32SurfaceCreateInfoKHR, VkWriteDescriptorSet,
-- VkXcbSurfaceCreateInfoKHR, VkXlibSurfaceCreateInfoKHR
newtype VkStructureType
VkStructureType :: Int32 -> VkStructureType
-- | VkObjectType - Specify an enumeration to track object handle types
--
-- Description
--
--
-- +------------------------------------------+---------------------------+
-- | 'VkObjectType' | Vulkan Handle Type |
-- +==========================================+===========================+
-- | @VK_OBJECT_TYPE_UNKNOWN@ | Unknown\/Undefined Handle |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_INSTANCE@ | 'Graphics.Vulkan.Core10.D |
-- | | eviceInitialization.VkIns |
-- | | tance' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_PHYSICAL_DEVICE@ | 'Graphics.Vulkan.Core10.D |
-- | | eviceInitialization.VkPhy |
-- | | sicalDevice' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DEVICE@ | 'Graphics.Vulkan.Core10.D |
-- | | eviceInitialization.VkDev |
-- | | ice' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_QUEUE@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkQueue' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_SEMAPHORE@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkSemaphore' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_COMMAND_BUFFER@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkCommandBuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_FENCE@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkFence' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DEVICE_MEMORY@ | 'Graphics.Vulkan.Core10.M |
-- | | emory.VkDeviceMemory' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_BUFFER@ | 'Graphics.Vulkan.Core10.M |
-- | | emoryManagement.VkBuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_IMAGE@ | 'Graphics.Vulkan.Core10.M |
-- | | emoryManagement.VkImage' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_EVENT@ | 'Graphics.Vulkan.Core10.E |
-- | | vent.VkEvent' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_QUERY_POOL@ | 'Graphics.Vulkan.Core10.Q |
-- | | uery.VkQueryPool' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_BUFFER_VIEW@ | 'Graphics.Vulkan.Core10.B |
-- | | ufferView.VkBufferView' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_IMAGE_VIEW@ | 'Graphics.Vulkan.Core10.I |
-- | | mageView.VkImageView' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_SHADER_MODULE@ | 'Graphics.Vulkan.Core10.S |
-- | | hader.VkShaderModule' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_PIPELINE_CACHE@ | 'Graphics.Vulkan.Core10.P |
-- | | ipelineCache.VkPipelineCa |
-- | | che' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_PIPELINE_LAYOUT@ | 'Graphics.Vulkan.Core10.P |
-- | | ipeline.VkPipelineLayout' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_RENDER_PASS@ | 'Graphics.Vulkan.Core10.P |
-- | | ipeline.VkRenderPass' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_PIPELINE@ | 'Graphics.Vulkan.Core10.P |
-- | | ipeline.VkPipeline' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DESCRIPTOR_SET_LAYOUT@ | 'Graphics.Vulkan.Core10.P |
-- | | ipelineLayout.VkDescripto |
-- | | rSetLayout' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_SAMPLER@ | 'Graphics.Vulkan.Core10.S |
-- | | ampler.VkSampler' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DESCRIPTOR_POOL@ | 'Graphics.Vulkan.Core10.D |
-- | | escriptorSet.VkDescriptor |
-- | | Pool' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DESCRIPTOR_SET@ | 'Graphics.Vulkan.Core10.D |
-- | | escriptorSet.VkDescriptor |
-- | | Set' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_FRAMEBUFFER@ | 'Graphics.Vulkan.Core10.P |
-- | | ass.VkFramebuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_COMMAND_POOL@ | 'Graphics.Vulkan.Core10.C |
-- | | ommandPool.VkCommandPool' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_SURFACE_KHR@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_KHR_surface.VkSurfa |
-- | | ceKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_SWAPCHAIN_KHR@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_KHR_swapchain.VkSwa |
-- | | pchainKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DISPLAY_KHR@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_KHR_display.VkDispl |
-- | | ayKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DISPLAY_MODE_KHR@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_KHR_display.VkDispl |
-- | | ayModeKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EX | 'Graphics.Vulkan.Extensio |
-- | T@ | ns.VK_EXT_debug_report.Vk |
-- | | DebugReportCallbackEXT' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_DESCRIPTOR_UPDATE_TEMPLA | 'Graphics.Vulkan.Core11.P |
-- | TE@ | romoted_from_VK_KHR_descr |
-- | | iptor_update_template.VkD |
-- | | escriptorUpdateTemplate' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_OBJECT_TABLE_NVX@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_NVX_device_generate |
-- | | d_commands.VkObjectTableN |
-- | | VX' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_INDIRECT_COMMANDS_LAYOUT | 'Graphics.Vulkan.Extensio |
-- | _NVX@ | ns.VK_NVX_device_generate |
-- | | d_commands.VkIndirectComm |
-- | | andsLayoutNVX' |
-- +------------------------------------------+---------------------------+
-- | @VK_OBJECT_TYPE_VALIDATION_CACHE_EXT@ | 'Graphics.Vulkan.Extensio |
-- | | ns.VK_EXT_validation_cach |
-- | | e.VkValidationCacheEXT' |
-- +------------------------------------------+---------------------------+
--
-- VkObjectType and Vulkan Handle Relationship
--
--
-- See Also
--
-- VkDebugUtilsObjectNameInfoEXT,
-- VkDebugUtilsObjectTagInfoEXT
newtype VkObjectType
VkObjectType :: Int32 -> VkObjectType
-- | VkFlags - Vulkan bitmasks
--
-- Description
--
-- Bitmasks are passed to many commands and structures to compactly
-- represent options, but VkFlags is not used directly in the
-- API. Instead, a Vk*Flags type which is an alias of
-- VkFlags, and whose name matches the corresponding
-- Vk*FlagBits that are valid for that type, is used.
--
-- See Also
--
-- VkColorComponentFlags
type VkFlags = Word32
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Core.VkObjectType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Core.VkObjectType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Core.VkObjectType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Core.VkStructureType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Core.VkStructureType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Core.VkStructureType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Core.VkResult
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Core.VkResult
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Core.VkResult
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Core.VkFormat
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Core.VkFormat
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Core.VkFormat
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Core.VkBool32
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Core.VkBool32
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Core.VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core10.Core.VkObjectType
instance GHC.Read.Read Graphics.Vulkan.Core10.Core.VkObjectType
instance GHC.Show.Show Graphics.Vulkan.Core10.Core.VkStructureType
instance GHC.Read.Read Graphics.Vulkan.Core10.Core.VkStructureType
instance GHC.Show.Show Graphics.Vulkan.Core10.Core.VkResult
instance GHC.Read.Read Graphics.Vulkan.Core10.Core.VkResult
instance GHC.Show.Show Graphics.Vulkan.Core10.Core.VkFormat
instance GHC.Read.Read Graphics.Vulkan.Core10.Core.VkFormat
instance GHC.Show.Show Graphics.Vulkan.Core10.Core.VkBool32
instance GHC.Read.Read Graphics.Vulkan.Core10.Core.VkBool32
module Graphics.Vulkan.Core10.Version
-- | VK_HEADER_VERSION - Vulkan header file version number
--
-- Description
--
-- See Also
--
-- No cross-references are available
-- | VK_MAKE_VERSION - Construct an API version number
--
-- Description
--
--
-- - major is the major version number.
--
--
--
-- - minor is the minor version number.
-- - patch is the patch version number.
--
--
-- This macro can be used when constructing the
-- VkApplicationInfo::apiVersion parameter passed to
-- vkCreateInstance.
--
-- See Also
--
-- VkApplicationInfo, vkCreateInstance
-- | VK_API_VERSION_1_0 - Return API version number for Vulkan 1.0
--
-- Description
--
-- See Also
--
-- vkCreateInstance, vkGetPhysicalDeviceProperties
-- | VK_API_VERSION_1_1 - Return API version number for Vulkan 1.1
--
-- Description
--
-- See Also
--
-- vkCreateInstance, vkGetPhysicalDeviceProperties
-- | VK_VERSION_MAJOR - Extract API major version number
--
-- Description
--
-- See Also
--
-- No cross-references are available
_VK_VERSION_MAJOR :: Word32 -> Word32
-- | VK_VERSION_MINOR - Extract API minor version number
--
-- Description
--
-- See Also
--
-- No cross-references are available
_VK_VERSION_MINOR :: Word32 -> Word32
_VK_VERSION_PATCH :: Word32 -> Word32
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_16bit_storage
-- | VkPhysicalDevice16BitStorageFeatures - Structure describing features
-- supported by VK_KHR_16bit_storage
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDevice16BitStorageFeatures
VkPhysicalDevice16BitStorageFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDevice16BitStorageFeatures
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> Ptr ()
-- | storageBuffer16BitAccess specifies whether objects in the
-- StorageBuffer storage class with the Block
-- decoration can have 16-bit integer and 16-bit floating-point
-- members. If this feature is not enabled, 16-bit integer or 16-bit
-- floating-point members must not be used in such objects. This
-- also specifies whether shader modules can declare the
-- StorageBuffer16BitAccess capability.
[$sel:vkStorageBuffer16BitAccess:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> VkBool32
-- | uniformAndStorageBuffer16BitAccess specifies whether objects
-- in the Uniform storage class with the Block
-- decoration and in the StorageBuffer storage class with the
-- same decoration can have 16-bit integer and 16-bit
-- floating-point members. If this feature is not enabled, 16-bit integer
-- or 16-bit floating-point members must not be used in such
-- objects. This also specifies whether shader modules can declare
-- the UniformAndStorageBuffer16BitAccess capability.
[$sel:vkUniformAndStorageBuffer16BitAccess:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> VkBool32
-- | storagePushConstant16 specifies whether objects in the
-- PushConstant storage class can have 16-bit integer and
-- 16-bit floating-point members. If this feature is not enabled, 16-bit
-- integer or floating-point members must not be used in such
-- objects. This also specifies whether shader modules can declare
-- the StoragePushConstant16 capability.
[$sel:vkStoragePushConstant16:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> VkBool32
-- | storageInputOutput16 specifies whether objects in the
-- Input and Output storage classes can have
-- 16-bit integer and 16-bit floating-point members. If this feature is
-- not enabled, 16-bit integer or 16-bit floating-point members
-- must not be used in such objects. This also specifies whether
-- shader modules can declare the StorageInputOutput16
-- capability.
[$sel:vkStorageInputOutput16:VkPhysicalDevice16BitStorageFeatures] :: VkPhysicalDevice16BitStorageFeatures -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_16bit_storage.VkPhysicalDevice16BitStorageFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_16bit_storage.VkPhysicalDevice16BitStorageFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_16bit_storage.VkPhysicalDevice16BitStorageFeatures
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_shader_draw_parameters
-- | VkPhysicalDeviceShaderDrawParameterFeatures - Structure describing
-- shader draw parameter features that can be supported by an
-- implementation
--
-- Description
--
-- If the VkPhysicalDeviceShaderDrawParameterFeatures structure
-- is included in the pNext chain of
-- VkPhysicalDeviceFeatures2, it is filled with a value indicating
-- whether the feature is supported.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_DRAW_PARAMETER_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceShaderDrawParameterFeatures
VkPhysicalDeviceShaderDrawParameterFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceShaderDrawParameterFeatures
[$sel:vkSType:VkPhysicalDeviceShaderDrawParameterFeatures] :: VkPhysicalDeviceShaderDrawParameterFeatures -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceShaderDrawParameterFeatures] :: VkPhysicalDeviceShaderDrawParameterFeatures -> Ptr ()
-- | shaderDrawParameters specifies whether shader draw parameters
-- are supported.
[$sel:vkShaderDrawParameters:VkPhysicalDeviceShaderDrawParameterFeatures] :: VkPhysicalDeviceShaderDrawParameterFeatures -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_shader_draw_parameters.VkPhysicalDeviceShaderDrawParameterFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_shader_draw_parameters.VkPhysicalDeviceShaderDrawParameterFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_shader_draw_parameters.VkPhysicalDeviceShaderDrawParameterFeatures
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_variable_pointers
-- | VkPhysicalDeviceVariablePointerFeatures - Structure describing
-- variable pointers features that can be supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceVariablePointerFeatures
-- structure describe the following features:
--
-- Description
--
--
-- - variablePointersStorageBuffer specifies whether the
-- implementation supports the SPIR-V
-- VariablePointersStorageBuffer capability. When this feature
-- is not enabled, shader modules must not declare the
-- SPV_KHR_variable_pointers extension or the
-- VariablePointersStorageBuffer capability.
--
--
--
-- - variablePointers specifies whether the implementation
-- supports the SPIR-V VariablePointers capability. When this
-- feature is not enabled, shader modules must not declare the
-- VariablePointers capability.
--
--
-- If the VkPhysicalDeviceVariablePointerFeatures structure is
-- included in the pNext chain of
-- VkPhysicalDeviceFeatures2, it is filled with values indicating
-- whether each feature is supported.
-- VkPhysicalDeviceVariablePointerFeatures can also be
-- used in the pNext chain of VkDeviceCreateInfo to
-- enable the features.
--
-- Valid Usage
--
--
-- - If variablePointers is enabled then
-- variablePointersStorageBuffer must also be
-- enabled.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VARIABLE_POINTER_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceVariablePointerFeatures
VkPhysicalDeviceVariablePointerFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkPhysicalDeviceVariablePointerFeatures
[$sel:vkSType:VkPhysicalDeviceVariablePointerFeatures] :: VkPhysicalDeviceVariablePointerFeatures -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceVariablePointerFeatures] :: VkPhysicalDeviceVariablePointerFeatures -> Ptr ()
[$sel:vkVariablePointersStorageBuffer:VkPhysicalDeviceVariablePointerFeatures] :: VkPhysicalDeviceVariablePointerFeatures -> VkBool32
[$sel:vkVariablePointers:VkPhysicalDeviceVariablePointerFeatures] :: VkPhysicalDeviceVariablePointerFeatures -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_variable_pointers.VkPhysicalDeviceVariablePointerFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_variable_pointers.VkPhysicalDeviceVariablePointerFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_variable_pointers.VkPhysicalDeviceVariablePointerFeatures
module Graphics.Vulkan.Extensions.VK_AMD_gcn_shader
module Graphics.Vulkan.Extensions.VK_AMD_gpu_shader_half_float
module Graphics.Vulkan.Extensions.VK_AMD_gpu_shader_int16
module Graphics.Vulkan.Extensions.VK_AMD_mixed_attachment_samples
module Graphics.Vulkan.Extensions.VK_AMD_negative_viewport_height
module Graphics.Vulkan.Extensions.VK_AMD_rasterization_order
-- | VkRasterizationOrderAMD - Specify rasterization order for a graphics
-- pipeline
--
-- See Also
--
-- VkPipelineRasterizationStateRasterizationOrderAMD
newtype VkRasterizationOrderAMD
VkRasterizationOrderAMD :: Int32 -> VkRasterizationOrderAMD
-- | VK_RASTERIZATION_ORDER_STRICT_AMD specifies that operations
-- for each primitive in a subpass must occur in primitive
-- order.
-- | VK_RASTERIZATION_ORDER_RELAXED_AMD specifies that operations
-- for each primitive in a subpass may not occur in primitive
-- order.
-- | VkPipelineRasterizationStateRasterizationOrderAMD - Structure defining
-- rasterization order for a graphics pipeline
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_RASTERIZATION_ORDER_AMD
--
--
--
--
-- If the {html_spec_relative}#VK_AMD_rasterization_order device
-- extension is not enabled or the application does not request a
-- particular rasterization order through specifying a
-- VkPipelineRasterizationStateRasterizationOrderAMD structure
-- then the rasterization order used by the graphics pipeline defaults to
-- VK_RASTERIZATION_ORDER_STRICT_AMD.
--
-- See Also
--
-- VkRasterizationOrderAMD, VkStructureType
data VkPipelineRasterizationStateRasterizationOrderAMD
VkPipelineRasterizationStateRasterizationOrderAMD :: VkStructureType -> Ptr () -> VkRasterizationOrderAMD -> VkPipelineRasterizationStateRasterizationOrderAMD
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineRasterizationStateRasterizationOrderAMD] :: VkPipelineRasterizationStateRasterizationOrderAMD -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineRasterizationStateRasterizationOrderAMD] :: VkPipelineRasterizationStateRasterizationOrderAMD -> Ptr ()
-- | rasterizationOrder is a VkRasterizationOrderAMD value
-- specifying the primitive rasterization order to use.
[$sel:vkRasterizationOrder:VkPipelineRasterizationStateRasterizationOrderAMD] :: VkPipelineRasterizationStateRasterizationOrderAMD -> VkRasterizationOrderAMD
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkPipelineRasterizationStateRasterizationOrderAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkPipelineRasterizationStateRasterizationOrderAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkRasterizationOrderAMD
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkRasterizationOrderAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkRasterizationOrderAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkPipelineRasterizationStateRasterizationOrderAMD
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkRasterizationOrderAMD
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_AMD_rasterization_order.VkRasterizationOrderAMD
module Graphics.Vulkan.Extensions.VK_AMD_shader_ballot
module Graphics.Vulkan.Extensions.VK_AMD_shader_core_properties
-- | VkPhysicalDeviceShaderCorePropertiesAMD - Structure describing shader
-- core properties that can be supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceShaderCorePropertiesAMD
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - shaderEngineCount is an unsigned integer value indicating
-- the number of shader engines found inside the shader core of the
-- physical device.
--
--
--
-- - shaderArraysPerEngineCount is an unsigned integer value
-- indicating the number of shader arrays inside a shader engine. Each
-- shader array has its own scan converter, set of compute units, and a
-- render back end (color and depth buffers). Shader arrays within a
-- shader engine share shader processor input (wave launcher) and shader
-- export (export buffer) units. Currently, a shader engine can have one
-- or two shader arrays.
-- - computeUnitsPerShaderArray is an unsigned integer value
-- indicating the number of compute units within a shader array. A
-- compute unit houses a set of SIMDs along with a sequencer module and a
-- local data store.
-- - simdPerComputeUnit is an unsigned integer value
-- indicating the number of SIMDs inside a compute unit. Each SIMD
-- processes a single instruction at a time.
-- - wavefrontSize is an unsigned integer value indicating the
-- number of channels (or threads) in a wavefront.
-- - sgprsPerSimd is an unsigned integer value indicating the
-- number of physical Scalar General Purpose Registers (SGPRs) per
-- SIMD.
-- - minSgprAllocation is an unsigned integer value indicating
-- the minimum number of SGPRs allocated for a wave.
-- - maxSgprAllocation is an unsigned integer value indicating
-- the maximum number of SGPRs allocated for a wave.
-- - sgprAllocationGranularity is an unsigned integer value
-- indicating the granularity of SGPR allocation for a wave.
-- - vgprsPerSimd is an unsigned integer value indicating the
-- number of physical Vector General Purpose Registers (VGPRs) per
-- SIMD.
-- - minVgprAllocation is an unsigned integer value indicating
-- the minimum number of VGPRs allocated for a wave.
-- - maxVgprAllocation is an unsigned integer value indicating
-- the maximum number of VGPRs allocated for a wave.
-- - vgprAllocationGranularity is an unsigned integer value
-- indicating the granularity of VGPR allocation for a wave.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_CORE_PROPERTIES_AMD
--
--
-- If the VkPhysicalDeviceShaderCorePropertiesAMD structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkStructureType
data VkPhysicalDeviceShaderCorePropertiesAMD
VkPhysicalDeviceShaderCorePropertiesAMD :: VkStructureType -> Ptr () -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> VkPhysicalDeviceShaderCorePropertiesAMD
[$sel:vkSType:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Ptr ()
[$sel:vkShaderEngineCount:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkShaderArraysPerEngineCount:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkComputeUnitsPerShaderArray:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkSimdPerComputeUnit:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkWavefrontsPerSimd:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkWavefrontSize:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkSgprsPerSimd:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkMinSgprAllocation:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkMaxSgprAllocation:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkSgprAllocationGranularity:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkVgprsPerSimd:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkMinVgprAllocation:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkMaxVgprAllocation:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
[$sel:vkVgprAllocationGranularity:VkPhysicalDeviceShaderCorePropertiesAMD] :: VkPhysicalDeviceShaderCorePropertiesAMD -> Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_shader_core_properties.VkPhysicalDeviceShaderCorePropertiesAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_shader_core_properties.VkPhysicalDeviceShaderCorePropertiesAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_shader_core_properties.VkPhysicalDeviceShaderCorePropertiesAMD
module Graphics.Vulkan.Extensions.VK_AMD_shader_explicit_vertex_parameter
module Graphics.Vulkan.Extensions.VK_AMD_shader_fragment_mask
module Graphics.Vulkan.Extensions.VK_AMD_shader_image_load_store_lod
module Graphics.Vulkan.Extensions.VK_AMD_shader_trinary_minmax
module Graphics.Vulkan.Extensions.VK_AMD_texture_gather_bias_lod
-- | VkTextureLODGatherFormatPropertiesAMD - Structure informing whether or
-- not texture gather bias/LOD functionality is supported for a given
-- image format and a given physical device.
--
-- Description
--
-- See Also
--
-- VkBool32, VkStructureType
data VkTextureLODGatherFormatPropertiesAMD
VkTextureLODGatherFormatPropertiesAMD :: VkStructureType -> Ptr () -> VkBool32 -> VkTextureLODGatherFormatPropertiesAMD
-- | sType is the type of this structure.
[$sel:vkSType:VkTextureLODGatherFormatPropertiesAMD] :: VkTextureLODGatherFormatPropertiesAMD -> VkStructureType
-- | pNext is NULL.
[$sel:vkPNext:VkTextureLODGatherFormatPropertiesAMD] :: VkTextureLODGatherFormatPropertiesAMD -> Ptr ()
-- | supportsTextureGatherLODBiasAMD tells if the image format can
-- be used with texture gather bias/LOD functions, as introduced by the
-- {html_spec_relative}#VK_AMD_texture_gather_bias_lod
-- extension. This field is set by the implementation. User-specified
-- value is ignored.
[$sel:vkSupportsTextureGatherLODBiasAMD:VkTextureLODGatherFormatPropertiesAMD] :: VkTextureLODGatherFormatPropertiesAMD -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_texture_gather_bias_lod.VkTextureLODGatherFormatPropertiesAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_texture_gather_bias_lod.VkTextureLODGatherFormatPropertiesAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_texture_gather_bias_lod.VkTextureLODGatherFormatPropertiesAMD
module Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization
-- | VkConservativeRasterizationModeEXT - Specify the conservative
-- rasterization mode
--
-- See Also
--
-- VkPipelineRasterizationConservativeStateCreateInfoEXT
newtype VkConservativeRasterizationModeEXT
VkConservativeRasterizationModeEXT :: Int32 -> VkConservativeRasterizationModeEXT
-- | VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT specifies
-- that conservative rasterization is disabled and rasterization proceeds
-- as normal.
-- | VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT specifies
-- that conservative rasterization is enabled in overestimation mode.
-- | VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT
-- specifies that conservative rasterization is enabled in
-- underestimation mode.
-- | VkPipelineRasterizationConservativeStateCreateFlagsEXT - Reserved for
-- future use
--
-- Description
--
-- VkPipelineRasterizationConservativeStateCreateFlagsEXT is a
-- bitmask type for setting a mask, but is currently reserved for future
-- use.
--
-- See Also
--
-- VkPipelineRasterizationConservativeStateCreateInfoEXT
newtype VkPipelineRasterizationConservativeStateCreateFlagsEXT
VkPipelineRasterizationConservativeStateCreateFlagsEXT :: VkFlags -> VkPipelineRasterizationConservativeStateCreateFlagsEXT
-- | VkPhysicalDeviceConservativeRasterizationPropertiesEXT - Structure
-- describing conservative raster properties that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - primitiveOverestimationSize is the size in pixels the
-- generating primitive is increased at each of its edges during
-- conservative rasterization overestimation mode. Even with a size of
-- 0.0, conservative rasterization overestimation rules still apply and
-- if any part of the pixel rectangle is covered by the generating
-- primitive, fragments are generated for the entire pixel. However
-- implementations may make the pixel coverage area even more
-- conservative by increasing the size of the generating primitive.
--
--
--
-- - maxExtraPrimitiveOverestimationSize is the maximum size
-- in pixels of extra overestimation the implementation supports in the
-- pipeline state. A value of 0.0 means the implementation does not
-- support any additional overestimation of the generating primitive
-- during conservative rasterization. A value above 0.0 allows the
-- application to further increase the size of the generating primitive
-- during conservative rasterization overestimation.
-- - extraPrimitiveOverestimationSizeGranularity is the
-- granularity of extra overestimation that can be specified in the
-- pipeline state between 0.0 and
-- maxExtraPrimitiveOverestimationSize inclusive. A value of 0.0
-- means the implementation can use the smallest representable non-zero
-- value in the screen space pixel fixed-point grid.
-- - primitiveUnderestimation is true if the implementation
-- supports the
-- VK_CONSERVATIVE_RASTERIZATION_MODE_UNDERESTIMATE_EXT
-- conservative rasterization mode in addition to
-- VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT.
-- Otherwise the implementation only supports
-- VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT.
-- - conservativePointAndLineRasterization is true if the
-- implementation supports conservative rasterization of point and line
-- primitives as well as triangle primitives. Otherwise the
-- implementation only supports triangle primitives.
-- - degenerateTrianglesRasterized is false if the
-- implementation culls primitives generated from triangles that become
-- zero area after they are quantized to the fixed-point rasterization
-- pixel grid. degenerateTrianglesRasterized is true if these
-- primitives are not culled and the provoking vertex attributes and
-- depth value are used for the fragments. The primitive area calculation
-- is done on the primitive generated from the clipped triangle if
-- applicable. Zero area primitives are backfacing and the application
-- can enable backface culling if desired.
-- - degenerateLinesRasterized is false if the implementation
-- culls lines that become zero length after they are quantized to the
-- fixed-point rasterization pixel grid.
-- degenerateLinesRasterized is true if zero length lines are
-- not culled and the provoking vertex attributes and depth value are
-- used for the fragments.
-- - fullyCoveredFragmentShaderInputVariable is true if the
-- implementation supports the SPIR-V builtin fragment shader input
-- variable FullyCoveredEXT which specifies that conservative
-- rasterization is enabled and the fragment pixel square is fully
-- covered by the generating primitive.
-- - conservativeRasterizationPostDepthCoverage is true if the
-- implementation supports conservative rasterization with the
-- PostDepthCoverage execution mode enabled. When supported the
-- SampleMask built-in input variable will reflect the coverage
-- after the early per-fragment depth and stencil tests are applied even
-- when conservative rasterization is enabled. Otherwise
-- PostDepthCoverage execution mode must not be used when
-- conservative rasterization is enabled.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_CONSERVATIVE_RASTERIZATION_PROPERTIES_EXT
--
--
-- If the VkPhysicalDeviceConservativeRasterizationPropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2KHR, it is filled with the
-- implementation-dependent limits and properties.
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceConservativeRasterizationPropertiesEXT
VkPhysicalDeviceConservativeRasterizationPropertiesEXT :: VkStructureType -> Ptr () -> CFloat -> CFloat -> CFloat -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceConservativeRasterizationPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> Ptr ()
[$sel:vkPrimitiveOverestimationSize:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> CFloat
[$sel:vkMaxExtraPrimitiveOverestimationSize:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> CFloat
[$sel:vkExtraPrimitiveOverestimationSizeGranularity:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> CFloat
[$sel:vkPrimitiveUnderestimation:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
[$sel:vkConservativePointAndLineRasterization:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
[$sel:vkDegenerateTrianglesRasterized:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
[$sel:vkDegenerateLinesRasterized:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
[$sel:vkFullyCoveredFragmentShaderInputVariable:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
[$sel:vkConservativeRasterizationPostDepthCoverage:VkPhysicalDeviceConservativeRasterizationPropertiesEXT] :: VkPhysicalDeviceConservativeRasterizationPropertiesEXT -> VkBool32
-- | VkPipelineRasterizationConservativeStateCreateInfoEXT - Structure
-- specifying conservative raster state
--
-- Description
--
-- Valid Usage
--
--
-- - extraPrimitiveOverestimationSize must be in the
-- range of 0.0 to
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT::maxExtraPrimitiveOverestimationSize
-- inclusive
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkConservativeRasterizationModeEXT,
-- VkPipelineRasterizationConservativeStateCreateFlagsEXT,
-- VkStructureType
data VkPipelineRasterizationConservativeStateCreateInfoEXT
VkPipelineRasterizationConservativeStateCreateInfoEXT :: VkStructureType -> Ptr () -> VkPipelineRasterizationConservativeStateCreateFlagsEXT -> VkConservativeRasterizationModeEXT -> CFloat -> VkPipelineRasterizationConservativeStateCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineRasterizationConservativeStateCreateInfoEXT] :: VkPipelineRasterizationConservativeStateCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineRasterizationConservativeStateCreateInfoEXT] :: VkPipelineRasterizationConservativeStateCreateInfoEXT -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineRasterizationConservativeStateCreateInfoEXT] :: VkPipelineRasterizationConservativeStateCreateInfoEXT -> VkPipelineRasterizationConservativeStateCreateFlagsEXT
-- | conservativeRasterizationMode is the conservative
-- rasterization mode to use.
[$sel:vkConservativeRasterizationMode:VkPipelineRasterizationConservativeStateCreateInfoEXT] :: VkPipelineRasterizationConservativeStateCreateInfoEXT -> VkConservativeRasterizationModeEXT
-- | extraPrimitiveOverestimationSize is the extra size in pixels
-- to increase the generating primitive during conservative rasterization
-- at each of its edges in X and Y equally in screen
-- space beyond the base overestimation specified in
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT::primitiveOverestimationSize.
[$sel:vkExtraPrimitiveOverestimationSize:VkPipelineRasterizationConservativeStateCreateInfoEXT] :: VkPipelineRasterizationConservativeStateCreateInfoEXT -> CFloat
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPhysicalDeviceConservativeRasterizationPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPhysicalDeviceConservativeRasterizationPropertiesEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkConservativeRasterizationModeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkConservativeRasterizationModeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkConservativeRasterizationModeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPhysicalDeviceConservativeRasterizationPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkPipelineRasterizationConservativeStateCreateFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkConservativeRasterizationModeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_conservative_rasterization.VkConservativeRasterizationModeEXT
module Graphics.Vulkan.Extensions.VK_EXT_depth_range_unrestricted
module Graphics.Vulkan.Extensions.VK_EXT_global_priority
-- | VkQueueGlobalPriorityEXT - Values specifying a system-wide queue
-- priority
--
-- Description
--
-- Priority values are sorted in ascending order. A comparison operation
-- on the enum values can be used to determine the priority order.
--
--
-- - VK_QUEUE_GLOBAL_PRIORITY_LOW_EXT is below the system
-- default. Useful for non-interactive tasks.
-- - VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT is the system default
-- priority.
-- - VK_QUEUE_GLOBAL_PRIORITY_HIGH_EXT is above the system
-- default.
-- - VK_QUEUE_GLOBAL_PRIORITY_REALTIME_EXT is the highest
-- priority. Useful for critical tasks.
--
--
-- See Also
--
-- VkDeviceQueueGlobalPriorityCreateInfoEXT
newtype VkQueueGlobalPriorityEXT
VkQueueGlobalPriorityEXT :: Int32 -> VkQueueGlobalPriorityEXT
-- | VkDeviceQueueGlobalPriorityCreateInfoEXT - Specify a system wide
-- priority
--
-- Description
--
-- A queue created without specifying
-- VkDeviceQueueGlobalPriorityCreateInfoEXT will default to
-- VK_QUEUE_GLOBAL_PRIORITY_MEDIUM_EXT.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_QUEUE_GLOBAL_PRIORITY_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkQueueGlobalPriorityEXT, VkStructureType
data VkDeviceQueueGlobalPriorityCreateInfoEXT
VkDeviceQueueGlobalPriorityCreateInfoEXT :: VkStructureType -> Ptr () -> VkQueueGlobalPriorityEXT -> VkDeviceQueueGlobalPriorityCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceQueueGlobalPriorityCreateInfoEXT] :: VkDeviceQueueGlobalPriorityCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceQueueGlobalPriorityCreateInfoEXT] :: VkDeviceQueueGlobalPriorityCreateInfoEXT -> Ptr ()
-- | globalPriority is the system-wide priority associated to this
-- queue as specified by VkQueueGlobalPriorityEXT
[$sel:vkGlobalPriority:VkDeviceQueueGlobalPriorityCreateInfoEXT] :: VkDeviceQueueGlobalPriorityCreateInfoEXT -> VkQueueGlobalPriorityEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkDeviceQueueGlobalPriorityCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkDeviceQueueGlobalPriorityCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkQueueGlobalPriorityEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkQueueGlobalPriorityEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkQueueGlobalPriorityEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkDeviceQueueGlobalPriorityCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkQueueGlobalPriorityEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_global_priority.VkQueueGlobalPriorityEXT
module Graphics.Vulkan.Extensions.VK_EXT_post_depth_coverage
module Graphics.Vulkan.Extensions.VK_EXT_queue_family_foreign
module Graphics.Vulkan.Extensions.VK_EXT_shader_stencil_export
module Graphics.Vulkan.Extensions.VK_EXT_shader_subgroup_ballot
module Graphics.Vulkan.Extensions.VK_EXT_shader_subgroup_vote
module Graphics.Vulkan.Extensions.VK_EXT_shader_viewport_index_layer
module Graphics.Vulkan.Extensions.VK_EXT_validation_flags
-- | VkValidationCheckEXT - Specify validation checks to disable
--
-- See Also
--
-- VkValidationFlagsEXT
newtype VkValidationCheckEXT
VkValidationCheckEXT :: Int32 -> VkValidationCheckEXT
-- | VK_VALIDATION_CHECK_ALL_EXT specifies that all validation
-- checks are disabled.
-- | VK_VALIDATION_CHECK_SHADERS_EXT specifies that shader
-- validation is disabled.
-- | VkValidationFlagsEXT - Specify validation checks to disable for a
-- Vulkan instance
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_VALIDATION_FLAGS_EXT
--
--
--
-- - pDisabledValidationChecks must be a valid pointer
-- to an array of disabledValidationCheckCount
-- VkValidationCheckEXT values
-- - disabledValidationCheckCount must be greater than
-- 0
--
--
-- See Also
--
-- VkStructureType, VkValidationCheckEXT
data VkValidationFlagsEXT
VkValidationFlagsEXT :: VkStructureType -> Ptr () -> Word32 -> Ptr VkValidationCheckEXT -> VkValidationFlagsEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkValidationFlagsEXT] :: VkValidationFlagsEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkValidationFlagsEXT] :: VkValidationFlagsEXT -> Ptr ()
-- | disabledValidationCheckCount is the number of checks to
-- disable.
[$sel:vkDisabledValidationCheckCount:VkValidationFlagsEXT] :: VkValidationFlagsEXT -> Word32
-- | pDisabledValidationChecks is a pointer to an array of
-- VkValidationCheckEXT values specifying the validation checks to
-- be disabled.
[$sel:vkPDisabledValidationChecks:VkValidationFlagsEXT] :: VkValidationFlagsEXT -> Ptr VkValidationCheckEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationCheckEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationCheckEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationCheckEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationCheckEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_validation_flags.VkValidationCheckEXT
module Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor
-- | VkVertexInputBindingDivisorDescriptionEXT - Structure specifying a
-- divisor used in instanced rendering
--
-- Description
--
-- If this structure is not used to define a divisor value for an
-- attribute then the divisor has a logical default value of 1.
--
-- Valid Usage
--
--
-- - binding must be less than
-- VkPhysicalDeviceLimits::maxVertexInputBindings
--
--
--
-- - divisor must be a value between 0 and
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT::maxVertexAttribDivisor,
-- inclusive.
-- - VkVertexInputBindingDescription::inputRate
-- must be of type VK_VERTEX_INPUT_RATE_INSTANCE for this
-- binding.
--
--
-- See Also
--
-- VkPipelineVertexInputDivisorStateCreateInfoEXT
data VkVertexInputBindingDivisorDescriptionEXT
VkVertexInputBindingDivisorDescriptionEXT :: Word32 -> Word32 -> VkVertexInputBindingDivisorDescriptionEXT
-- | binding is the binding number for which the divisor is
-- specified.
[$sel:vkBinding:VkVertexInputBindingDivisorDescriptionEXT] :: VkVertexInputBindingDivisorDescriptionEXT -> Word32
-- | divisor is the the number of successive instances that will
-- use the same value of the vertex attribute when instanced rendering is
-- enabled. For example, if the divisor is N, the same vertex attribute
-- will applied to N successive instances before moving on to the next
-- vertex attribute. If a value of 0 is used for the divisor, then the
-- first vertex attribute will be applied to all instances. The maximum
-- value of divisor is implementation dependent and can be queried using
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT::maxVertexAttribDivisor.
[$sel:vkDivisor:VkVertexInputBindingDivisorDescriptionEXT] :: VkVertexInputBindingDivisorDescriptionEXT -> Word32
-- | VkPipelineVertexInputDivisorStateCreateInfoEXT - Structure specifying
-- vertex attributes assignment during instanced rendering
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT
--
--
--
-- - pVertexBindingDivisors must be a valid pointer to
-- an array of vertexBindingDivisorCount
-- VkVertexInputBindingDivisorDescriptionEXT structures
-- - vertexBindingDivisorCount must be greater than
-- 0
--
--
-- See Also
--
-- VkStructureType,
-- VkVertexInputBindingDivisorDescriptionEXT
data VkPipelineVertexInputDivisorStateCreateInfoEXT
VkPipelineVertexInputDivisorStateCreateInfoEXT :: VkStructureType -> Ptr () -> Word32 -> Ptr VkVertexInputBindingDivisorDescriptionEXT -> VkPipelineVertexInputDivisorStateCreateInfoEXT
-- | sType is the type of this structure
[$sel:vkSType:VkPipelineVertexInputDivisorStateCreateInfoEXT] :: VkPipelineVertexInputDivisorStateCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure
[$sel:vkPNext:VkPipelineVertexInputDivisorStateCreateInfoEXT] :: VkPipelineVertexInputDivisorStateCreateInfoEXT -> Ptr ()
-- | vertexBindingDivisorCount is the number of elements in the
-- pVertexBindingDivisors array.
[$sel:vkVertexBindingDivisorCount:VkPipelineVertexInputDivisorStateCreateInfoEXT] :: VkPipelineVertexInputDivisorStateCreateInfoEXT -> Word32
-- | pVertexBindingDivisors is a pointer to an array of
-- VkVertexInputBindingDivisorDescriptionEXT structures, which
-- specifies the divisor value for each binding.
[$sel:vkPVertexBindingDivisors:VkPipelineVertexInputDivisorStateCreateInfoEXT] :: VkPipelineVertexInputDivisorStateCreateInfoEXT -> Ptr VkVertexInputBindingDivisorDescriptionEXT
-- | VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT - Structure
-- describing max value of vertex attribute divisor that can be supported
-- by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxVertexAttribDivisor is the maximum value of the number
-- of instances that will repeat the value of vertex attribute data when
-- instanced rendering is enabled.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_VERTEX_ATTRIBUTE_DIVISOR_PROPERTIES_EXT
--
--
-- See Also
--
-- VkStructureType
data VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT :: VkStructureType -> Ptr () -> Word32 -> VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT] :: VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT] :: VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT -> Ptr ()
[$sel:vkMaxVertexAttribDivisor:VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT] :: VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT -> Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPipelineVertexInputDivisorStateCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPipelineVertexInputDivisorStateCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkVertexInputBindingDivisorDescriptionEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkVertexInputBindingDivisorDescriptionEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkPipelineVertexInputDivisorStateCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_vertex_attribute_divisor.VkVertexInputBindingDivisorDescriptionEXT
module Graphics.Vulkan.Extensions.VK_IMG_format_pvrtc
module Graphics.Vulkan.Extensions.VK_KHR_image_format_list
-- | VkImageFormatListCreateInfoKHR - Specify that an image can be
-- used with a particular set of formats
--
-- Description
--
-- If viewFormatCount is zero, pViewFormats is ignored
-- and the image is created as if the
-- VkImageFormatListCreateInfoKHR structure were not included in
-- the pNext list of VkImageCreateInfo.
--
-- Valid Usage
--
--
-- - If viewFormatCount is not 0, all of the formats
-- in the pViewFormats array must be compatible with the
-- format specified in the format field of
-- VkImageCreateInfo, as described in the compatibility
-- table.
--
--
--
-- - If VkImageCreateInfo::flags does not contain
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT, viewFormatCount
-- must be 0 or 1.
-- - If viewFormatCount is not 0,
-- VkImageCreateInfo::format must be in
-- pViewFormats.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_FORMAT_LIST_CREATE_INFO_KHR
--
--
--
-- - If viewFormatCount is not 0,
-- pViewFormats must be a valid pointer to an array of
-- viewFormatCount valid VkFormat values
--
--
-- See Also
--
-- VkFormat, VkStructureType
data VkImageFormatListCreateInfoKHR
VkImageFormatListCreateInfoKHR :: VkStructureType -> Ptr () -> Word32 -> Ptr VkFormat -> VkImageFormatListCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkImageFormatListCreateInfoKHR] :: VkImageFormatListCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageFormatListCreateInfoKHR] :: VkImageFormatListCreateInfoKHR -> Ptr ()
-- | viewFormatCount is the number of entries in the
-- pViewFormats array.
[$sel:vkViewFormatCount:VkImageFormatListCreateInfoKHR] :: VkImageFormatListCreateInfoKHR -> Word32
-- | pViewFormats is an array which lists of all formats which
-- can be used when creating views of this image.
[$sel:vkPViewFormats:VkImageFormatListCreateInfoKHR] :: VkImageFormatListCreateInfoKHR -> Ptr VkFormat
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_image_format_list.VkImageFormatListCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_image_format_list.VkImageFormatListCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_image_format_list.VkImageFormatListCreateInfoKHR
module Graphics.Vulkan.Extensions.VK_KHR_relaxed_block_layout
module Graphics.Vulkan.Extensions.VK_KHR_shader_draw_parameters
module Graphics.Vulkan.Extensions.VK_KHR_storage_buffer_storage_class
module Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color
-- | VkPipelineCoverageToColorStateCreateFlagsNV - Reserved for future use
--
-- Description
--
-- VkPipelineCoverageToColorStateCreateFlagsNV is a bitmask type
-- for setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineCoverageToColorStateCreateInfoNV
newtype VkPipelineCoverageToColorStateCreateFlagsNV
VkPipelineCoverageToColorStateCreateFlagsNV :: VkFlags -> VkPipelineCoverageToColorStateCreateFlagsNV
-- | VkPipelineCoverageToColorStateCreateInfoNV - Structure specifying
-- whether fragment coverage replaces a color
--
-- Description
--
-- If coverageToColorEnable is VK_TRUE, the fragment
-- coverage information is treated as a bitmask with one bit for each
-- sample (as in the Sample Mask section), and this bitmask
-- replaces the first component of the color value corresponding to the
-- fragment shader output location with Location equal to
-- coverageToColorLocation and Index equal to zero. If
-- the color attachment format has fewer bits than the sample coverage,
-- the low bits of the sample coverage bitmask are taken without any
-- clamping. If the color attachment format has more bits than the sample
-- coverage, the high bits of the sample coverage bitmask are filled with
-- zeros.
--
-- If Sample Shading is in use, the coverage bitmask only has bits
-- set for samples that correspond to the fragment shader invocation that
-- shades those samples.
--
-- This pipeline stage occurs after sample counting and before blending,
-- and is always performed after fragment shading regardless of the
-- setting of EarlyFragmentTests.
--
-- If coverageToColorEnable is VK_FALSE, these
-- operations are skipped. If this structure is not present, it is as if
-- coverageToColorEnable is VK_FALSE.
--
-- Valid Usage
--
--
-- - If coverageToColorEnable is VK_TRUE, then the
-- render pass subpass indicated by
-- VkGraphicsPipelineCreateInfo::renderPass and
-- VkGraphicsPipelineCreateInfo::subpass must have
-- a color attachment at the location selected by
-- coverageToColorLocation, with a VkFormat of
-- VK_FORMAT_R8_UINT, VK_FORMAT_R8_SINT,
-- VK_FORMAT_R16_UINT, VK_FORMAT_R16_SINT,
-- VK_FORMAT_R32_UINT, or VK_FORMAT_R32_SINT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_TO_COLOR_STATE_CREATE_INFO_NV
--
--
--
--
-- See Also
--
-- VkBool32, VkPipelineCoverageToColorStateCreateFlagsNV,
-- VkStructureType
data VkPipelineCoverageToColorStateCreateInfoNV
VkPipelineCoverageToColorStateCreateInfoNV :: VkStructureType -> Ptr () -> VkPipelineCoverageToColorStateCreateFlagsNV -> VkBool32 -> Word32 -> VkPipelineCoverageToColorStateCreateInfoNV
-- | sType is the type of this structure
[$sel:vkSType:VkPipelineCoverageToColorStateCreateInfoNV] :: VkPipelineCoverageToColorStateCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure
[$sel:vkPNext:VkPipelineCoverageToColorStateCreateInfoNV] :: VkPipelineCoverageToColorStateCreateInfoNV -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineCoverageToColorStateCreateInfoNV] :: VkPipelineCoverageToColorStateCreateInfoNV -> VkPipelineCoverageToColorStateCreateFlagsNV
-- | coverageToColorEnable controls whether the fragment coverage
-- value replaces a fragment color output.
[$sel:vkCoverageToColorEnable:VkPipelineCoverageToColorStateCreateInfoNV] :: VkPipelineCoverageToColorStateCreateInfoNV -> VkBool32
-- | coverageToColorLocation controls which fragment shader color
-- output value is replaced.
[$sel:vkCoverageToColorLocation:VkPipelineCoverageToColorStateCreateInfoNV] :: VkPipelineCoverageToColorStateCreateInfoNV -> Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateInfoNV
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_fragment_coverage_to_color.VkPipelineCoverageToColorStateCreateFlagsNV
module Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples
-- | VkCoverageModulationModeNV - Specify the discard rectangle mode
--
-- See Also
--
-- VkPipelineCoverageModulationStateCreateInfoNV
newtype VkCoverageModulationModeNV
VkCoverageModulationModeNV :: Int32 -> VkCoverageModulationModeNV
-- | VK_COVERAGE_MODULATION_MODE_NONE_NV specifies that no
-- components are multiplied by the modulation factor.
-- | VK_COVERAGE_MODULATION_MODE_RGB_NV specifies that the red,
-- green, and blue components are multiplied by the modulation factor.
-- | VK_COVERAGE_MODULATION_MODE_ALPHA_NV specifies that the alpha
-- component is multiplied by the modulation factor.
-- | VK_COVERAGE_MODULATION_MODE_RGBA_NV specifies that all
-- components are multiplied by the modulation factor.
-- | VkPipelineCoverageModulationStateCreateFlagsNV - Reserved for future
-- use
--
-- Description
--
-- VkPipelineCoverageModulationStateCreateFlagsNV is a bitmask
-- type for setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineCoverageModulationStateCreateInfoNV
newtype VkPipelineCoverageModulationStateCreateFlagsNV
VkPipelineCoverageModulationStateCreateFlagsNV :: VkFlags -> VkPipelineCoverageModulationStateCreateFlagsNV
-- | VkPipelineCoverageModulationStateCreateInfoNV - Structure specifying
-- parameters controlling coverage modulation
--
-- Description
--
-- If coverageModulationTableEnable is VK_FALSE, then
-- for each color sample the associated bits of the fragment’s coverage
-- are counted and divided by the number of associated bits to produce a
-- modulation factor R in the range (0,1] (a value of zero would have
-- been killed due to a color coverage of 0). Specifically:
--
--
-- - N = value of rasterizationSamples
-- - M = value of VkAttachmentDescription::samples for
-- any color attachments
-- - R = popcount(associated coverage bits) / (N / M)
--
--
-- If coverageModulationTableEnable is VK_TRUE, the
-- value R is computed using a programmable lookup table. The lookup
-- table has N / M elements, and the element of the table is selected by:
--
--
-- - R = pCoverageModulationTable[popcount(associated coverage
-- bits)-1]
--
--
-- Note that the table does not have an entry for popcount(associated
-- coverage bits) = 0, because such samples would have been killed.
--
-- The values of pCoverageModulationTable may be rounded
-- to an implementation-dependent precision, which is at least as fine as
-- 1 / N, and clamped to [0,1].
--
-- For each color attachment with a floating point or normalized color
-- format, each fragment output color value is replicated to M values
-- which can each be modulated (multiplied) by that color sample’s
-- associated value of R. Which components are modulated is controlled by
-- coverageModulationMode.
--
-- If this structure is not present, it is as if coverageModulationMode
-- is VK_COVERAGE_MODULATION_MODE_NONE_NV.
--
-- Valid Usage
--
--
-- - If coverageModulationTableEnable is VK_TRUE,
-- coverageModulationTableCount must be equal to the
-- number of rasterization samples divided by the number of color samples
-- in the subpass.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_COVERAGE_MODULATION_STATE_CREATE_INFO_NV
--
--
--
-- - flags must be 0
-- - coverageModulationMode must be a valid
-- VkCoverageModulationModeNV value
-- - coverageModulationTableCount must be greater than
-- 0
--
--
-- See Also
--
-- VkBool32, VkCoverageModulationModeNV,
-- VkPipelineCoverageModulationStateCreateFlagsNV,
-- VkStructureType
data VkPipelineCoverageModulationStateCreateInfoNV
VkPipelineCoverageModulationStateCreateInfoNV :: VkStructureType -> Ptr () -> VkPipelineCoverageModulationStateCreateFlagsNV -> VkCoverageModulationModeNV -> VkBool32 -> Word32 -> Ptr CFloat -> VkPipelineCoverageModulationStateCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> VkPipelineCoverageModulationStateCreateFlagsNV
-- | coverageModulationMode controls which color components are
-- modulated and is of type VkCoverageModulationModeNV.
[$sel:vkCoverageModulationMode:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> VkCoverageModulationModeNV
-- | coverageModulationTableEnable controls whether the modulation
-- factor is looked up from a table in pCoverageModulationTable.
[$sel:vkCoverageModulationTableEnable:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> VkBool32
-- | coverageModulationTableCount is the number of elements in
-- pCoverageModulationTable.
[$sel:vkCoverageModulationTableCount:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> Word32
-- | pCoverageModulationTable is a table of modulation factors
-- containing a value for each number of covered samples.
[$sel:vkPCoverageModulationTable:VkPipelineCoverageModulationStateCreateInfoNV] :: VkPipelineCoverageModulationStateCreateInfoNV -> Ptr CFloat
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateInfoNV
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkCoverageModulationModeNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkCoverageModulationModeNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkCoverageModulationModeNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkPipelineCoverageModulationStateCreateFlagsNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkCoverageModulationModeNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_framebuffer_mixed_samples.VkCoverageModulationModeNV
module Graphics.Vulkan.Extensions.VK_NV_geometry_shader_passthrough
module Graphics.Vulkan.Extensions.VK_NV_glsl_shader
module Graphics.Vulkan.Extensions.VK_NV_sample_mask_override_coverage
module Graphics.Vulkan.Extensions.VK_NV_viewport_array2
module Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle
-- | VkViewportCoordinateSwizzleNV - Specify how a viewport coordinate is
-- swizzled
--
-- Description
--
-- These values are described in detail in Viewport Swizzle.
--
-- See Also
--
-- VkViewportSwizzleNV
newtype VkViewportCoordinateSwizzleNV
VkViewportCoordinateSwizzleNV :: Int32 -> VkViewportCoordinateSwizzleNV
-- | VkPipelineViewportSwizzleStateCreateFlagsNV - Reserved for future use
--
-- Description
--
-- VkPipelineViewportSwizzleStateCreateFlagsNV is a bitmask type
-- for setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineViewportSwizzleStateCreateInfoNV
newtype VkPipelineViewportSwizzleStateCreateFlagsNV
VkPipelineViewportSwizzleStateCreateFlagsNV :: VkFlags -> VkPipelineViewportSwizzleStateCreateFlagsNV
-- | VkViewportSwizzleNV - Structure specifying a viewport swizzle
--
-- Description
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkPipelineViewportSwizzleStateCreateInfoNV,
-- VkViewportCoordinateSwizzleNV
data VkViewportSwizzleNV
VkViewportSwizzleNV :: VkViewportCoordinateSwizzleNV -> VkViewportCoordinateSwizzleNV -> VkViewportCoordinateSwizzleNV -> VkViewportCoordinateSwizzleNV -> VkViewportSwizzleNV
-- | x is a VkViewportCoordinateSwizzleNV value specifying
-- the swizzle operation to apply to the x component of the primitive
[$sel:vkX:VkViewportSwizzleNV] :: VkViewportSwizzleNV -> VkViewportCoordinateSwizzleNV
-- | y is a VkViewportCoordinateSwizzleNV value specifying
-- the swizzle operation to apply to the y component of the primitive
[$sel:vkY:VkViewportSwizzleNV] :: VkViewportSwizzleNV -> VkViewportCoordinateSwizzleNV
-- | z is a VkViewportCoordinateSwizzleNV value specifying
-- the swizzle operation to apply to the z component of the primitive
[$sel:vkZ:VkViewportSwizzleNV] :: VkViewportSwizzleNV -> VkViewportCoordinateSwizzleNV
-- | w is a VkViewportCoordinateSwizzleNV value specifying
-- the swizzle operation to apply to the w component of the primitive
[$sel:vkW:VkViewportSwizzleNV] :: VkViewportSwizzleNV -> VkViewportCoordinateSwizzleNV
-- | VkPipelineViewportSwizzleStateCreateInfoNV - Structure specifying
-- swizzle applied to primitive clip coordinates
--
-- Description
--
-- Valid Usage
--
--
-- - viewportCount must match the
-- viewportCount set in
-- VkPipelineViewportStateCreateInfo
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_SWIZZLE_STATE_CREATE_INFO_NV
--
--
--
-- - flags must be 0
-- - viewportCount must be greater than 0
--
--
-- See Also
--
-- VkPipelineViewportSwizzleStateCreateFlagsNV,
-- VkStructureType, VkViewportSwizzleNV
data VkPipelineViewportSwizzleStateCreateInfoNV
VkPipelineViewportSwizzleStateCreateInfoNV :: VkStructureType -> Ptr () -> VkPipelineViewportSwizzleStateCreateFlagsNV -> Word32 -> Ptr VkViewportSwizzleNV -> VkPipelineViewportSwizzleStateCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineViewportSwizzleStateCreateInfoNV] :: VkPipelineViewportSwizzleStateCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineViewportSwizzleStateCreateInfoNV] :: VkPipelineViewportSwizzleStateCreateInfoNV -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineViewportSwizzleStateCreateInfoNV] :: VkPipelineViewportSwizzleStateCreateInfoNV -> VkPipelineViewportSwizzleStateCreateFlagsNV
-- | viewportCount is the number of viewport swizzles used by the
-- pipeline.
[$sel:vkViewportCount:VkPipelineViewportSwizzleStateCreateInfoNV] :: VkPipelineViewportSwizzleStateCreateInfoNV -> Word32
-- | pViewportSwizzles is a pointer to an array of
-- VkViewportSwizzleNV structures, defining the viewport swizzles.
[$sel:vkPViewportSwizzles:VkPipelineViewportSwizzleStateCreateInfoNV] :: VkPipelineViewportSwizzleStateCreateInfoNV -> Ptr VkViewportSwizzleNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportSwizzleNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportSwizzleNV
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportCoordinateSwizzleNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportCoordinateSwizzleNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportCoordinateSwizzleNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportSwizzleNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkPipelineViewportSwizzleStateCreateFlagsNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportCoordinateSwizzleNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_viewport_swizzle.VkViewportCoordinateSwizzleNV
module Graphics.Vulkan.NamedType
-- | Annotate a type with a name
type (name :: k) ::: a = a
module Graphics.Vulkan.Extensions.VK_KHR_variable_pointers
type VkPhysicalDeviceVariablePointerFeaturesKHR = VkPhysicalDeviceVariablePointerFeatures
module Graphics.Vulkan.Extensions.VK_KHR_16bit_storage
type VkPhysicalDevice16BitStorageFeaturesKHR = VkPhysicalDevice16BitStorageFeatures
module Graphics.Vulkan.Core11.DeviceInitialization
-- | vkEnumerateInstanceVersion - Query instance-level version before
-- instance creation
--
-- Parameters
--
--
-- - pApiVersion points to a uint32_t, which is the
-- version of Vulkan supported by instance-level functionality, encoded
-- as described in the API Version Numbers and Semantics
-- section.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - pApiVersion must be a valid pointer to a
-- uint32_t value
--
--
-- Return Codes
--
--
--
-- See Also
--
-- No cross-references are available
vkEnumerateInstanceVersion :: ("pApiVersion" ::: Ptr Word32) -> IO VkResult
module Graphics.Vulkan.Core10.DeviceInitialization
-- | VkImageTiling - Specifies the tiling arrangement of data in an image
--
-- See Also
--
-- VkImageCreateInfo, VkPhysicalDeviceImageFormatInfo2,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceImageFormatProperties,
-- vkGetPhysicalDeviceSparseImageFormatProperties
newtype VkImageTiling
VkImageTiling :: Int32 -> VkImageTiling
-- | VK_IMAGE_TILING_OPTIMAL specifies optimal tiling (texels are
-- laid out in an implementation-dependent arrangement, for more optimal
-- memory access).
-- | VK_IMAGE_TILING_LINEAR specifies linear tiling (texels are
-- laid out in memory in row-major order, possibly with some padding on
-- each row).
-- | VkImageType - Specifies the type of an image object
--
-- See Also
--
-- VkImageCreateInfo, VkPhysicalDeviceImageFormatInfo2,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceImageFormatProperties,
-- vkGetPhysicalDeviceSparseImageFormatProperties
newtype VkImageType
VkImageType :: Int32 -> VkImageType
-- | VK_IMAGE_TYPE_1D specifies a one-dimensional image.
-- | VK_IMAGE_TYPE_2D specifies a two-dimensional image.
-- | VK_IMAGE_TYPE_3D specifies a three-dimensional image.
-- | VkPhysicalDeviceType - Supported physical device types
--
-- Description
--
--
-- - VK_PHYSICAL_DEVICE_TYPE_OTHER - the device does not match
-- any other available types.
--
--
--
-- - VK_PHYSICAL_DEVICE_TYPE_INTEGRATED_GPU - the device is
-- typically one embedded in or tightly coupled with the host.
-- - VK_PHYSICAL_DEVICE_TYPE_DISCRETE_GPU - the device is
-- typically a separate processor connected to the host via an
-- interlink.
-- - VK_PHYSICAL_DEVICE_TYPE_VIRTUAL_GPU - the device is
-- typically a virtual node in a virtualization environment.
-- - VK_PHYSICAL_DEVICE_TYPE_CPU - the device is typically
-- running on the same processors as the host.
--
--
-- The physical device type is advertised for informational purposes
-- only, and does not directly affect the operation of the system.
-- However, the device type may correlate with other advertised
-- properties or capabilities of the system, such as how many memory
-- heaps there are.
--
-- See Also
--
-- VkPhysicalDeviceProperties
newtype VkPhysicalDeviceType
VkPhysicalDeviceType :: Int32 -> VkPhysicalDeviceType
-- | VkSystemAllocationScope - Allocation scope
--
-- Description
--
--
-- - VK_SYSTEM_ALLOCATION_SCOPE_COMMAND specifies that the
-- allocation is scoped to the duration of the Vulkan command.
--
--
--
-- - VK_SYSTEM_ALLOCATION_SCOPE_OBJECT specifies that the
-- allocation is scoped to the lifetime of the Vulkan object that is
-- being created or used.
-- - VK_SYSTEM_ALLOCATION_SCOPE_CACHE specifies that the
-- allocation is scoped to the lifetime of a VkPipelineCache or
-- VkValidationCacheEXT object.
-- - VK_SYSTEM_ALLOCATION_SCOPE_DEVICE specifies that the
-- allocation is scoped to the lifetime of the Vulkan device.
-- - VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE specifies that the
-- allocation is scoped to the lifetime of the Vulkan instance.
--
--
-- Most Vulkan commands operate on a single object, or there is a sole
-- object that is being created or manipulated. When an allocation uses
-- an allocation scope of VK_SYSTEM_ALLOCATION_SCOPE_OBJECT or
-- VK_SYSTEM_ALLOCATION_SCOPE_CACHE, the allocation is scoped to
-- the object being created or manipulated.
--
-- When an implementation requires host memory, it will make callbacks to
-- the application using the most specific allocator and allocation scope
-- available:
--
--
-- - If an allocation is scoped to the duration of a command, the
-- allocator will use the VK_SYSTEM_ALLOCATION_SCOPE_COMMAND
-- allocation scope. The most specific allocator available is used: if
-- the object being created or manipulated has an allocator, that
-- object’s allocator will be used, else if the parent VkDevice
-- has an allocator it will be used, else if the parent
-- VkInstance has an allocator it will be used. Else,
-- - If an allocation is associated with an object of type
-- VkValidationCacheEXT or VkPipelineCache, the
-- allocator will use the VK_SYSTEM_ALLOCATION_SCOPE_CACHE
-- allocation scope. The most specific allocator available is used
-- (cache, else device, else instance). Else,
-- - If an allocation is scoped to the lifetime of an object, that
-- object is being created or manipulated by the command, and that
-- object’s type is not VkDevice or VkInstance, the
-- allocator will use an allocation scope of
-- VK_SYSTEM_ALLOCATION_SCOPE_OBJECT. The most specific
-- allocator available is used (object, else device, else instance).
-- Else,
-- - If an allocation is scoped to the lifetime of a device, the
-- allocator will use an allocation scope of
-- VK_SYSTEM_ALLOCATION_SCOPE_DEVICE. The most specific
-- allocator available is used (device, else instance). Else,
-- - If the allocation is scoped to the lifetime of an instance and the
-- instance has an allocator, its allocator will be used with an
-- allocation scope of VK_SYSTEM_ALLOCATION_SCOPE_INSTANCE.
-- - Otherwise an implementation will allocate memory through an
-- alternative mechanism that is unspecified.
--
--
-- See Also
--
-- VkAllocationCallbacks
newtype VkSystemAllocationScope
VkSystemAllocationScope :: Int32 -> VkSystemAllocationScope
-- | VkInternalAllocationType - Allocation type
--
-- See Also
--
-- PFN_vkInternalAllocationNotification,
-- PFN_vkInternalFreeNotification
newtype VkInternalAllocationType
VkInternalAllocationType :: Int32 -> VkInternalAllocationType
-- | VK_INTERNAL_ALLOCATION_TYPE_EXECUTABLE specifies that the
-- allocation is intended for execution by the host.
-- | VkInstanceCreateFlags - Reserved for future use
--
-- Description
--
-- VkInstanceCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkInstanceCreateInfo
newtype VkInstanceCreateFlags
VkInstanceCreateFlags :: VkFlags -> VkInstanceCreateFlags
-- | VkQueueFlagBits - Bitmask specifying capabilities of queues in a queue
-- family
--
-- Description
--
--
-- - VK_QUEUE_GRAPHICS_BIT specifies that queues in this queue
-- family support graphics operations.
--
--
--
-- - VK_QUEUE_COMPUTE_BIT specifies that queues in this queue
-- family support compute operations.
-- - VK_QUEUE_TRANSFER_BIT specifies that queues in this queue
-- family support transfer operations.
-- - VK_QUEUE_SPARSE_BINDING_BIT specifies that queues in this
-- queue family support sparse memory management operations (see
-- Sparse Resources). If any of the sparse resource features are
-- enabled, then at least one queue family must support this
-- bit.
--
--
-- If an implementation exposes any queue family that supports graphics
-- operations, at least one queue family of at least one physical device
-- exposed by the implementation must support both graphics and
-- compute operations.
--
-- Note
--
-- All commands that are allowed on a queue that supports transfer
-- operations are also allowed on a queue that supports either graphics
-- or compute operations. Thus, if the capabilities of a queue family
-- include VK_QUEUE_GRAPHICS_BIT or
-- VK_QUEUE_COMPUTE_BIT, then reporting the
-- VK_QUEUE_TRANSFER_BIT capability separately for that queue
-- family is optional.
--
-- For further details see Queues.
--
-- See Also
--
-- VkQueueFlags
newtype VkQueueFlagBits
VkQueueFlagBits :: VkFlags -> VkQueueFlagBits
-- | VkMemoryPropertyFlagBits - Bitmask specifying properties for a memory
-- type
--
-- See Also
--
-- VkMemoryPropertyFlags
newtype VkMemoryPropertyFlagBits
VkMemoryPropertyFlagBits :: VkFlags -> VkMemoryPropertyFlagBits
-- | VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT bit specifies that memory
-- allocated with this type is the most efficient for device access. This
-- property will be set if and only if the memory type belongs to a heap
-- with the VK_MEMORY_HEAP_DEVICE_LOCAL_BIT set.
-- | VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT bit specifies that memory
-- allocated with this type can be mapped for host access using
-- vkMapMemory.
-- | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT bit specifies that the
-- host cache management commands vkFlushMappedMemoryRanges and
-- vkInvalidateMappedMemoryRanges are not needed to flush host
-- writes to the device or make device writes visible to the host,
-- respectively.
-- | VK_MEMORY_PROPERTY_HOST_CACHED_BIT bit specifies that memory
-- allocated with this type is cached on the host. Host memory accesses
-- to uncached memory are slower than to cached memory, however uncached
-- memory is always host coherent.
-- | VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT bit specifies that
-- the memory type only allows device access to the memory. Memory types
-- must not have both
-- VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT and
-- VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT set. Additionally, the
-- object’s backing memory may be provided by the implementation
-- lazily as specified in Lazily Allocated Memory.
-- | VkMemoryHeapFlagBits - Bitmask specifying attribute flags for a heap
--
-- See Also
--
-- VkMemoryHeapFlags
newtype VkMemoryHeapFlagBits
VkMemoryHeapFlagBits :: VkFlags -> VkMemoryHeapFlagBits
-- | VK_MEMORY_HEAP_DEVICE_LOCAL_BIT specifies that the heap
-- corresponds to device local memory. Device local memory may
-- have different performance characteristics than host local memory, and
-- may support different memory property flags.
-- | VkImageUsageFlagBits - Bitmask specifying intended usage of an image
--
-- See Also
--
-- VkImageUsageFlags
newtype VkImageUsageFlagBits
VkImageUsageFlagBits :: VkFlags -> VkImageUsageFlagBits
-- | VK_IMAGE_USAGE_TRANSFER_SRC_BIT specifies that the image
-- can be used as the source of a transfer command.
-- | VK_IMAGE_USAGE_TRANSFER_DST_BIT specifies that the image
-- can be used as the destination of a transfer command.
-- | VK_IMAGE_USAGE_SAMPLED_BIT specifies that the image
-- can be used to create a VkImageView suitable for
-- occupying a VkDescriptorSet slot either of type
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, and be sampled by
-- a shader.
-- | VK_IMAGE_USAGE_STORAGE_BIT specifies that the image
-- can be used to create a VkImageView suitable for
-- occupying a VkDescriptorSet slot of type
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE.
-- | VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT specifies that the image
-- can be used to create a VkImageView suitable for use
-- as a color or resolve attachment in a VkFramebuffer.
-- | VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT specifies that
-- the image can be used to create a VkImageView suitable
-- for use as a depth/stencil attachment in a VkFramebuffer.
-- | VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT specifies that the
-- memory bound to this image will have been allocated with the
-- VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT (see
-- {html_spec_relative}#memory for more detail). This bit
-- can be set for any image that can be used to create a
-- VkImageView suitable for use as a color, resolve,
-- depth/stencil, or input attachment.
-- | VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT specifies that the image
-- can be used to create a VkImageView suitable for
-- occupying VkDescriptorSet slot of type
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT; be read from a shader as
-- an input attachment; and be used as an input attachment in a
-- framebuffer.
-- | VkImageCreateFlagBits - Bitmask specifying additional parameters of an
-- image
--
-- Description
--
--
-- - VK_IMAGE_CREATE_SPARSE_BINDING_BIT specifies that the
-- image will be backed using sparse memory binding.
--
--
--
-- - VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT specifies that the
-- image can be partially backed using sparse memory binding.
-- Images created with this flag must also be created with the
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT flag.
-- - VK_IMAGE_CREATE_SPARSE_ALIASED_BIT specifies that the
-- image will be backed using sparse memory binding with memory ranges
-- that might also simultaneously be backing another image (or another
-- portion of the same image). Images created with this flag must
-- also be created with the VK_IMAGE_CREATE_SPARSE_BINDING_BIT
-- flag
-- - VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT specifies that the
-- image can be used to create a VkImageView with a
-- different format from the image. For multi-planar formats,
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT specifies that a
-- VkImageView can be created of a plane of the
-- image.
-- - VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT specifies that the
-- image can be used to create a VkImageView of type
-- VK_IMAGE_VIEW_TYPE_CUBE or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY.
-- - VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT specifies that
-- the image can be used to create a VkImageView of type
-- VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY.
-- - VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT specifies
-- that the image can be used with a non-zero value of the
-- splitInstanceBindRegionCount member of a
-- VkBindImageMemoryDeviceGroupInfo structure passed into
-- vkBindImageMemory2. This flag also has the effect of making the
-- image use the standard sparse image block dimensions.
-- - VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT specifies
-- that the image having a compressed format can be used to create
-- a VkImageView with an uncompressed format where each texel in
-- the image view corresponds to a compressed texel block of the
-- image.
-- - VK_IMAGE_CREATE_EXTENDED_USAGE_BIT specifies that the
-- image can be created with usage flags that are not supported
-- for the format the image is created with but are supported for at
-- least one format a VkImageView created from the image
-- can have.
-- - VK_IMAGE_CREATE_DISJOINT_BIT specifies that an image with
-- a multi-planar format must have each plane separately
-- bound to memory, rather than having a single memory binding for the
-- whole image; the presence of this bit distinguishes a disjoint
-- image from an image without this bit set.
-- - VK_IMAGE_CREATE_ALIAS_BIT specifies that two images
-- created with the same creation parameters and aliased to the same
-- memory can interpret the contents of the memory consistently
-- with each other, subject to the rules described in the Memory
-- Aliasing section. This flag further specifies that each plane of a
-- disjoint image can share an in-memory non-linear
-- representation with single-plane images, and that a single-plane image
-- can share an in-memory non-linear representation with a plane
-- of a multi-planar disjoint image, according to the rules in
-- {html_spec_relative}#features-formats-compatible-planes. If the
-- pNext chain includes a VkExternalMemoryImageCreateInfo
-- or VkExternalMemoryImageCreateInfoNV structure whose
-- handleTypes member is not 0, it is as if
-- VK_IMAGE_CREATE_ALIAS_BIT is set.
-- - VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- specifies that an image with a depth or depth/stencil format
-- can be used with custom sample locations when used as a
-- depth/stencil attachment.
--
--
-- See Sparse Resource Features and Sparse Physical Device
-- Features for more details.
--
-- See Also
--
-- VkImageCreateFlags
newtype VkImageCreateFlagBits
VkImageCreateFlagBits :: VkFlags -> VkImageCreateFlagBits
-- | VkFormatFeatureFlagBits - Bitmask specifying features supported by a
-- buffer
--
-- Description
--
-- The following bits may be set in linearTilingFeatures
-- and optimalTilingFeatures, specifying that the features are
-- supported by images or image views created with the
-- queried vkGetPhysicalDeviceFormatProperties::format:
--
--
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT specifies that an
-- image view can be sampled from.
-- - VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT specifies that an
-- image view can be used as a storage images.
-- - VK_FORMAT_FEATURE_STORAGE_IMAGE_ATOMIC_BIT specifies that
-- an image view can be used as storage image that supports atomic
-- operations.
-- - VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT specifies that an
-- image view can be used as a framebuffer color attachment and as
-- an input attachment.
-- - VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT specifies
-- that an image view can be used as a framebuffer color
-- attachment that supports blending and as an input attachment.
-- - VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT specifies
-- that an image view can be used as a framebuffer depth/stencil
-- attachment and as an input attachment.
-- - VK_FORMAT_FEATURE_BLIT_SRC_BIT specifies that an image
-- can be used as srcImage for the
-- vkCmdBlitImage command.
-- - VK_FORMAT_FEATURE_BLIT_DST_BIT specifies that an image
-- can be used as dstImage for the
-- vkCmdBlitImage command.
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT
-- specifies that if VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT is also
-- set, an image view can be used with a sampler that has either
-- of magFilter or minFilter set to
-- VK_FILTER_LINEAR, or mipmapMode set to
-- VK_SAMPLER_MIPMAP_MODE_LINEAR. If
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT is also set, an image can be
-- used as the srcImage to vkCmdBlitImage with a
-- filter of VK_FILTER_LINEAR. This bit must
-- only be exposed for formats that also support the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT or
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT.If the format being queried is
-- a depth/stencil format, this bit only specifies that the depth aspect
-- (not the stencil aspect) of an image of this format supports linear
-- filtering, and that linear filtering of the depth aspect is supported
-- whether depth compare is enabled in the sampler or not. If this bit is
-- not present, linear filtering with depth compare disabled is
-- unsupported and linear filtering with depth compare enabled is
-- supported, but may compute the filtered value in an
-- implementation-dependent manner which differs from the normal rules of
-- linear filtering. The resulting value must be in the range
-- [0,1] and should be proportional to, or a weighted average of,
-- the number of comparison passes or failures.
-- - VK_FORMAT_FEATURE_TRANSFER_SRC_BIT specifies that an
-- image can be used as a source image for copy
-- commands.
-- - VK_FORMAT_FEATURE_TRANSFER_DST_BIT specifies that an
-- image can be used as a destination image for copy
-- commands and clear commands.
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT
-- specifies VkImage can be used as a sampled image with
-- a min or max VkSamplerReductionModeEXT. This bit must
-- only be exposed for formats that also support the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT.
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG
-- specifies that VkImage can be used with a sampler that
-- has either of magFilter or minFilter set to
-- VK_FILTER_CUBIC_IMG, or be the source image for a blit with
-- filter set to VK_FILTER_CUBIC_IMG. This bit
-- must only be exposed for formats that also support the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT. If the format being
-- queried is a depth/stencil format, this only specifies that the depth
-- aspect is cubic filterable.
-- - VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT specifies
-- that an application can define a sampler Y’CBCR
-- conversion using this format as a source, and that an image of
-- this format can be used with a
-- VkSamplerYcbcrConversionCreateInfo xChromaOffset
-- and/or yChromaOffset of VK_CHROMA_LOCATION_MIDPOINT.
-- Otherwise both xChromaOffset and yChromaOffset
-- must be VK_CHROMA_LOCATION_COSITED_EVEN. If a format
-- does not incorporate chroma downsampling (it is not a “422” or “420”
-- format) but the implementation supports sampler Y’CBCR conversion for
-- this format, the implementation must set
-- VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT.
-- - VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT specifies
-- that an application can define a sampler Y’CBCR
-- conversion using this format as a source, and that an image of
-- this format can be used with a
-- VkSamplerYcbcrConversionCreateInfo xChromaOffset
-- and/or yChromaOffset of
-- VK_CHROMA_LOCATION_COSITED_EVEN. Otherwise both
-- xChromaOffset and yChromaOffset must be
-- VK_CHROMA_LOCATION_MIDPOINT. If neither
-- VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT nor
-- VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT is set, the
-- application must not define a sampler Y’CBCR conversion
-- using this format as a source.
--
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT
-- specifies that the format can do linear sampler filtering
-- (min/magFilter) whilst sampler Y’CBCR conversion is enabled.
--
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT
-- specifies that the format can have different chroma, min, and mag
-- filters.
--
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_BIT
-- specifies that reconstruction is explicit, as described in
-- {html_spec_relative}#textures-chroma-reconstruction. If this
-- bit is not present, reconstruction is implicit by default.
--
-- - VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT
-- specifies that reconstruction can be forcibly made explicit by
-- setting
-- VkSamplerYcbcrConversionCreateInfo::forceExplicitReconstruction
-- to VK_TRUE.
-- - VK_FORMAT_FEATURE_DISJOINT_BIT specifies that a
-- multi-planar image can have the
-- VK_IMAGE_CREATE_DISJOINT_BIT set during image creation. An
-- implementation must not set
-- VK_FORMAT_FEATURE_DISJOINT_BIT for single-plane
-- formats.
--
--
-- The following bits may be set in bufferFeatures,
-- specifying that the features are supported by buffers or
-- buffer views created with the queried
-- vkGetPhysicalDeviceProperties::format:
--
--
-- - VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT specifies that
-- the format can be used to create a buffer view that can
-- be bound to a VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER
-- descriptor.
-- - VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT specifies that
-- the format can be used to create a buffer view that can
-- be bound to a VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER
-- descriptor.
-- - VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_ATOMIC_BIT
-- specifies that atomic operations are supported on
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER with this
-- format.
-- - VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT specifies that the
-- format can be used as a vertex attribute format
-- (VkVertexInputAttributeDescription::format).
--
--
-- See Also
--
-- VkFormatFeatureFlags
newtype VkFormatFeatureFlagBits
VkFormatFeatureFlagBits :: VkFlags -> VkFormatFeatureFlagBits
-- | VkSampleCountFlagBits - Bitmask specifying sample counts supported for
-- an image used for storage operations
--
-- See Also
--
-- VkAttachmentDescription, VkImageCreateInfo,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- VkPipelineMultisampleStateCreateInfo,
-- VkSampleCountFlags, VkSampleLocationsInfoEXT,
-- vkGetPhysicalDeviceMultisamplePropertiesEXT,
-- vkGetPhysicalDeviceSparseImageFormatProperties
newtype VkSampleCountFlagBits
VkSampleCountFlagBits :: VkFlags -> VkSampleCountFlagBits
-- | VK_SAMPLE_COUNT_1_BIT specifies an image with one sample per
-- pixel.
-- | VK_SAMPLE_COUNT_2_BIT specifies an image with 2 samples per
-- pixel.
-- | VK_SAMPLE_COUNT_4_BIT specifies an image with 4 samples per
-- pixel.
-- | VK_SAMPLE_COUNT_8_BIT specifies an image with 8 samples per
-- pixel.
-- | VK_SAMPLE_COUNT_16_BIT specifies an image with 16 samples per
-- pixel.
-- | VK_SAMPLE_COUNT_32_BIT specifies an image with 32 samples per
-- pixel.
-- | VK_SAMPLE_COUNT_64_BIT specifies an image with 64 samples per
-- pixel.
type VK_MAX_PHYSICAL_DEVICE_NAME_SIZE = 256
type VK_UUID_SIZE = 16
type VK_MAX_MEMORY_TYPES = 32
type VK_MAX_MEMORY_HEAPS = 16
-- | PFN_vkInternalAllocationNotification - Application-defined memory
-- allocation notification function
--
-- Parameters
--
--
-- - pUserData is the value specified for
-- VkAllocationCallbacks::pUserData in the allocator
-- specified by the application.
--
--
--
-- - size is the requested size of an allocation.
-- - allocationType is a VkInternalAllocationType value
-- specifying the requested type of an allocation.
-- - allocationScope is a VkSystemAllocationScope value
-- specifying the allocation scope of the lifetime of the allocation, as
-- described here.
--
--
-- Description
--
-- This is a purely informational callback.
--
-- See Also
--
-- VkAllocationCallbacks
type PFN_vkInternalAllocationNotification = Ptr (("pUserData" ::: Ptr ()) -> ("size" ::: CSize) -> ("allocationType" ::: VkInternalAllocationType) -> ("allocationScope" ::: VkSystemAllocationScope) -> IO ())
-- | PFN_vkInternalFreeNotification - Application-defined memory free
-- notification function
--
-- Parameters
--
--
-- - pUserData is the value specified for
-- VkAllocationCallbacks::pUserData in the allocator
-- specified by the application.
--
--
--
-- - size is the requested size of an allocation.
-- - allocationType is a VkInternalAllocationType value
-- specifying the requested type of an allocation.
-- - allocationScope is a VkSystemAllocationScope value
-- specifying the allocation scope of the lifetime of the allocation, as
-- described here.
--
--
-- Description
--
-- See Also
--
-- VkAllocationCallbacks
type PFN_vkInternalFreeNotification = Ptr (("pUserData" ::: Ptr ()) -> ("size" ::: CSize) -> ("allocationType" ::: VkInternalAllocationType) -> ("allocationScope" ::: VkSystemAllocationScope) -> IO ())
-- | PFN_vkReallocationFunction - Application-defined memory reallocation
-- function
--
-- Parameters
--
--
-- - pUserData is the value specified for
-- VkAllocationCallbacks::pUserData in the allocator
-- specified by the application.
--
--
--
-- - pOriginal must be either NULL or a
-- pointer previously returned by pfnReallocation or
-- pfnAllocation of the same allocator.
-- - size is the size in bytes of the requested
-- allocation.
-- - alignment is the requested alignment of the allocation in
-- bytes and must be a power of two.
-- - allocationScope is a VkSystemAllocationScope value
-- specifying the allocation scope of the lifetime of the allocation, as
-- described here.
--
--
-- Description
--
-- pfnReallocation must return an allocation with enough
-- space for size bytes, and the contents of the original
-- allocation from bytes zero to min(original size, new size) - 1
-- must be preserved in the returned allocation. If size
-- is larger than the old size, the contents of the additional space are
-- undefined. If satisfying these requirements involves creating a new
-- allocation, then the old allocation should be freed.
--
-- If pOriginal is NULL, then pfnReallocation
-- must behave equivalently to a call to
-- PFN_vkAllocationFunction with the same parameter values
-- (without pOriginal).
--
-- If size is zero, then pfnReallocation must
-- behave equivalently to a call to PFN_vkFreeFunction with the
-- same pUserData parameter value, and pMemory equal to
-- pOriginal.
--
-- If pOriginal is non-NULL, the implementation
-- must ensure that alignment is equal to the
-- alignment used to originally allocate pOriginal.
--
-- If this function fails and pOriginal is non-NULL the
-- application must not free the old allocation.
--
-- pfnReallocation must follow the same rules for
-- return values as PFN_vkAllocationFunction.
--
-- See Also
--
-- VkAllocationCallbacks
type PFN_vkReallocationFunction = Ptr (("pUserData" ::: Ptr ()) -> ("pOriginal" ::: Ptr ()) -> ("size" ::: CSize) -> ("alignment" ::: CSize) -> ("allocationScope" ::: VkSystemAllocationScope) -> IO (Ptr ()))
-- | PFN_vkAllocationFunction - Application-defined memory allocation
-- function
--
-- Parameters
--
--
-- - pUserData is the value specified for
-- VkAllocationCallbacks::pUserData in the allocator
-- specified by the application.
--
--
--
-- - size is the size in bytes of the requested
-- allocation.
-- - alignment is the requested alignment of the allocation in
-- bytes and must be a power of two.
-- - allocationScope is a VkSystemAllocationScope value
-- specifying the allocation scope of the lifetime of the allocation, as
-- described here.
--
--
-- Description
--
-- If pfnAllocation is unable to allocate the requested memory,
-- it must return NULL. If the allocation was successful,
-- it must return a valid pointer to memory allocation containing
-- at least size bytes, and with the pointer value being a
-- multiple of alignment.
--
-- Note
--
-- Correct Vulkan operation cannot be assumed if the application
-- does not follow these rules.
--
-- For example, pfnAllocation (or pfnReallocation)
-- could cause termination of running Vulkan instance(s) on a failed
-- allocation for debugging purposes, either directly or indirectly. In
-- these circumstances, it cannot be assumed that any part of any
-- affected VkInstance objects are going to operate correctly
-- (even vkDestroyInstance), and the application must
-- ensure it cleans up properly via other means (e.g. process
-- termination).
--
-- If pfnAllocation returns NULL, and if the
-- implementation is unable to continue correct processing of the current
-- command without the requested allocation, it must treat this as
-- a run-time error, and generate VK_ERROR_OUT_OF_HOST_MEMORY at
-- the appropriate time for the command in which the condition was
-- detected, as described in Return Codes.
--
-- If the implementation is able to continue correct processing of the
-- current command without the requested allocation, then it may
-- do so, and must not generate
-- VK_ERROR_OUT_OF_HOST_MEMORY as a result of this failed
-- allocation.
--
-- See Also
--
-- VkAllocationCallbacks
type PFN_vkAllocationFunction = Ptr (("pUserData" ::: Ptr ()) -> ("size" ::: CSize) -> ("alignment" ::: CSize) -> ("allocationScope" ::: VkSystemAllocationScope) -> IO (Ptr ()))
-- | PFN_vkFreeFunction - Application-defined memory free function
--
-- Parameters
--
--
-- - pUserData is the value specified for
-- VkAllocationCallbacks::pUserData in the allocator
-- specified by the application.
--
--
--
-- - pMemory is the allocation to be freed.
--
--
-- Description
--
-- pMemory may be NULL, which the callback
-- must handle safely. If pMemory is non-NULL,
-- it must be a pointer previously allocated by
-- pfnAllocation or pfnReallocation. The application
-- should free this memory.
--
-- See Also
--
-- VkAllocationCallbacks
type PFN_vkFreeFunction = Ptr (("pUserData" ::: Ptr ()) -> ("pMemory" ::: Ptr ()) -> IO ())
-- | PFN_vkVoidFunction - Dummy function pointer type returned by queries
--
-- Parameters
--
-- Description
--
-- See Also
--
-- vkGetDeviceProcAddr, vkGetInstanceProcAddr
type PFN_vkVoidFunction = Ptr (() -> IO ())
-- | VkInstance - Opaque handle to a instance object
--
-- Description
--
-- See Also
--
-- vkCreateAndroidSurfaceKHR,
-- vkCreateDebugReportCallbackEXT,
-- vkCreateDebugUtilsMessengerEXT,
-- vkCreateDisplayPlaneSurfaceKHR, vkCreateIOSSurfaceMVK,
-- vkCreateInstance, vkCreateMacOSSurfaceMVK,
-- vkCreateMirSurfaceKHR, vkCreateViSurfaceNN,
-- vkCreateWaylandSurfaceKHR, vkCreateWin32SurfaceKHR,
-- vkCreateXcbSurfaceKHR, vkCreateXlibSurfaceKHR,
-- vkDebugReportMessageEXT,
-- vkDestroyDebugReportCallbackEXT,
-- vkDestroyDebugUtilsMessengerEXT, vkDestroyInstance,
-- vkDestroySurfaceKHR, vkEnumeratePhysicalDeviceGroups,
-- vkEnumeratePhysicalDeviceGroupsKHR,
-- vkEnumeratePhysicalDevices, vkGetInstanceProcAddr,
-- vkSubmitDebugUtilsMessageEXT
type VkInstance = Ptr VkInstance_T
-- | VkPhysicalDevice - Opaque handle to a physical device object
--
-- Description
--
-- See Also
--
-- VkDeviceGroupDeviceCreateInfo,
-- VkPhysicalDeviceGroupProperties,
-- vkAcquireXlibDisplayEXT, vkCreateDevice,
-- vkCreateDisplayModeKHR,
-- vkEnumerateDeviceExtensionProperties,
-- vkEnumerateDeviceLayerProperties,
-- vkEnumeratePhysicalDevices,
-- vkGetDisplayModePropertiesKHR,
-- vkGetDisplayPlaneCapabilitiesKHR,
-- vkGetDisplayPlaneSupportedDisplaysKHR,
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR,
-- vkGetPhysicalDeviceDisplayPropertiesKHR,
-- vkGetPhysicalDeviceExternalBufferProperties,
-- vkGetPhysicalDeviceExternalBufferPropertiesKHR,
-- vkGetPhysicalDeviceExternalFenceProperties,
-- vkGetPhysicalDeviceExternalFencePropertiesKHR,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceExternalSemaphoreProperties,
-- vkGetPhysicalDeviceExternalSemaphorePropertiesKHR,
-- vkGetPhysicalDeviceFeatures,
-- vkGetPhysicalDeviceFeatures2,
-- vkGetPhysicalDeviceFeatures2KHR,
-- vkGetPhysicalDeviceFormatProperties,
-- vkGetPhysicalDeviceFormatProperties2,
-- vkGetPhysicalDeviceFormatProperties2KHR,
-- vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX,
-- vkGetPhysicalDeviceImageFormatProperties,
-- vkGetPhysicalDeviceImageFormatProperties2,
-- vkGetPhysicalDeviceImageFormatProperties2KHR,
-- vkGetPhysicalDeviceMemoryProperties,
-- vkGetPhysicalDeviceMemoryProperties2,
-- vkGetPhysicalDeviceMemoryProperties2KHR,
-- vkGetPhysicalDeviceMirPresentationSupportKHR,
-- vkGetPhysicalDeviceMultisamplePropertiesEXT,
-- vkGetPhysicalDevicePresentRectanglesKHR,
-- vkGetPhysicalDeviceProperties,
-- vkGetPhysicalDeviceProperties2,
-- vkGetPhysicalDeviceProperties2KHR,
-- vkGetPhysicalDeviceQueueFamilyProperties,
-- vkGetPhysicalDeviceQueueFamilyProperties2,
-- vkGetPhysicalDeviceQueueFamilyProperties2KHR,
-- vkGetPhysicalDeviceSparseImageFormatProperties,
-- vkGetPhysicalDeviceSparseImageFormatProperties2,
-- vkGetPhysicalDeviceSparseImageFormatProperties2KHR,
-- vkGetPhysicalDeviceSurfaceCapabilities2EXT,
-- vkGetPhysicalDeviceSurfaceCapabilities2KHR,
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR,
-- vkGetPhysicalDeviceSurfaceFormats2KHR,
-- vkGetPhysicalDeviceSurfaceFormatsKHR,
-- vkGetPhysicalDeviceSurfacePresentModesKHR,
-- vkGetPhysicalDeviceSurfaceSupportKHR,
-- vkGetPhysicalDeviceWaylandPresentationSupportKHR,
-- vkGetPhysicalDeviceWin32PresentationSupportKHR,
-- vkGetPhysicalDeviceXcbPresentationSupportKHR,
-- vkGetPhysicalDeviceXlibPresentationSupportKHR,
-- vkGetRandROutputDisplayEXT, vkReleaseDisplayEXT
type VkPhysicalDevice = Ptr VkPhysicalDevice_T
-- | VkDevice - Opaque handle to a device object
--
-- Description
--
-- See Also
--
-- vkAcquireNextImage2KHR, vkAcquireNextImageKHR,
-- vkAllocateCommandBuffers, vkAllocateDescriptorSets,
-- vkAllocateMemory, vkBindBufferMemory,
-- vkBindBufferMemory2, vkBindBufferMemory2KHR,
-- vkBindImageMemory, vkBindImageMemory2,
-- vkBindImageMemory2KHR, vkCreateBuffer,
-- vkCreateBufferView, vkCreateCommandPool,
-- vkCreateComputePipelines, vkCreateDescriptorPool,
-- vkCreateDescriptorSetLayout,
-- vkCreateDescriptorUpdateTemplate,
-- vkCreateDescriptorUpdateTemplateKHR, vkCreateDevice,
-- vkCreateEvent, vkCreateFence,
-- vkCreateFramebuffer, vkCreateGraphicsPipelines,
-- vkCreateImage, vkCreateImageView,
-- vkCreateIndirectCommandsLayoutNVX,
-- vkCreateObjectTableNVX, vkCreatePipelineCache,
-- vkCreatePipelineLayout, vkCreateQueryPool,
-- vkCreateRenderPass, vkCreateSampler,
-- vkCreateSamplerYcbcrConversion,
-- vkCreateSamplerYcbcrConversionKHR, vkCreateSemaphore,
-- vkCreateShaderModule, vkCreateSharedSwapchainsKHR,
-- vkCreateSwapchainKHR, vkCreateValidationCacheEXT,
-- vkDebugMarkerSetObjectNameEXT,
-- vkDebugMarkerSetObjectTagEXT, vkDestroyBuffer,
-- vkDestroyBufferView, vkDestroyCommandPool,
-- vkDestroyDescriptorPool, vkDestroyDescriptorSetLayout,
-- vkDestroyDescriptorUpdateTemplate,
-- vkDestroyDescriptorUpdateTemplateKHR, vkDestroyDevice,
-- vkDestroyEvent, vkDestroyFence,
-- vkDestroyFramebuffer, vkDestroyImage,
-- vkDestroyImageView, vkDestroyIndirectCommandsLayoutNVX,
-- vkDestroyObjectTableNVX, vkDestroyPipeline,
-- vkDestroyPipelineCache, vkDestroyPipelineLayout,
-- vkDestroyQueryPool, vkDestroyRenderPass,
-- vkDestroySampler, vkDestroySamplerYcbcrConversion,
-- vkDestroySamplerYcbcrConversionKHR, vkDestroySemaphore,
-- vkDestroyShaderModule, vkDestroySwapchainKHR,
-- vkDestroyValidationCacheEXT, vkDeviceWaitIdle,
-- vkDisplayPowerControlEXT, vkFlushMappedMemoryRanges,
-- vkFreeCommandBuffers, vkFreeDescriptorSets,
-- vkFreeMemory,
-- vkGetAndroidHardwareBufferPropertiesANDROID,
-- vkGetBufferMemoryRequirements,
-- vkGetBufferMemoryRequirements2,
-- vkGetBufferMemoryRequirements2KHR,
-- vkGetDescriptorSetLayoutSupport,
-- vkGetDescriptorSetLayoutSupportKHR,
-- vkGetDeviceGroupPeerMemoryFeatures,
-- vkGetDeviceGroupPeerMemoryFeaturesKHR,
-- vkGetDeviceGroupPresentCapabilitiesKHR,
-- vkGetDeviceGroupSurfacePresentModesKHR,
-- vkGetDeviceMemoryCommitment, vkGetDeviceProcAddr,
-- vkGetDeviceQueue, vkGetDeviceQueue2,
-- vkGetEventStatus, vkGetFenceFdKHR,
-- vkGetFenceStatus, vkGetFenceWin32HandleKHR,
-- vkGetImageMemoryRequirements,
-- vkGetImageMemoryRequirements2,
-- vkGetImageMemoryRequirements2KHR,
-- vkGetImageSparseMemoryRequirements,
-- vkGetImageSparseMemoryRequirements2,
-- vkGetImageSparseMemoryRequirements2KHR,
-- vkGetImageSubresourceLayout,
-- vkGetMemoryAndroidHardwareBufferANDROID,
-- vkGetMemoryFdKHR, vkGetMemoryFdPropertiesKHR,
-- vkGetMemoryHostPointerPropertiesEXT,
-- vkGetMemoryWin32HandleKHR, vkGetMemoryWin32HandleNV,
-- vkGetMemoryWin32HandlePropertiesKHR,
-- vkGetPastPresentationTimingGOOGLE,
-- vkGetPipelineCacheData, vkGetQueryPoolResults,
-- vkGetRefreshCycleDurationGOOGLE,
-- vkGetRenderAreaGranularity, vkGetSemaphoreFdKHR,
-- vkGetSemaphoreWin32HandleKHR, vkGetShaderInfoAMD,
-- vkGetSwapchainCounterEXT, vkGetSwapchainImagesKHR,
-- vkGetSwapchainStatusKHR, vkGetValidationCacheDataEXT,
-- vkImportFenceFdKHR, vkImportFenceWin32HandleKHR,
-- vkImportSemaphoreFdKHR, vkImportSemaphoreWin32HandleKHR,
-- vkInvalidateMappedMemoryRanges, vkMapMemory,
-- vkMergePipelineCaches, vkMergeValidationCachesEXT,
-- vkRegisterDeviceEventEXT, vkRegisterDisplayEventEXT,
-- vkRegisterObjectsNVX, vkResetCommandPool,
-- vkResetDescriptorPool, vkResetEvent,
-- vkResetFences, vkSetDebugUtilsObjectNameEXT,
-- vkSetDebugUtilsObjectTagEXT, vkSetEvent,
-- vkSetHdrMetadataEXT, vkTrimCommandPool,
-- vkTrimCommandPoolKHR, vkUnmapMemory,
-- vkUnregisterObjectsNVX,
-- vkUpdateDescriptorSetWithTemplate,
-- vkUpdateDescriptorSetWithTemplateKHR,
-- vkUpdateDescriptorSets, vkWaitForFences
type VkDevice = Ptr VkDevice_T
-- | vkCreateInstance - Create a new Vulkan instance
--
-- Parameters
--
--
-- - pCreateInfo points to an instance of
-- VkInstanceCreateInfo controlling creation of the instance.
--
--
--
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pInstance points a VkInstance handle in which
-- the resulting instance is returned.
--
--
-- Description
--
-- vkCreateInstance verifies that the requested layers exist. If
-- not, vkCreateInstance will return
-- VK_ERROR_LAYER_NOT_PRESENT. Next vkCreateInstance
-- verifies that the requested extensions are supported (e.g. in the
-- implementation or in any enabled instance layer) and if any requested
-- extension is not supported, vkCreateInstance must
-- return VK_ERROR_EXTENSION_NOT_PRESENT. After verifying and
-- enabling the instance layers and extensions the VkInstance
-- object is created and returned to the application. If a requested
-- extension is only supported by a layer, both the layer and the
-- extension need to be specified at vkCreateInstance time for
-- the creation to succeed.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkInstanceCreateInfo structure
--
--
--
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pInstance must be a valid pointer to a
-- VkInstance handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- 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
--
--
-- See Also
--
-- VkAllocationCallbacks, VkInstance,
-- VkInstanceCreateInfo
vkCreateInstance :: ("pCreateInfo" ::: Ptr VkInstanceCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pInstance" ::: Ptr VkInstance) -> IO VkResult
-- | vkDestroyInstance - Destroy an instance of Vulkan
--
-- Parameters
--
--
-- - instance is the handle of the instance to destroy.
--
--
--
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All child objects created using instance must have
-- been destroyed prior to destroying instance
--
--
--
-- - If VkAllocationCallbacks were provided when
-- instance was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- instance was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - If instance is not NULL, instance
-- must be a valid VkInstance handle
--
--
--
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
--
--
-- Host Synchronization
--
--
-- - Host access to instance must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkInstance
vkDestroyInstance :: ("instance" ::: VkInstance) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkEnumeratePhysicalDevices - Enumerates the physical devices
-- accessible to a Vulkan instance
--
-- Parameters
--
--
-- - instance is a handle to a Vulkan instance previously
-- created with vkCreateInstance.
--
--
--
-- - pPhysicalDeviceCount is a pointer to an integer related
-- to the number of physical devices available or queried, as described
-- below.
-- - pPhysicalDevices is either NULL or a pointer to
-- an array of VkPhysicalDevice handles.
--
--
-- Description
--
-- If pPhysicalDevices is NULL, then the number of
-- physical devices available is returned in
-- pPhysicalDeviceCount. Otherwise,
-- pPhysicalDeviceCount must point to a variable set by
-- the user to the number of elements in the pPhysicalDevices
-- array, and on return the variable is overwritten with the number of
-- handles actually written to pPhysicalDevices. If
-- pPhysicalDeviceCount is less than the number of physical
-- devices available, at most pPhysicalDeviceCount structures
-- will be written. If pPhysicalDeviceCount is smaller than the
-- number of physical devices available, VK_INCOMPLETE will be
-- returned instead of VK_SUCCESS, to indicate that not all the
-- available physical devices were returned.
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - pPhysicalDeviceCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPhysicalDeviceCount is not
-- 0, and pPhysicalDevices is not NULL,
-- pPhysicalDevices must be a valid pointer to an array
-- of pPhysicalDeviceCount VkPhysicalDevice
-- handles
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkInstance, VkPhysicalDevice
vkEnumeratePhysicalDevices :: ("instance" ::: VkInstance) -> ("pPhysicalDeviceCount" ::: Ptr Word32) -> ("pPhysicalDevices" ::: Ptr VkPhysicalDevice) -> IO VkResult
-- | vkGetDeviceProcAddr - Return a function pointer for a command
--
-- Parameters
--
-- The table below defines the various use cases for
-- vkGetDeviceProcAddr and expected return value for each case.
--
-- Description
--
-- The returned function pointer is of type PFN_vkVoidFunction,
-- and must be cast to the type of the command being queried. The
-- function pointer must only be called with a dispatchable object
-- (the first parameter) that is device or a child of
-- device.
--
--
-- +-----------------------+-----------------------+-----------------------+
-- | @device@ | @pName@ | return value |
-- +=======================+=======================+=======================+
-- | @NULL@ | * | undefined |
-- +-----------------------+-----------------------+-----------------------+
-- | invalid device | * | undefined |
-- +-----------------------+-----------------------+-----------------------+
-- | device | @NULL@ | undefined |
-- +-----------------------+-----------------------+-----------------------+
-- | device | core device-level | fp |
-- | | Vulkan command | |
-- +-----------------------+-----------------------+-----------------------+
-- | device | enabled device | fp |
-- | | extension commands | |
-- +-----------------------+-----------------------+-----------------------+
-- | device | * (any @pName@ not | @NULL@ |
-- | | covered above) | |
-- +-----------------------+-----------------------+-----------------------+
--
-- vkGetDeviceProcAddr behavior
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pName must be a null-terminated UTF-8 string
--
--
-- See Also
--
-- PFN_vkVoidFunction, VkDevice
vkGetDeviceProcAddr :: ("device" ::: VkDevice) -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
-- | vkGetInstanceProcAddr - Return a function pointer for a command
--
-- Parameters
--
--
-- - instance is the instance that the function pointer will
-- be compatible with, or NULL for commands not dependent on any
-- instance.
--
--
--
-- - pName is the name of the command to obtain.
--
--
-- Description
--
-- vkGetInstanceProcAddr itself is obtained in a platform- and
-- loader- specific manner. Typically, the loader library will export
-- this command as a function symbol, so applications can link
-- against the loader library, or load it dynamically and look up the
-- symbol using platform-specific APIs.
--
-- The table below defines the various use cases for
-- vkGetInstanceProcAddr and expected return value (“fp” is
-- “function pointer”) for each case.
--
-- The returned function pointer is of type PFN_vkVoidFunction,
-- and must be cast to the type of the command being queried.
--
--
-- +-----------------------+-----------------------+-----------------------+
-- | @instance@ | @pName@ | return value |
-- +=======================+=======================+=======================+
-- | * | @NULL@ | undefined |
-- +-----------------------+-----------------------+-----------------------+
-- | invalid instance | * | undefined |
-- +-----------------------+-----------------------+-----------------------+
-- | @NULL@ | 'Graphics.Vulkan.Core | fp |
-- | | 10.ExtensionDiscovery | |
-- | | .vkEnumerateInstanceE | |
-- | | xtensionProperties' | |
-- +-----------------------+-----------------------+-----------------------+
-- | @NULL@ | 'Graphics.Vulkan.Core | fp |
-- | | 10.LayerDiscovery.vkE | |
-- | | numerateInstanceLayer | |
-- | | Properties' | |
-- +-----------------------+-----------------------+-----------------------+
-- | @NULL@ | 'vkCreateInstance' | fp |
-- +-----------------------+-----------------------+-----------------------+
-- | @NULL@ | * (any @pName@ not | @NULL@ |
-- | | covered above) | |
-- +-----------------------+-----------------------+-----------------------+
-- | instance | core Vulkan command | fp1 |
-- +-----------------------+-----------------------+-----------------------+
-- | instance | enabled instance | fp1 |
-- | | extension commands | |
-- | | for @instance@ | |
-- +-----------------------+-----------------------+-----------------------+
-- | instance | available device | fp1 |
-- | | extension2 commands | |
-- | | for @instance@ | |
-- +-----------------------+-----------------------+-----------------------+
-- | instance | * (any @pName@ not | @NULL@ |
-- | | covered above) | |
-- +-----------------------+-----------------------+-----------------------+
--
-- vkGetInstanceProcAddr behavior
--
--
--
-- - 1 The returned function pointer must only be called
-- with a dispatchable object (the first parameter) that is
-- instance or a child of instance, e.g.
-- VkInstance, VkPhysicalDevice, VkDevice,
-- VkQueue, or VkCommandBuffer.
-- - 2 An “available device extension” is a device extension
-- supported by any physical device enumerated by instance.
--
--
-- Valid Usage (Implicit)
--
--
-- - If instance is not NULL, instance
-- must be a valid VkInstance handle
--
--
--
-- - pName must be a null-terminated UTF-8 string
--
--
-- See Also
--
-- PFN_vkVoidFunction, VkInstance
vkGetInstanceProcAddr :: ("instance" ::: VkInstance) -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
-- | vkGetPhysicalDeviceProperties - Returns properties of a physical
-- device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the physical device whose
-- properties will be queried.
--
--
--
-- - pProperties points to an instance of the
-- VkPhysicalDeviceProperties structure, that will be filled with
-- returned information.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pProperties must be a valid pointer to a
-- VkPhysicalDeviceProperties structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceProperties
vkGetPhysicalDeviceProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pProperties" ::: Ptr VkPhysicalDeviceProperties) -> IO ()
-- | vkGetPhysicalDeviceQueueFamilyProperties - Reports properties of the
-- queues of the specified physical device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the physical device whose
-- properties will be queried.
--
--
--
-- - pQueueFamilyPropertyCount is a pointer to an integer
-- related to the number of queue families available or queried, as
-- described below.
-- - pQueueFamilyProperties is either NULL or a
-- pointer to an array of VkQueueFamilyProperties structures.
--
--
-- Description
--
-- If pQueueFamilyProperties is NULL, then the number
-- of queue families available is returned in
-- pQueueFamilyPropertyCount. Otherwise,
-- pQueueFamilyPropertyCount must point to a variable set
-- by the user to the number of elements in the
-- pQueueFamilyProperties array, and on return the variable is
-- overwritten with the number of structures actually written to
-- pQueueFamilyProperties. If pQueueFamilyPropertyCount
-- is less than the number of queue families available, at most
-- pQueueFamilyPropertyCount structures will be written.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pQueueFamilyPropertyCount must be a valid pointer
-- to a uint32_t value
-- - If the value referenced by pQueueFamilyPropertyCount is
-- not 0, and pQueueFamilyProperties is not
-- NULL, pQueueFamilyProperties must be a valid
-- pointer to an array of pQueueFamilyPropertyCount
-- VkQueueFamilyProperties structures
--
--
-- See Also
--
-- VkPhysicalDevice, VkQueueFamilyProperties
vkGetPhysicalDeviceQueueFamilyProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pQueueFamilyPropertyCount" ::: Ptr Word32) -> ("pQueueFamilyProperties" ::: Ptr VkQueueFamilyProperties) -> IO ()
-- | vkGetPhysicalDeviceMemoryProperties - Reports memory information for
-- the specified physical device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the device to query.
--
--
--
-- - pMemoryProperties points to an instance of
-- VkPhysicalDeviceMemoryProperties structure in which the
-- properties are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pMemoryProperties must be a valid pointer to a
-- VkPhysicalDeviceMemoryProperties structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceMemoryProperties
vkGetPhysicalDeviceMemoryProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pMemoryProperties" ::: Ptr VkPhysicalDeviceMemoryProperties) -> IO ()
-- | vkGetPhysicalDeviceFeatures - Reports capabilities of a physical
-- device
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the supported features.
--
--
--
-- - pFeatures is a pointer to a
-- VkPhysicalDeviceFeatures structure in which the physical device
-- features are returned. For each feature, a value of VK_TRUE
-- specifies that the feature is supported on this physical device, and
-- VK_FALSE specifies that the feature is not supported.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pFeatures must be a valid pointer to a
-- VkPhysicalDeviceFeatures structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceFeatures
vkGetPhysicalDeviceFeatures :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFeatures" ::: Ptr VkPhysicalDeviceFeatures) -> IO ()
-- | vkGetPhysicalDeviceFormatProperties - Lists physical device’s format
-- capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the format properties.
--
--
--
-- - format is the format whose properties are queried.
-- - pFormatProperties is a pointer to a
-- VkFormatProperties structure in which physical device
-- properties for format are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - format must be a valid VkFormat value
-- - pFormatProperties must be a valid pointer to a
-- VkFormatProperties structure
--
--
-- See Also
--
-- VkFormat, VkFormatProperties, VkPhysicalDevice
vkGetPhysicalDeviceFormatProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("pFormatProperties" ::: Ptr VkFormatProperties) -> IO ()
-- | vkGetPhysicalDeviceImageFormatProperties - Lists physical device’s
-- image format capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the image capabilities.
--
--
--
--
-- Description
--
-- The format, type, tiling, usage,
-- and flags parameters correspond to parameters that would be
-- consumed by vkCreateImage (as members of
-- VkImageCreateInfo).
--
-- If format is not a supported image format, or if the
-- combination of format, type, tiling,
-- usage, and flags is not supported for images, then
-- vkGetPhysicalDeviceImageFormatProperties returns
-- VK_ERROR_FORMAT_NOT_SUPPORTED.
--
-- The limitations on an image format that are reported by
-- vkGetPhysicalDeviceImageFormatProperties have the following
-- property: if usage1 and usage2 of type
-- VkImageUsageFlags are such that the bits set in usage1
-- are a subset of the bits set in usage2, and flags1
-- and flags2 of type VkImageCreateFlags are such that
-- the bits set in flags1 are a subset of the bits set in
-- flags2, then the limitations for usage1 and
-- flags1 must be no more strict than the limitations for
-- usage2 and flags2, for all values of
-- format, type, and tiling.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - format must be a valid VkFormat value
-- - type must be a valid VkImageType value
-- - tiling must be a valid VkImageTiling
-- value
-- - usage must be a valid combination of
-- VkImageUsageFlagBits values
-- - usage must not be 0
-- - flags must be a valid combination of
-- VkImageCreateFlagBits values
-- - pImageFormatProperties must be a valid pointer to
-- a VkImageFormatProperties structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkFormat, VkImageCreateFlags,
-- VkImageFormatProperties, VkImageTiling,
-- VkImageType, VkImageUsageFlags, VkPhysicalDevice
vkGetPhysicalDeviceImageFormatProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("type" ::: VkImageType) -> ("tiling" ::: VkImageTiling) -> ("usage" ::: VkImageUsageFlags) -> ("flags" ::: VkImageCreateFlags) -> ("pImageFormatProperties" ::: Ptr VkImageFormatProperties) -> IO VkResult
-- | VkExtent3D - Structure specifying a three-dimensional extent
--
-- Description
--
-- See Also
--
-- VkBufferImageCopy, VkImageCopy,
-- VkImageCreateInfo, VkImageFormatProperties,
-- VkImageResolve, VkQueueFamilyProperties,
-- VkSparseImageFormatProperties, VkSparseImageMemoryBind
data VkExtent3D
VkExtent3D :: Word32 -> Word32 -> Word32 -> VkExtent3D
-- | width is the width of the extent.
[$sel:vkWidth:VkExtent3D] :: VkExtent3D -> Word32
-- | height is the height of the extent.
[$sel:vkHeight:VkExtent3D] :: VkExtent3D -> Word32
-- | depth is the depth of the extent.
[$sel:vkDepth:VkExtent3D] :: VkExtent3D -> Word32
-- | VkPhysicalDeviceProperties - Structure specifying physical device
-- properties
--
-- Description
--
-- The vendorID and deviceID fields are provided to
-- allow applications to adapt to device characteristics that are not
-- adequately exposed by other Vulkan queries.
--
-- Note
--
-- These may include performance profiles, hardware errata, or
-- other characteristics.
--
-- The vendor identified by vendorID is the entity
-- responsible for the most salient characteristics of the underlying
-- implementation of the VkPhysicalDevice being queried.
--
-- Note
--
-- For example, in the case of a discrete GPU implementation, this
-- should be the GPU chipset vendor. In the case of a hardware
-- accelerator integrated into a system-on-chip (SoC), this should
-- be the supplier of the silicon IP used to create the accelerator.
--
-- If the vendor has a PCI vendor ID, the low 16 bits of
-- vendorID must contain that PCI vendor ID, and the
-- remaining bits must be set to zero. Otherwise, the value
-- returned must be a valid Khronos vendor ID, obtained as
-- described in the Vulkan Documentation and Extensions document
-- in the section “Registering a Vendor ID with Khronos”. Khronos vendor
-- IDs are allocated starting at 0x10000, to distinguish them from the
-- PCI vendor ID namespace.
--
-- The vendor is also responsible for the value returned in
-- deviceID. If the implementation is driven primarily by a
-- PCI device with a PCI device ID, the low 16 bits of
-- deviceID must contain that PCI device ID, and the
-- remaining bits must be set to zero. Otherwise, the choice of
-- what values to return may be dictated by operating system or
-- platform policies - but should uniquely identify both the
-- device version and any major configuration options (for example, core
-- count in the case of multicore devices).
--
-- Note
--
-- The same device ID should be used for all physical
-- implementations of that device version and configuration. For example,
-- all uses of a specific silicon IP GPU version and configuration
-- should use the same device ID, even if those uses occur in
-- different SoCs.
--
-- See Also
--
-- VkPhysicalDeviceLimits, VkPhysicalDeviceProperties2,
-- VkPhysicalDeviceSparseProperties, VkPhysicalDeviceType,
-- vkGetPhysicalDeviceProperties
data VkPhysicalDeviceProperties
VkPhysicalDeviceProperties :: Word32 -> Word32 -> Word32 -> Word32 -> VkPhysicalDeviceType -> Vector VK_MAX_PHYSICAL_DEVICE_NAME_SIZE CChar -> Vector VK_UUID_SIZE Word8 -> VkPhysicalDeviceLimits -> VkPhysicalDeviceSparseProperties -> VkPhysicalDeviceProperties
-- | apiVersion is the version of Vulkan supported by the device,
-- encoded as described in the API Version Numbers and Semantics
-- section.
[$sel:vkApiVersion:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Word32
-- | driverVersion is the vendor-specified version of the driver.
[$sel:vkDriverVersion:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Word32
-- | vendorID is a unique identifier for the vendor (see
-- below) of the physical device.
[$sel:vkVendorID:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Word32
-- | deviceID is a unique identifier for the physical device among
-- devices available from the vendor.
[$sel:vkDeviceID:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Word32
-- | deviceType is a VkPhysicalDeviceType specifying the
-- type of device.
[$sel:vkDeviceType:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> VkPhysicalDeviceType
-- | deviceName is a null-terminated UTF-8 string containing the
-- name of the device.
[$sel:vkDeviceName:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Vector VK_MAX_PHYSICAL_DEVICE_NAME_SIZE CChar
-- | pipelineCacheUUID is an array of size VK_UUID_SIZE,
-- containing 8-bit values that represent a universally unique identifier
-- for the device.
[$sel:vkPipelineCacheUUID:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> Vector VK_UUID_SIZE Word8
-- | limits is the VkPhysicalDeviceLimits structure which
-- specifies device-specific limits of the physical device. See
-- Limits for details.
[$sel:vkLimits:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> VkPhysicalDeviceLimits
-- | sparseProperties is the
-- VkPhysicalDeviceSparseProperties structure which specifies
-- various sparse related properties of the physical device. See
-- Sparse Properties for details.
[$sel:vkSparseProperties:VkPhysicalDeviceProperties] :: VkPhysicalDeviceProperties -> VkPhysicalDeviceSparseProperties
-- | VkApplicationInfo - Structure specifying application info
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_APPLICATION_INFO
--
--
--
-- - pNext must be NULL
-- - If pApplicationName is not NULL,
-- pApplicationName must be a null-terminated UTF-8
-- string
-- - If pEngineName is not NULL, pEngineName
-- must be a null-terminated UTF-8 string
--
--
-- See Also
--
-- VkInstanceCreateInfo, VkStructureType
data VkApplicationInfo
VkApplicationInfo :: VkStructureType -> Ptr () -> Ptr CChar -> Word32 -> Ptr CChar -> Word32 -> Word32 -> VkApplicationInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkApplicationInfo] :: VkApplicationInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkApplicationInfo] :: VkApplicationInfo -> Ptr ()
-- | pApplicationName is NULL or is a pointer to a
-- null-terminated UTF-8 string containing the name of the application.
[$sel:vkPApplicationName:VkApplicationInfo] :: VkApplicationInfo -> Ptr CChar
-- | applicationVersion is an unsigned integer variable containing
-- the developer-supplied version number of the application.
[$sel:vkApplicationVersion:VkApplicationInfo] :: VkApplicationInfo -> Word32
-- | pEngineName is NULL or is a pointer to a
-- null-terminated UTF-8 string containing the name of the engine (if
-- any) used to create the application.
[$sel:vkPEngineName:VkApplicationInfo] :: VkApplicationInfo -> Ptr CChar
-- | engineVersion is an unsigned integer variable containing the
-- developer-supplied version number of the engine used to create the
-- application.
[$sel:vkEngineVersion:VkApplicationInfo] :: VkApplicationInfo -> Word32
-- | apiVersion is the version of the Vulkan API against which the
-- application expects to run, encoded as described in the API Version
-- Numbers and Semantics section. If apiVersion is 0 the
-- implementation must ignore it, otherwise if the implementation
-- does not support the requested apiVersion, or an effective
-- substitute for apiVersion, it must return
-- VK_ERROR_INCOMPATIBLE_DRIVER. The patch version number
-- specified in apiVersion is ignored when creating an instance
-- object. Only the major and minor versions of the instance must
-- match those requested in apiVersion.
[$sel:vkApiVersion:VkApplicationInfo] :: VkApplicationInfo -> Word32
-- | VkAllocationCallbacks - Structure containing callback function
-- pointers for memory allocation
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - pfnReallocation must be a valid pointer to a valid
-- user-defined PFN_vkReallocationFunction
-- - pfnFree must be a valid pointer to a valid
-- user-defined PFN_vkFreeFunction
-- - If either of pfnInternalAllocation or
-- pfnInternalFree is not NULL, both must be
-- valid callbacks
--
--
-- See Also
--
-- PFN_vkAllocationFunction, PFN_vkFreeFunction,
-- PFN_vkInternalAllocationNotification,
-- PFN_vkInternalFreeNotification,
-- PFN_vkReallocationFunction, vkAllocateMemory,
-- vkCreateAndroidSurfaceKHR, vkCreateBuffer,
-- vkCreateBufferView, vkCreateCommandPool,
-- vkCreateComputePipelines,
-- vkCreateDebugReportCallbackEXT,
-- vkCreateDebugUtilsMessengerEXT, vkCreateDescriptorPool,
-- vkCreateDescriptorSetLayout,
-- vkCreateDescriptorUpdateTemplate,
-- vkCreateDescriptorUpdateTemplateKHR, vkCreateDevice,
-- vkCreateDisplayModeKHR, vkCreateDisplayPlaneSurfaceKHR,
-- vkCreateEvent, vkCreateFence,
-- vkCreateFramebuffer, vkCreateGraphicsPipelines,
-- vkCreateIOSSurfaceMVK, vkCreateImage,
-- vkCreateImageView, vkCreateIndirectCommandsLayoutNVX,
-- vkCreateInstance, vkCreateMacOSSurfaceMVK,
-- vkCreateMirSurfaceKHR, vkCreateObjectTableNVX,
-- vkCreatePipelineCache, vkCreatePipelineLayout,
-- vkCreateQueryPool, vkCreateRenderPass,
-- vkCreateSampler, vkCreateSamplerYcbcrConversion,
-- vkCreateSamplerYcbcrConversionKHR, vkCreateSemaphore,
-- vkCreateShaderModule, vkCreateSharedSwapchainsKHR,
-- vkCreateSwapchainKHR, vkCreateValidationCacheEXT,
-- vkCreateViSurfaceNN, vkCreateWaylandSurfaceKHR,
-- vkCreateWin32SurfaceKHR, vkCreateXcbSurfaceKHR,
-- vkCreateXlibSurfaceKHR, vkDestroyBuffer,
-- vkDestroyBufferView, vkDestroyCommandPool,
-- vkDestroyDebugReportCallbackEXT,
-- vkDestroyDebugUtilsMessengerEXT,
-- vkDestroyDescriptorPool, vkDestroyDescriptorSetLayout,
-- vkDestroyDescriptorUpdateTemplate,
-- vkDestroyDescriptorUpdateTemplateKHR, vkDestroyDevice,
-- vkDestroyEvent, vkDestroyFence,
-- vkDestroyFramebuffer, vkDestroyImage,
-- vkDestroyImageView, vkDestroyIndirectCommandsLayoutNVX,
-- vkDestroyInstance, vkDestroyObjectTableNVX,
-- vkDestroyPipeline, vkDestroyPipelineCache,
-- vkDestroyPipelineLayout, vkDestroyQueryPool,
-- vkDestroyRenderPass, vkDestroySampler,
-- vkDestroySamplerYcbcrConversion,
-- vkDestroySamplerYcbcrConversionKHR, vkDestroySemaphore,
-- vkDestroyShaderModule, vkDestroySurfaceKHR,
-- vkDestroySwapchainKHR, vkDestroyValidationCacheEXT,
-- vkFreeMemory, vkRegisterDeviceEventEXT,
-- vkRegisterDisplayEventEXT
data VkAllocationCallbacks
VkAllocationCallbacks :: Ptr () -> PFN_vkAllocationFunction -> PFN_vkReallocationFunction -> PFN_vkFreeFunction -> PFN_vkInternalAllocationNotification -> PFN_vkInternalFreeNotification -> VkAllocationCallbacks
-- | pUserData is a value to be interpreted by the implementation
-- of the callbacks. When any of the callbacks in
-- VkAllocationCallbacks are called, the Vulkan implementation
-- will pass this value as the first parameter to the callback. This
-- value can vary each time an allocator is passed into a command,
-- even when the same object takes an allocator in multiple commands.
[$sel:vkPUserData:VkAllocationCallbacks] :: VkAllocationCallbacks -> Ptr ()
-- | pfnAllocation is a pointer to an application-defined memory
-- allocation function of type PFN_vkAllocationFunction.
[$sel:vkPfnAllocation:VkAllocationCallbacks] :: VkAllocationCallbacks -> PFN_vkAllocationFunction
-- | pfnReallocation is a pointer to an application-defined memory
-- reallocation function of type PFN_vkReallocationFunction.
[$sel:vkPfnReallocation:VkAllocationCallbacks] :: VkAllocationCallbacks -> PFN_vkReallocationFunction
-- | pfnFree is a pointer to an application-defined memory free
-- function of type PFN_vkFreeFunction.
[$sel:vkPfnFree:VkAllocationCallbacks] :: VkAllocationCallbacks -> PFN_vkFreeFunction
-- | pfnInternalAllocation is a pointer to an application-defined
-- function that is called by the implementation when the implementation
-- makes internal allocations, and it is of type
-- PFN_vkInternalAllocationNotification.
[$sel:vkPfnInternalAllocation:VkAllocationCallbacks] :: VkAllocationCallbacks -> PFN_vkInternalAllocationNotification
-- | pfnInternalFree is a pointer to an application-defined
-- function that is called by the implementation when the implementation
-- frees internal allocations, and it is of type
-- PFN_vkInternalFreeNotification.
[$sel:vkPfnInternalFree:VkAllocationCallbacks] :: VkAllocationCallbacks -> PFN_vkInternalFreeNotification
-- | VkInstanceCreateInfo - Structure specifying parameters of a newly
-- created instance
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkDebugReportCallbackCreateInfoEXT,
-- VkDebugUtilsMessengerCreateInfoEXT, or
-- VkValidationFlagsEXT
-- - Each sType member in the pNext chain must
-- be unique
-- - flags must be 0
-- - If pApplicationInfo is not NULL,
-- pApplicationInfo must be a valid pointer to a valid
-- VkApplicationInfo structure
-- - If enabledLayerCount is not 0,
-- ppEnabledLayerNames must be a valid pointer to an
-- array of enabledLayerCount null-terminated UTF-8 strings
-- - If enabledExtensionCount is not 0,
-- ppEnabledExtensionNames must be a valid pointer to an
-- array of enabledExtensionCount null-terminated UTF-8
-- strings
--
--
-- See Also
--
-- VkApplicationInfo, VkInstanceCreateFlags,
-- VkStructureType, vkCreateInstance
data VkInstanceCreateInfo
VkInstanceCreateInfo :: VkStructureType -> Ptr () -> VkInstanceCreateFlags -> Ptr VkApplicationInfo -> Word32 -> Ptr (Ptr CChar) -> Word32 -> Ptr (Ptr CChar) -> VkInstanceCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> VkInstanceCreateFlags
-- | pApplicationInfo is NULL or a pointer to an instance
-- of VkApplicationInfo. If not NULL, this information
-- helps implementations recognize behavior inherent to classes of
-- applications. VkApplicationInfo is defined in detail below.
[$sel:vkPApplicationInfo:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Ptr VkApplicationInfo
-- | enabledLayerCount is the number of global layers to enable.
[$sel:vkEnabledLayerCount:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Word32
-- | ppEnabledLayerNames is a pointer to an array of
-- enabledLayerCount null-terminated UTF-8 strings containing
-- the names of layers to enable for the created instance. See the
-- Layers section for further details.
[$sel:vkPPEnabledLayerNames:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Ptr (Ptr CChar)
-- | enabledExtensionCount is the number of global extensions to
-- enable.
[$sel:vkEnabledExtensionCount:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Word32
-- | ppEnabledExtensionNames is a pointer to an array of
-- enabledExtensionCount null-terminated UTF-8 strings
-- containing the names of extensions to enable.
[$sel:vkPPEnabledExtensionNames:VkInstanceCreateInfo] :: VkInstanceCreateInfo -> Ptr (Ptr CChar)
-- | VkQueueFamilyProperties - Structure providing information about a
-- queue family
--
-- Description
--
-- The value returned in minImageTransferGranularity has a unit
-- of compressed texel blocks for images having a block-compressed
-- format, and a unit of texels otherwise.
--
-- Possible values of minImageTransferGranularity are:
--
--
-- - (0,0,0) which indicates that only whole mip levels must be
-- transferred using the image transfer operations on the corresponding
-- queues. In this case, the following restrictions apply to all offset
-- and extent parameters of image transfer operations:
- The
-- x, y, and z members of a VkOffset3D
-- parameter must always be zero.
- The width,
-- height, and depth members of a VkExtent3D
-- parameter must always match the width, height, and depth of the
-- image subresource corresponding to the parameter,
-- respectively.
-- - (Ax, Ay, Az) where Ax, Ay, and Az are all integer powers of two.
-- In this case the following restrictions apply to all image transfer
-- operations:
- x, y, and z of a
-- VkOffset3D parameter must be integer multiples of Ax,
-- Ay, and Az, respectively.
- width of a
-- VkExtent3D parameter must be an integer multiple of Ax,
-- or else x + width must equal the width of the
-- image subresource corresponding to the
-- parameter.
- height of a VkExtent3D parameter
-- must be an integer multiple of Ay, or else y +
-- height must equal the height of the image subresource
-- corresponding to the parameter.
- depth of a
-- VkExtent3D parameter must be an integer multiple of Az,
-- or else z + depth must equal the depth of the
-- image subresource corresponding to the parameter.
- If the
-- format of the image corresponding to the parameters is one of the
-- block-compressed formats then for the purposes of the above
-- calculations the granularity must be scaled up by the
-- compressed texel block dimensions.
--
--
-- Queues supporting graphics and/or compute operations must
-- report (1,1,1) in minImageTransferGranularity, meaning that
-- there are no additional restrictions on the granularity of image
-- transfer operations for these queues. Other queues supporting image
-- transfer operations are only required to support whole mip
-- level transfers, thus minImageTransferGranularity for queues
-- belonging to such queue families may be (0,0,0).
--
-- The Device Memory section describes memory properties queried
-- from the physical device.
--
-- For physical device feature queries see the Features chapter.
--
-- See Also
--
-- VkExtent3D, VkQueueFamilyProperties2,
-- VkQueueFlags, vkGetPhysicalDeviceQueueFamilyProperties
data VkQueueFamilyProperties
VkQueueFamilyProperties :: VkQueueFlags -> Word32 -> Word32 -> VkExtent3D -> VkQueueFamilyProperties
-- | queueFlags is a bitmask of VkQueueFlagBits indicating
-- capabilities of the queues in this queue family.
[$sel:vkQueueFlags:VkQueueFamilyProperties] :: VkQueueFamilyProperties -> VkQueueFlags
-- | queueCount is the unsigned integer count of queues in this
-- queue family.
[$sel:vkQueueCount:VkQueueFamilyProperties] :: VkQueueFamilyProperties -> Word32
-- | timestampValidBits is the unsigned integer count of
-- meaningful bits in the timestamps written via
-- vkCmdWriteTimestamp. The valid range for the count is 36..64
-- bits, or a value of 0, indicating no support for timestamps. Bits
-- outside the valid range are guaranteed to be zeros.
[$sel:vkTimestampValidBits:VkQueueFamilyProperties] :: VkQueueFamilyProperties -> Word32
-- | minImageTransferGranularity is the minimum granularity
-- supported for image transfer operations on the queues in this queue
-- family.
[$sel:vkMinImageTransferGranularity:VkQueueFamilyProperties] :: VkQueueFamilyProperties -> VkExtent3D
-- | VkPhysicalDeviceMemoryProperties - Structure specifying physical
-- device memory properties
--
-- Description
--
-- The VkPhysicalDeviceMemoryProperties structure describes a
-- number of memory heaps as well as a number of memory
-- types that can be used to access memory allocated in those
-- heaps. Each heap describes a memory resource of a particular size, and
-- each memory type describes a set of memory properties (e.g. host
-- cached vs uncached) that can be used with a given memory heap.
-- Allocations using a particular memory type will consume resources from
-- the heap indicated by that memory type’s heap index. More than one
-- memory type may share each heap, and the heaps and memory types
-- provide a mechanism to advertise an accurate size of the physical
-- memory resources while allowing the memory to be used with a variety
-- of different properties.
--
-- The number of memory heaps is given by memoryHeapCount and is
-- less than or equal to VK_MAX_MEMORY_HEAPS. Each heap is
-- described by an element of the memoryHeaps array as a
-- VkMemoryHeap structure. The number of memory types available
-- across all memory heaps is given by memoryTypeCount and is
-- less than or equal to VK_MAX_MEMORY_TYPES. Each memory type
-- is described by an element of the memoryTypes array as a
-- VkMemoryType structure.
--
-- At least one heap must include
-- VK_MEMORY_HEAP_DEVICE_LOCAL_BIT in
-- VkMemoryHeap::flags. If there are multiple heaps that
-- all have similar performance characteristics, they may all
-- include VK_MEMORY_HEAP_DEVICE_LOCAL_BIT. In a unified memory
-- architecture (UMA) system there is often only a single memory heap
-- which is considered to be equally “local” to the host and to the
-- device, and such an implementation must advertise the heap as
-- device-local.
--
-- Each memory type returned by
-- vkGetPhysicalDeviceMemoryProperties must have its
-- propertyFlags set to one of the following values:
--
--
--
-- There must be at least one memory type with both the
-- VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT and
-- VK_MEMORY_PROPERTY_HOST_COHERENT_BIT bits set in its
-- propertyFlags. There must be at least one memory type
-- with the VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT bit set in its
-- propertyFlags.
--
-- For each pair of elements X and Y returned in
-- memoryTypes, X must be placed at a lower index
-- position than Y if:
--
--
-- - either the set of bit flags returned in the propertyFlags
-- member of X is a strict subset of the set of bit flags returned
-- in the propertyFlags member of Y.
-- - or the propertyFlags members of X and Y are
-- equal, and X belongs to a memory heap with greater performance
-- (as determined in an implementation-specific manner).
--
--
-- Note
--
-- There is no ordering requirement between X and Y
-- elements for the case their propertyFlags members are not in
-- a subset relation. That potentially allows more than one possible way
-- to order the same set of memory types. Notice that the list of all
-- allowed memory property flag combinations is written in the
-- required order. But if instead
-- VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT was before
-- VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT |
-- VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, the list would still be
-- in the required order.
--
-- This ordering requirement enables applications to use a simple search
-- loop to select the desired memory type along the lines of:
--
--
-- // Find a memory in `memoryTypeBitsRequirement` that includes all of `requiredProperties`
-- int32_t findProperties(const VkPhysicalDeviceMemoryProperties* pMemoryProperties,
-- uint32_t memoryTypeBitsRequirement,
-- VkMemoryPropertyFlags requiredProperties) {
-- const uint32_t memoryCount = pMemoryProperties->memoryTypeCount;
-- for (uint32_t memoryIndex = 0; memoryIndex < memoryCount; ++memoryIndex) {
-- const uint32_t memoryTypeBits = (1 << memoryIndex);
-- const bool isRequiredMemoryType = memoryTypeBitsRequirement & memoryTypeBits;
--
-- const VkMemoryPropertyFlags properties =
-- pMemoryProperties->memoryTypes[memoryIndex].propertyFlags;
-- const bool hasRequiredProperties =
-- (properties & requiredProperties) == requiredProperties;
--
-- if (isRequiredMemoryType && hasRequiredProperties)
-- return static_cast<int32_t>(memoryIndex);
-- }
--
-- // failed to find memory type
-- return -1;
-- }
--
-- // Try to find an optimal memory type, or if it does not exist try fallback memory type
-- // `device` is the VkDevice
-- // `image` is the VkImage that requires memory to be bound
-- // `memoryProperties` properties as returned by vkGetPhysicalDeviceMemoryProperties
-- // `requiredProperties` are the property flags that must be present
-- // `optimalProperties` are the property flags that are preferred by the application
-- VkMemoryRequirements memoryRequirements;
-- vkGetImageMemoryRequirements(device, image, &memoryRequirements);
-- int32_t memoryType =
-- findProperties(&memoryProperties, memoryRequirements.memoryTypeBits, optimalProperties);
-- if (memoryType == -1) // not found; try fallback properties
-- memoryType =
-- findProperties(&memoryProperties, memoryRequirements.memoryTypeBits, requiredProperties);
--
--
-- See Also
--
-- VkMemoryHeap, VkMemoryType,
-- VkPhysicalDeviceMemoryProperties2,
-- vkGetPhysicalDeviceMemoryProperties
data VkPhysicalDeviceMemoryProperties
VkPhysicalDeviceMemoryProperties :: Word32 -> Vector VK_MAX_MEMORY_TYPES VkMemoryType -> Word32 -> Vector VK_MAX_MEMORY_HEAPS VkMemoryHeap -> VkPhysicalDeviceMemoryProperties
-- | memoryTypeCount is the number of valid elements in the
-- memoryTypes array.
[$sel:vkMemoryTypeCount:VkPhysicalDeviceMemoryProperties] :: VkPhysicalDeviceMemoryProperties -> Word32
-- | memoryTypes is an array of VkMemoryType structures
-- describing the memory types that can be used to access
-- memory allocated from the heaps specified by memoryHeaps.
[$sel:vkMemoryTypes:VkPhysicalDeviceMemoryProperties] :: VkPhysicalDeviceMemoryProperties -> Vector VK_MAX_MEMORY_TYPES VkMemoryType
-- | memoryHeapCount is the number of valid elements in the
-- memoryHeaps array.
[$sel:vkMemoryHeapCount:VkPhysicalDeviceMemoryProperties] :: VkPhysicalDeviceMemoryProperties -> Word32
-- | memoryHeaps is an array of VkMemoryHeap structures
-- describing the memory heaps from which memory can be
-- allocated.
[$sel:vkMemoryHeaps:VkPhysicalDeviceMemoryProperties] :: VkPhysicalDeviceMemoryProperties -> Vector VK_MAX_MEMORY_HEAPS VkMemoryHeap
-- | VkMemoryType - Structure specifying memory type
--
-- Description
--
-- See Also
--
-- VkMemoryPropertyFlags, VkPhysicalDeviceMemoryProperties
data VkMemoryType
VkMemoryType :: VkMemoryPropertyFlags -> Word32 -> VkMemoryType
-- | propertyFlags is a bitmask of VkMemoryPropertyFlagBits
-- of properties for this memory type.
[$sel:vkPropertyFlags:VkMemoryType] :: VkMemoryType -> VkMemoryPropertyFlags
-- | heapIndex describes which memory heap this memory type
-- corresponds to, and must be less than memoryHeapCount
-- from the VkPhysicalDeviceMemoryProperties structure.
[$sel:vkHeapIndex:VkMemoryType] :: VkMemoryType -> Word32
-- | VkMemoryHeap - Structure specifying a memory heap
--
-- Description
--
-- See Also
--
-- VkDeviceSize, VkMemoryHeapFlags,
-- VkPhysicalDeviceMemoryProperties
data VkMemoryHeap
VkMemoryHeap :: VkDeviceSize -> VkMemoryHeapFlags -> VkMemoryHeap
-- | size is the total memory size in bytes in the heap.
[$sel:vkSize:VkMemoryHeap] :: VkMemoryHeap -> VkDeviceSize
-- | flags is a bitmask of VkMemoryHeapFlagBits specifying
-- attribute flags for the heap.
[$sel:vkFlags:VkMemoryHeap] :: VkMemoryHeap -> VkMemoryHeapFlags
-- | VkFormatProperties - Structure specifying image format properties
--
-- Description
--
-- Note
--
-- If no format feature flags are supported, the format itself is not
-- supported, and images of that format cannot be created.
--
-- If format is a block-compression format, then buffers
-- must not support any features for the format.
--
-- See Also
--
-- VkFormatFeatureFlags, VkFormatProperties2,
-- vkGetPhysicalDeviceFormatProperties
data VkFormatProperties
VkFormatProperties :: VkFormatFeatureFlags -> VkFormatFeatureFlags -> VkFormatFeatureFlags -> VkFormatProperties
-- | linearTilingFeatures is a bitmask of
-- VkFormatFeatureFlagBits specifying features supported by images
-- created with a tiling parameter of
-- VK_IMAGE_TILING_LINEAR.
[$sel:vkLinearTilingFeatures:VkFormatProperties] :: VkFormatProperties -> VkFormatFeatureFlags
-- | optimalTilingFeatures is a bitmask of
-- VkFormatFeatureFlagBits specifying features supported by images
-- created with a tiling parameter of
-- VK_IMAGE_TILING_OPTIMAL.
[$sel:vkOptimalTilingFeatures:VkFormatProperties] :: VkFormatProperties -> VkFormatFeatureFlags
-- | bufferFeatures is a bitmask of VkFormatFeatureFlagBits
-- specifying features supported by buffers.
[$sel:vkBufferFeatures:VkFormatProperties] :: VkFormatProperties -> VkFormatFeatureFlags
-- | VkImageFormatProperties - Structure specifying a image format
-- properties
--
-- Members
--
--
-- - maxExtent are the maximum image dimensions. See the
-- Allowed Extent Values section below for how these values are
-- constrained by type.
--
--
--
-- - maxMipLevels is the maximum number of mipmap levels.
-- maxMipLevels must be equal to
-- ⌈log2(max(width, height, depth))⌉ + 1,
-- where width, height, and depth are taken
-- from the corresponding members of maxExtent, except when one
-- of the following conditions is true, in which case it may
-- instead be
-- 1:
-- - maxArrayLayers is the maximum number of array layers.
-- maxArrayLayers must either be equal to 1 or be greater
-- than or equal to the maxImageArrayLayers member of
-- VkPhysicalDeviceLimits. A value of 1 is valid only if
-- tiling is VK_IMAGE_TILING_LINEAR or if type
-- is VK_IMAGE_TYPE_3D.
-- - sampleCounts is a bitmask of VkSampleCountFlagBits
-- specifying all the supported sample counts for this image as described
-- below.
-- - maxResourceSize is an upper bound on the total image size
-- in bytes, inclusive of all image subresources. Implementations
-- may have an address space limit on total size of a resource,
-- which is advertised by this property. maxResourceSize
-- must be at least 231.
--
--
-- Description
--
-- Note
--
-- There is no mechanism to query the size of an image before creating
-- it, to compare that size against maxResourceSize. If an
-- application attempts to create an image that exceeds this limit, the
-- creation will fail and vkCreateImage will return
-- VK_ERROR_OUT_OF_DEVICE_MEMORY. While the advertised limit
-- must be at least 231, it may not be possible to create
-- an image that approaches that size, particularly for
-- VK_IMAGE_TYPE_1D.
--
-- If the combination of parameters to
-- vkGetPhysicalDeviceImageFormatProperties is not supported by
-- the implementation for use in vkCreateImage, then all members
-- of VkImageFormatProperties will be filled with zero.
--
-- Note
--
-- Filling VkImageFormatProperties with zero for unsupported
-- formats is an exception to the usual rule that output structures have
-- undefined contents on error. This exception was unintentional, but is
-- preserved for backwards compatibility.
--
-- See Also
--
-- VkDeviceSize, VkExtent3D,
-- VkExternalImageFormatPropertiesNV,
-- VkImageFormatProperties2, VkSampleCountFlags,
-- vkGetPhysicalDeviceImageFormatProperties
data VkImageFormatProperties
VkImageFormatProperties :: VkExtent3D -> Word32 -> Word32 -> VkSampleCountFlags -> VkDeviceSize -> VkImageFormatProperties
[$sel:vkMaxExtent:VkImageFormatProperties] :: VkImageFormatProperties -> VkExtent3D
[$sel:vkMaxMipLevels:VkImageFormatProperties] :: VkImageFormatProperties -> Word32
[$sel:vkMaxArrayLayers:VkImageFormatProperties] :: VkImageFormatProperties -> Word32
[$sel:vkSampleCounts:VkImageFormatProperties] :: VkImageFormatProperties -> VkSampleCountFlags
[$sel:vkMaxResourceSize:VkImageFormatProperties] :: VkImageFormatProperties -> VkDeviceSize
-- | VkPhysicalDeviceFeatures - Structure describing the fine-grained
-- features that can be supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceFeatures structure
-- describe the following features:
--
-- Description
--
--
-- - robustBufferAccess specifies that accesses to buffers are
-- bounds-checked against the range of the buffer descriptor (as
-- determined by VkDescriptorBufferInfo::range,
-- VkBufferViewCreateInfo::range, or the size of the
-- buffer). Out of bounds accesses must not cause application
-- termination, and the effects of shader loads, stores, and atomics
-- must conform to an implementation-dependent behavior as
-- described below.
- A buffer access is considered to be out of
-- bounds if any of the following are true:
- The pointer was formed
-- by OpImageTexelPointer and the coordinate is less than zero
-- or greater than or equal to the number of whole elements in the bound
-- range.
- The pointer was not formed by
-- OpImageTexelPointer and the object pointed to is not wholly
-- contained within the bound range. This includes accesses performed via
-- /variable pointers/ where the buffer descriptor being accessed cannot
-- be statically determined. Uninitialized pointers and pointers equal to
-- OpConstantNull are treated as pointing to a zero-sized
-- object, so all accesses through such pointers are considered to be out
-- of bounds.NoteIf a SPIR-V OpLoad instruction loads a
-- structure and the tail end of the structure is out of bounds, then all
-- members of the structure are considered out of bounds even if the
-- members at the end are not statically used.
- If any buffer
-- access in a given SPIR-V block is determined to be out of bounds, then
-- any other access of the same type (load, store, or atomic) in the same
-- SPIR-V block that accesses an address less than 16 bytes away from the
-- out of bounds address may also be considered out of
-- bounds.
- Out-of-bounds buffer loads will return any
-- of the following values:
- Values from anywhere within the memory
-- range(s) bound to the buffer (possibly including bytes of memory past
-- the end of the buffer, up to the end of the bound range).
- Zero
-- values, or (0,0,0,x) vectors for vector reads where x is a valid value
-- represented in the type of the vector components and may be any
-- of:
- 0, 1, or the maximum representable positive integer value,
-- for signed or unsigned integer components
- 0.0 or 1.0, for
-- floating-point components
- Out-of-bounds
-- writes may modify values within the memory range(s) bound to
-- the buffer, but must not modify any other
-- memory.
- Out-of-bounds atomics may modify values within
-- the memory range(s) bound to the buffer, but must not modify
-- any other memory, and return an undefined value.
- Vertex input
-- attributes are considered out of bounds if the offset of the attribute
-- in the bound vertex buffer range plus the size of the attribute is
-- greater than either:
- vertexBufferRangeSize, if
-- bindingStride == 0;
-- or
- (vertexBufferRangeSize -
-- (vertexBufferRangeSize %
-- bindingStride))
where vertexBufferRangeSize
-- is the byte size of the memory range bound to the vertex buffer
-- binding and bindingStride is the byte stride of the
-- corresponding vertex input binding. Further, if any vertex input
-- attribute using a specific vertex input binding is out of bounds, then
-- all vertex input attributes using that vertex input binding for that
-- vertex shader invocation are considered out of bounds.- If a
-- vertex input attribute is out of bounds, it will be assigned one of
-- the following values:
- Values from anywhere within the memory
-- range(s) bound to the buffer, converted according to the format of the
-- attribute.
- Zero values, format converted according to the
-- format of the attribute.
- Zero values, or (0,0,0,x) vectors, as
-- described above.
- If
-- robustBufferAccess is not enabled, out of bounds accesses
-- may corrupt any memory within the process and cause undefined
-- behavior up to and including application termination.
--
--
--
-- - fullDrawIndexUint32 specifies the full 32-bit range of
-- indices is supported for indexed draw calls when using a
-- VkIndexType of VK_INDEX_TYPE_UINT32.
-- maxDrawIndexedIndexValue is the maximum index value that
-- may be used (aside from the primitive restart index, which is
-- always 232-1 when the VkIndexType is
-- VK_INDEX_TYPE_UINT32). If this feature is supported,
-- maxDrawIndexedIndexValue must be 232-1; otherwise it
-- must be no smaller than 224-1. See
-- maxDrawIndexedIndexValue.
-- - imageCubeArray specifies whether image views with a
-- VkImageViewType of VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- can be created, and that the corresponding
-- SampledCubeArray and ImageCubeArray SPIR-V
-- capabilities can be used in shader code.
-- - independentBlend specifies whether the
-- VkPipelineColorBlendAttachmentState settings are controlled
-- independently per-attachment. If this feature is not enabled, the
-- VkPipelineColorBlendAttachmentState settings for all color
-- attachments must be identical. Otherwise, a different
-- VkPipelineColorBlendAttachmentState can be provided
-- for each bound color attachment.
-- - geometryShader specifies whether geometry shaders are
-- supported. If this feature is not enabled, the
-- VK_SHADER_STAGE_GEOMETRY_BIT and
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT enum values must
-- not be used. This also specifies whether shader modules can
-- declare the Geometry capability.
-- - tessellationShader specifies whether tessellation control
-- and evaluation shaders are supported. If this feature is not enabled,
-- the VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT,
-- VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT,
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT,
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT, and
-- VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO
-- enum values must not be used. This also specifies whether
-- shader modules can declare the Tessellation
-- capability.
-- - sampleRateShading specifies whether Sample Shading
-- and multisample interpolation are supported. If this feature is not
-- enabled, the sampleShadingEnable member of the
-- VkPipelineMultisampleStateCreateInfo structure must be
-- set to VK_FALSE and the minSampleShading member is
-- ignored. This also specifies whether shader modules can declare
-- the SampleRateShading capability.
-- - dualSrcBlend specifies whether blend operations which
-- take two sources are supported. If this feature is not enabled, the
-- VK_BLEND_FACTOR_SRC1_COLOR,
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,
-- VK_BLEND_FACTOR_SRC1_ALPHA, and
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA enum values must
-- not be used as source or destination blending factors. See
-- {html_spec_relative}#framebuffer-dsb.
-- - logicOp specifies whether logic operations are supported.
-- If this feature is not enabled, the logicOpEnable member of
-- the VkPipelineColorBlendStateCreateInfo structure must
-- be set to VK_FALSE, and the logicOp member is
-- ignored.
-- - multiDrawIndirect specifies whether multiple draw
-- indirect is supported. If this feature is not enabled, the
-- drawCount parameter to the vkCmdDrawIndirect and
-- vkCmdDrawIndexedIndirect commands must be 0 or 1. The
-- maxDrawIndirectCount member of the
-- VkPhysicalDeviceLimits structure must also be 1 if
-- this feature is not supported. See maxDrawIndirectCount.
-- - drawIndirectFirstInstance specifies whether indirect draw
-- calls support the firstInstance parameter. If this feature is
-- not enabled, the firstInstance member of all
-- VkDrawIndirectCommand and
-- VkDrawIndexedIndirectCommand structures that are provided to
-- the vkCmdDrawIndirect and vkCmdDrawIndexedIndirect
-- commands must be 0.
-- - depthClamp specifies whether depth clamping is supported.
-- If this feature is not enabled, the depthClampEnable member
-- of the VkPipelineRasterizationStateCreateInfo structure
-- must be set to VK_FALSE. Otherwise, setting
-- depthClampEnable to VK_TRUE will enable depth
-- clamping.
-- - depthBiasClamp specifies whether depth bias clamping is
-- supported. If this feature is not enabled, the depthBiasClamp
-- member of the VkPipelineRasterizationStateCreateInfo
-- structure must be set to 0.0 unless the
-- VK_DYNAMIC_STATE_DEPTH_BIAS dynamic state is enabled, and the
-- depthBiasClamp parameter to vkCmdSetDepthBias
-- must be set to 0.0.
-- - fillModeNonSolid specifies whether point and wireframe
-- fill modes are supported. If this feature is not enabled, the
-- VK_POLYGON_MODE_POINT and VK_POLYGON_MODE_LINE enum
-- values must not be used.
-- - depthBounds specifies whether depth bounds tests are
-- supported. If this feature is not enabled, the
-- depthBoundsTestEnable member of the
-- VkPipelineDepthStencilStateCreateInfo structure must
-- be set to VK_FALSE. When depthBoundsTestEnable is
-- set to VK_FALSE, the minDepthBounds and
-- maxDepthBounds members of the
-- VkPipelineDepthStencilStateCreateInfo structure are
-- ignored.
-- - wideLines specifies whether lines with width other than
-- 1.0 are supported. If this feature is not enabled, the
-- lineWidth member of the
-- VkPipelineRasterizationStateCreateInfo structure must
-- be set to 1.0 unless the VK_DYNAMIC_STATE_LINE_WIDTH dynamic
-- state is enabled, and the lineWidth parameter to
-- vkCmdSetLineWidth must be set to 1.0. When this
-- feature is supported, the range and granularity of supported line
-- widths are indicated by the lineWidthRange and
-- lineWidthGranularity members of the
-- VkPhysicalDeviceLimits structure, respectively.
-- - largePoints specifies whether points with size greater
-- than 1.0 are supported. If this feature is not enabled, only a point
-- size of 1.0 written by a shader is supported. The range and
-- granularity of supported point sizes are indicated by the
-- pointSizeRange and pointSizeGranularity members of
-- the VkPhysicalDeviceLimits structure, respectively.
-- - alphaToOne specifies whether the implementation is able
-- to replace the alpha value of the color fragment output from the
-- fragment shader with the maximum representable alpha value for
-- fixed-point colors or 1.0 for floating-point colors. If this feature
-- is not enabled, then the alphaToOneEnable member of the
-- VkPipelineMultisampleStateCreateInfo structure must be
-- set to VK_FALSE. Otherwise setting alphaToOneEnable
-- to VK_TRUE will enable alpha-to-one behavior.
-- - multiViewport specifies whether more than one viewport is
-- supported. If this feature is not enabled, the viewportCount
-- and scissorCount members of the
-- VkPipelineViewportStateCreateInfo structure must be
-- set to 1. Similarly, the viewportCount parameter to the
-- vkCmdSetViewport command and the scissorCount
-- parameter to the vkCmdSetScissor command must be 1,
-- and the firstViewport parameter to the
-- vkCmdSetViewport command and the firstScissor
-- parameter to the vkCmdSetScissor command must be
-- 0.
-- - samplerAnisotropy specifies whether anisotropic filtering
-- is supported. If this feature is not enabled, the
-- anisotropyEnable member of the VkSamplerCreateInfo
-- structure must be VK_FALSE.
-- - textureCompressionETC2 specifies whether all of the ETC2
-- and EAC compressed texture formats are supported. If this feature is
-- enabled, then the VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT,
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT and
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT features
-- must be supported in optimalTilingFeatures for the
-- following
-- formats:
VK_FORMAT_ETC2_R8G8B8_UNORM_BLOCK
VK_FORMAT_ETC2_R8G8B8_SRGB_BLOCK
VK_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK
VK_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK
VK_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK
VK_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK
VK_FORMAT_EAC_R11_UNORM_BLOCK
VK_FORMAT_EAC_R11_SNORM_BLOCK
VK_FORMAT_EAC_R11G11_UNORM_BLOCK
VK_FORMAT_EAC_R11G11_SNORM_BLOCK
vkGetPhysicalDeviceFormatProperties
-- and vkGetPhysicalDeviceImageFormatProperties can be used
-- to check for additional supported properties of individual
-- formats.
-- - textureCompressionASTC_LDR specifies whether all of the
-- ASTC LDR compressed texture formats are supported. If this feature is
-- enabled, then the VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT,
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT and
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT features
-- must be supported in optimalTilingFeatures for the
-- following
-- formats:
VK_FORMAT_ASTC_4x4_UNORM_BLOCK
VK_FORMAT_ASTC_4x4_SRGB_BLOCK
VK_FORMAT_ASTC_5x4_UNORM_BLOCK
VK_FORMAT_ASTC_5x4_SRGB_BLOCK
VK_FORMAT_ASTC_5x5_UNORM_BLOCK
VK_FORMAT_ASTC_5x5_SRGB_BLOCK
VK_FORMAT_ASTC_6x5_UNORM_BLOCK
VK_FORMAT_ASTC_6x5_SRGB_BLOCK
VK_FORMAT_ASTC_6x6_UNORM_BLOCK
VK_FORMAT_ASTC_6x6_SRGB_BLOCK
VK_FORMAT_ASTC_8x5_UNORM_BLOCK
VK_FORMAT_ASTC_8x5_SRGB_BLOCK
VK_FORMAT_ASTC_8x6_UNORM_BLOCK
VK_FORMAT_ASTC_8x6_SRGB_BLOCK
VK_FORMAT_ASTC_8x8_UNORM_BLOCK
VK_FORMAT_ASTC_8x8_SRGB_BLOCK
VK_FORMAT_ASTC_10x5_UNORM_BLOCK
VK_FORMAT_ASTC_10x5_SRGB_BLOCK
VK_FORMAT_ASTC_10x6_UNORM_BLOCK
VK_FORMAT_ASTC_10x6_SRGB_BLOCK
VK_FORMAT_ASTC_10x8_UNORM_BLOCK
VK_FORMAT_ASTC_10x8_SRGB_BLOCK
VK_FORMAT_ASTC_10x10_UNORM_BLOCK
VK_FORMAT_ASTC_10x10_SRGB_BLOCK
VK_FORMAT_ASTC_12x10_UNORM_BLOCK
VK_FORMAT_ASTC_12x10_SRGB_BLOCK
VK_FORMAT_ASTC_12x12_UNORM_BLOCK
VK_FORMAT_ASTC_12x12_SRGB_BLOCK
vkGetPhysicalDeviceFormatProperties
-- and vkGetPhysicalDeviceImageFormatProperties can be used
-- to check for additional supported properties of individual
-- formats.
-- - textureCompressionBC specifies whether all of the BC
-- compressed texture formats are supported. If this feature is enabled,
-- then the VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT,
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT and
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT features
-- must be supported in optimalTilingFeatures for the
-- following
-- formats:
VK_FORMAT_BC1_RGB_UNORM_BLOCK
VK_FORMAT_BC1_RGB_SRGB_BLOCK
VK_FORMAT_BC1_RGBA_UNORM_BLOCK
VK_FORMAT_BC1_RGBA_SRGB_BLOCK
VK_FORMAT_BC2_UNORM_BLOCK
VK_FORMAT_BC2_SRGB_BLOCK
VK_FORMAT_BC3_UNORM_BLOCK
VK_FORMAT_BC3_SRGB_BLOCK
VK_FORMAT_BC4_UNORM_BLOCK
VK_FORMAT_BC4_SNORM_BLOCK
VK_FORMAT_BC5_UNORM_BLOCK
VK_FORMAT_BC5_SNORM_BLOCK
VK_FORMAT_BC6H_UFLOAT_BLOCK
VK_FORMAT_BC6H_SFLOAT_BLOCK
VK_FORMAT_BC7_UNORM_BLOCK
VK_FORMAT_BC7_SRGB_BLOCK
vkGetPhysicalDeviceFormatProperties
-- and vkGetPhysicalDeviceImageFormatProperties can be used
-- to check for additional supported properties of individual
-- formats.
-- - occlusionQueryPrecise specifies whether occlusion queries
-- returning actual sample counts are supported. Occlusion queries are
-- created in a VkQueryPool by specifying the queryType
-- of VK_QUERY_TYPE_OCCLUSION in the
-- VkQueryPoolCreateInfo structure which is passed to
-- vkCreateQueryPool. If this feature is enabled, queries of
-- this type can enable VK_QUERY_CONTROL_PRECISE_BIT in
-- the flags parameter to vkCmdBeginQuery. If this
-- feature is not supported, the implementation supports only boolean
-- occlusion queries. When any samples are passed, boolean queries will
-- return a non-zero result value, otherwise a result value of zero is
-- returned. When this feature is enabled and
-- VK_QUERY_CONTROL_PRECISE_BIT is set, occlusion queries will
-- report the actual number of samples passed.
-- - pipelineStatisticsQuery specifies whether the pipeline
-- statistics queries are supported. If this feature is not enabled,
-- queries of type VK_QUERY_TYPE_PIPELINE_STATISTICS
-- cannot be created, and none of the
-- VkQueryPipelineStatisticFlagBits bits can be set in the
-- pipelineStatistics member of the
-- VkQueryPoolCreateInfo structure.
-- - vertexPipelineStoresAndAtomics specifies whether storage
-- buffers and images support stores and atomic operations in the vertex,
-- tessellation, and geometry shader stages. If this feature is not
-- enabled, all storage image, storage texel buffers, and storage buffer
-- variables used by these stages in shader modules must be
-- decorated with the NonWriteable decoration (or the
-- readonly memory qualifier in GLSL).
-- - fragmentStoresAndAtomics specifies whether storage
-- buffers and images support stores and atomic operations in the
-- fragment shader stage. If this feature is not enabled, all storage
-- image, storage texel buffers, and storage buffer variables used by the
-- fragment stage in shader modules must be decorated with the
-- NonWriteable decoration (or the readonly memory
-- qualifier in GLSL).
-- - shaderTessellationAndGeometryPointSize specifies whether
-- the PointSize built-in decoration is available in the
-- tessellation control, tessellation evaluation, and geometry shader
-- stages. If this feature is not enabled, members decorated with the
-- PointSize built-in decoration must not be read from or
-- written to and all points written from a tessellation or geometry
-- shader will have a size of 1.0. This also specifies whether shader
-- modules can declare the TessellationPointSize
-- capability for tessellation control and evaluation shaders, or if the
-- shader modules can declare the GeometryPointSize
-- capability for geometry shaders. An implementation supporting this
-- feature must also support one or both of the
-- tessellationShader or geometryShader features.
-- - shaderImageGatherExtended specifies whether the extended
-- set of image gather instructions are available in shader code. If this
-- feature is not enabled, the OpImage*Gather
-- instructions do not support the Offset and
-- ConstOffsets operands. This also specifies whether shader
-- modules can declare the ImageGatherExtended
-- capability.
-- - shaderStorageImageExtendedFormats specifies whether the
-- extended storage image formats are available in shader code. If this
-- feature is not enabled, the formats requiring the
-- StorageImageExtendedFormats capability are not supported for
-- storage images. This also specifies whether shader modules can
-- declare the StorageImageExtendedFormats capability.
-- - shaderStorageImageMultisample specifies whether
-- multisampled storage images are supported. If this feature is not
-- enabled, images that are created with a usage that includes
-- VK_IMAGE_USAGE_STORAGE_BIT must be created with
-- samples equal to VK_SAMPLE_COUNT_1_BIT. This also
-- specifies whether shader modules can declare the
-- StorageImageMultisample capability.
-- - shaderStorageImageReadWithoutFormat specifies whether
-- storage images require a format qualifier to be specified when reading
-- from storage images. If this feature is not enabled, the
-- OpImageRead instruction must not have an
-- OpTypeImage of Unknown. This also specifies whether
-- shader modules can declare the
-- StorageImageReadWithoutFormat capability.
-- - shaderStorageImageWriteWithoutFormat specifies whether
-- storage images require a format qualifier to be specified when writing
-- to storage images. If this feature is not enabled, the
-- OpImageWrite instruction must not have an
-- OpTypeImage of Unknown. This also specifies whether
-- shader modules can declare the
-- StorageImageWriteWithoutFormat capability.
-- - shaderUniformBufferArrayDynamicIndexing specifies whether
-- arrays of uniform buffers can be indexed by dynamically
-- uniform integer expressions in shader code. If this feature is not
-- enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC must be
-- indexed only by constant integral expressions when aggregated into
-- arrays in shader code. This also specifies whether shader modules
-- can declare the UniformBufferArrayDynamicIndexing
-- capability.
-- - shaderSampledImageArrayDynamicIndexing specifies whether
-- arrays of samplers or sampled images can be indexed by
-- dynamically uniform integer expressions in shader code. If this
-- feature is not enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, or
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE must be indexed only
-- by constant integral expressions when aggregated into arrays in shader
-- code. This also specifies whether shader modules can declare
-- the SampledImageArrayDynamicIndexing capability.
-- - shaderStorageBufferArrayDynamicIndexing specifies whether
-- arrays of storage buffers can be indexed by dynamically uniform
-- integer expressions in shader code. If this feature is not enabled,
-- resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC must be
-- indexed only by constant integral expressions when aggregated into
-- arrays in shader code. This also specifies whether shader modules
-- can declare the StorageBufferArrayDynamicIndexing
-- capability.
-- - shaderStorageImageArrayDynamicIndexing specifies whether
-- arrays of storage images can be indexed by dynamically uniform
-- integer expressions in shader code. If this feature is not enabled,
-- resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE must be indexed only
-- by constant integral expressions when aggregated into arrays in shader
-- code. This also specifies whether shader modules can declare
-- the StorageImageArrayDynamicIndexing capability.
-- - shaderClipDistance specifies whether clip distances are
-- supported in shader code. If this feature is not enabled, any members
-- decorated with the ClipDistance built-in decoration
-- must not be read from or written to in shader modules. This
-- also specifies whether shader modules can declare the
-- ClipDistance capability.
-- - shaderCullDistance specifies whether cull distances are
-- supported in shader code. If this feature is not enabled, any members
-- decorated with the CullDistance built-in decoration
-- must not be read from or written to in shader modules. This
-- also specifies whether shader modules can declare the
-- CullDistance capability.
-- - shaderFloat64 specifies whether 64-bit floats (doubles)
-- are supported in shader code. If this feature is not enabled, 64-bit
-- floating-point types must not be used in shader code. This also
-- specifies whether shader modules can declare the
-- Float64 capability.
-- - shaderInt64 specifies whether 64-bit integers (signed and
-- unsigned) are supported in shader code. If this feature is not
-- enabled, 64-bit integer types must not be used in shader code.
-- This also specifies whether shader modules can declare the
-- Int64 capability.
-- - shaderInt16 specifies whether 16-bit integers (signed and
-- unsigned) are supported in shader code. If this feature is not
-- enabled, 16-bit integer types must not be used in shader code.
-- This also specifies whether shader modules can declare the
-- Int16 capability.
-- - shaderResourceResidency specifies whether image
-- operations that return resource residency information are supported in
-- shader code. If this feature is not enabled, the
-- OpImageSparse* instructions must not be used in shader
-- code. This also specifies whether shader modules can declare
-- the SparseResidency capability. The feature requires at least
-- one of the sparseResidency* features to be supported.
-- - shaderResourceMinLod specifies whether image operations
-- that specify the minimum resource LOD are supported in shader code. If
-- this feature is not enabled, the MinLod image operand
-- must not be used in shader code. This also specifies whether
-- shader modules can declare the MinLod capability.
-- - sparseBinding specifies whether resource memory
-- can be managed at opaque sparse block level instead of at the
-- object level. If this feature is not enabled, resource memory
-- must be bound only on a per-object basis using the
-- vkBindBufferMemory and vkBindImageMemory commands.
-- In this case, buffers and images must not be created with
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT and
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT set in the flags
-- member of the VkBufferCreateInfo and
-- VkImageCreateInfo structures, respectively. Otherwise
-- resource memory can be managed as described in Sparse
-- Resource Features.
-- - sparseResidencyBuffer specifies whether the device
-- can access partially resident buffers. If this feature is not
-- enabled, buffers must not be created with
-- VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkBufferCreateInfo
-- structure.
-- - sparseResidencyImage2D specifies whether the device
-- can access partially resident 2D images with 1 sample per
-- pixel. If this feature is not enabled, images with an
-- imageType of VK_IMAGE_TYPE_2D and samples
-- set to VK_SAMPLE_COUNT_1_BIT must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidencyImage3D specifies whether the device
-- can access partially resident 3D images. If this feature is not
-- enabled, images with an imageType of
-- VK_IMAGE_TYPE_3D must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidency2Samples specifies whether the physical
-- device can access partially resident 2D images with 2 samples
-- per pixel. If this feature is not enabled, images with an
-- imageType of VK_IMAGE_TYPE_2D and samples
-- set to VK_SAMPLE_COUNT_2_BIT must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidency4Samples specifies whether the physical
-- device can access partially resident 2D images with 4 samples
-- per pixel. If this feature is not enabled, images with an
-- imageType of VK_IMAGE_TYPE_2D and samples
-- set to VK_SAMPLE_COUNT_4_BIT must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidency8Samples specifies whether the physical
-- device can access partially resident 2D images with 8 samples
-- per pixel. If this feature is not enabled, images with an
-- imageType of VK_IMAGE_TYPE_2D and samples
-- set to VK_SAMPLE_COUNT_8_BIT must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidency16Samples specifies whether the physical
-- device can access partially resident 2D images with 16 samples
-- per pixel. If this feature is not enabled, images with an
-- imageType of VK_IMAGE_TYPE_2D and samples
-- set to VK_SAMPLE_COUNT_16_BIT must not be created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT set in the
-- flags member of the VkImageCreateInfo
-- structure.
-- - sparseResidencyAliased specifies whether the physical
-- device can correctly access data aliased into multiple
-- locations. If this feature is not enabled, the
-- VK_BUFFER_CREATE_SPARSE_ALIASED_BIT and
-- VK_IMAGE_CREATE_SPARSE_ALIASED_BIT enum values must
-- not be used in flags members of the
-- VkBufferCreateInfo and VkImageCreateInfo structures,
-- respectively.
-- - variableMultisampleRate specifies whether all pipelines
-- that will be bound to a command buffer during a subpass with no
-- attachments must have the same value for
-- VkPipelineMultisampleStateCreateInfo::rasterizationSamples.
-- If set to VK_TRUE, the implementation supports variable
-- multisample rates in a subpass with no attachments. If set to
-- VK_FALSE, then all pipelines bound in such a subpass
-- must have the same multisample rate. This has no effect in
-- situations where a subpass uses any attachments.
-- - inheritedQueries specifies whether a secondary command
-- buffer may be executed while a query is active.
--
--
-- See Also
--
-- VkBool32, VkDeviceCreateInfo,
-- VkPhysicalDeviceFeatures2, vkGetPhysicalDeviceFeatures
data VkPhysicalDeviceFeatures
VkPhysicalDeviceFeatures :: VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceFeatures
[$sel:vkRobustBufferAccess:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkFullDrawIndexUint32:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkImageCubeArray:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkIndependentBlend:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkGeometryShader:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkTessellationShader:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSampleRateShading:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkDualSrcBlend:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkLogicOp:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkMultiDrawIndirect:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkDrawIndirectFirstInstance:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkDepthClamp:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkDepthBiasClamp:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkFillModeNonSolid:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkDepthBounds:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkWideLines:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkLargePoints:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkAlphaToOne:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkMultiViewport:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSamplerAnisotropy:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkTextureCompressionETC2:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkTextureCompressionASTC_LDR:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkTextureCompressionBC:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkOcclusionQueryPrecise:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkPipelineStatisticsQuery:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkVertexPipelineStoresAndAtomics:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkFragmentStoresAndAtomics:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderTessellationAndGeometryPointSize:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderImageGatherExtended:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageImageExtendedFormats:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageImageMultisample:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageImageReadWithoutFormat:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageImageWriteWithoutFormat:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderUniformBufferArrayDynamicIndexing:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderSampledImageArrayDynamicIndexing:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageBufferArrayDynamicIndexing:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderStorageImageArrayDynamicIndexing:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderClipDistance:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderCullDistance:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderFloat64:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderInt64:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderInt16:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderResourceResidency:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkShaderResourceMinLod:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseBinding:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidencyBuffer:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidencyImage2D:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidencyImage3D:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidency2Samples:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidency4Samples:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidency8Samples:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidency16Samples:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkSparseResidencyAliased:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkVariableMultisampleRate:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
[$sel:vkInheritedQueries:VkPhysicalDeviceFeatures] :: VkPhysicalDeviceFeatures -> VkBool32
-- | VkPhysicalDeviceSparseProperties - Structure specifying physical
-- device sparse memory properties
--
-- Description
--
-- See Also
--
-- VkBool32, VkPhysicalDeviceProperties
data VkPhysicalDeviceSparseProperties
VkPhysicalDeviceSparseProperties :: VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceSparseProperties
-- | residencyStandard2DBlockShape is VK_TRUE if the
-- physical device will access all single-sample 2D sparse resources
-- using the standard sparse image block shapes (based on image format),
-- as described in the Standard Sparse Image Block Shapes (Single
-- Sample) table. If this property is not supported the value
-- returned in the imageGranularity member of the
-- VkSparseImageFormatProperties structure for single-sample 2D
-- images is not required to match the standard sparse image block
-- dimensions listed in the table.
[$sel:vkResidencyStandard2DBlockShape:VkPhysicalDeviceSparseProperties] :: VkPhysicalDeviceSparseProperties -> VkBool32
-- | residencyStandard2DMultisampleBlockShape is VK_TRUE
-- if the physical device will access all multisample 2D sparse resources
-- using the standard sparse image block shapes (based on image format),
-- as described in the Standard Sparse Image Block Shapes (MSAA)
-- table. If this property is not supported, the value returned in the
-- imageGranularity member of the
-- VkSparseImageFormatProperties structure for multisample 2D
-- images is not required to match the standard sparse image block
-- dimensions listed in the table.
[$sel:vkResidencyStandard2DMultisampleBlockShape:VkPhysicalDeviceSparseProperties] :: VkPhysicalDeviceSparseProperties -> VkBool32
-- | residencyStandard3DBlockShape is VK_TRUE if the
-- physical device will access all 3D sparse resources using the standard
-- sparse image block shapes (based on image format), as described in the
-- Standard Sparse Image Block Shapes (Single Sample) table. If
-- this property is not supported, the value returned in the
-- imageGranularity member of the
-- VkSparseImageFormatProperties structure for 3D images is not
-- required to match the standard sparse image block dimensions
-- listed in the table.
[$sel:vkResidencyStandard3DBlockShape:VkPhysicalDeviceSparseProperties] :: VkPhysicalDeviceSparseProperties -> VkBool32
-- | residencyAlignedMipSize is VK_TRUE if images with
-- mip level dimensions that are not integer multiples of the
-- corresponding dimensions of the sparse image block may be
-- placed in the mip tail. If this property is not reported, only mip
-- levels with dimensions smaller than the imageGranularity
-- member of the VkSparseImageFormatProperties structure will be
-- placed in the mip tail. If this property is reported the
-- implementation is allowed to return
-- VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT in the
-- flags member of VkSparseImageFormatProperties,
-- indicating that mip level dimensions that are not integer multiples of
-- the corresponding dimensions of the sparse image block will be placed
-- in the mip tail.
[$sel:vkResidencyAlignedMipSize:VkPhysicalDeviceSparseProperties] :: VkPhysicalDeviceSparseProperties -> VkBool32
-- | residencyNonResidentStrict specifies whether the physical
-- device can consistently access non-resident regions of a
-- resource. If this property is VK_TRUE, access to non-resident
-- regions of resources will be guaranteed to return values as if the
-- resource were populated with 0; writes to non-resident regions will be
-- discarded.
[$sel:vkResidencyNonResidentStrict:VkPhysicalDeviceSparseProperties] :: VkPhysicalDeviceSparseProperties -> VkBool32
-- | VkPhysicalDeviceLimits - Structure reporting implementation-dependent
-- physical device limits
--
-- Members
--
--
-- - maxImageDimension1D is the maximum dimension
-- (width) supported for all images created with an
-- imageType of VK_IMAGE_TYPE_1D.
--
--
--
-- - maxImageDimension2D is the maximum dimension
-- (width or height) supported for all images created
-- with an imageType of VK_IMAGE_TYPE_2D and without
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT set in
-- flags.
-- - maxImageDimension3D is the maximum dimension
-- (width, height, or depth) supported for all
-- images created with an imageType of
-- VK_IMAGE_TYPE_3D.
-- - maxImageDimensionCube is the maximum dimension
-- (width or height) supported for all images created
-- with an imageType of VK_IMAGE_TYPE_2D and with
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT set in
-- flags.
-- - maxImageArrayLayers is the maximum number of layers
-- (arrayLayers) for an image.
-- - maxTexelBufferElements is the maximum number of
-- addressable texels for a buffer view created on a buffer which was
-- created with the VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT set in the
-- usage member of the VkBufferCreateInfo
-- structure.
-- - maxUniformBufferRange is the maximum value that
-- can be specified in the range member of any
-- VkDescriptorBufferInfo structures passed to a call to
-- vkUpdateDescriptorSets for descriptors of type
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC.
-- - maxStorageBufferRange is the maximum value that
-- can be specified in the range member of any
-- VkDescriptorBufferInfo structures passed to a call to
-- vkUpdateDescriptorSets for descriptors of type
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC.
-- - maxPushConstantsSize is the maximum size, in bytes, of
-- the pool of push constant memory. For each of the push constant ranges
-- indicated by the pPushConstantRanges member of the
-- VkPipelineLayoutCreateInfo structure, (offset +
-- size) must be less than or equal to this limit.
-- - maxMemoryAllocationCount is the maximum number of device
-- memory allocations, as created by vkAllocateMemory, which
-- can simultaneously exist.
-- - maxSamplerAllocationCount is the maximum number of
-- sampler objects, as created by vkCreateSampler, which
-- can simultaneously exist on a device.
-- - bufferImageGranularity is the granularity, in bytes, at
-- which buffer or linear image resources, and optimal image resources
-- can be bound to adjacent offsets in the same
-- VkDeviceMemory object without aliasing. See Buffer-Image
-- Granularity for more details.
-- - sparseAddressSpaceSize is the total amount of address
-- space available, in bytes, for sparse memory resources. This is an
-- upper bound on the sum of the size of all sparse resources, regardless
-- of whether any memory is bound to them.
-- - maxBoundDescriptorSets is the maximum number of
-- descriptor sets that can be simultaneously used by a pipeline.
-- All DescriptorSet decorations in shader modules must
-- have a value less than maxBoundDescriptorSets. See
-- {html_spec_relative}#descriptorsets-sets.
-- - maxPerStageDescriptorSamplers is the maximum number of
-- samplers that can be accessible to a single shader stage in a
-- pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_SAMPLER or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. See
-- {html_spec_relative}#descriptorsets-sampler and
-- {html_spec_relative}#descriptorsets-combinedimagesampler.
-- - maxPerStageDescriptorUniformBuffers is the maximum number
-- of uniform buffers that can be accessible to a single shader
-- stage in a pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. See
-- {html_spec_relative}#descriptorsets-uniformbuffer and
-- {html_spec_relative}#descriptorsets-uniformbufferdynamic.
-- - maxPerStageDescriptorStorageBuffers is the maximum number
-- of storage buffers that can be accessible to a single shader
-- stage in a pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- pipeline shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. See
-- {html_spec_relative}#descriptorsets-storagebuffer and
-- {html_spec_relative}#descriptorsets-storagebufferdynamic.
-- - maxPerStageDescriptorSampledImages is the maximum number
-- of sampled images that can be accessible to a single shader
-- stage in a pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, or
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- pipeline shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. See
-- {html_spec_relative}#descriptorsets-combinedimagesampler,
-- {html_spec_relative}#descriptorsets-sampledimage, and
-- {html_spec_relative}#descriptorsets-uniformtexelbuffer.
-- - maxPerStageDescriptorStorageImages is the maximum number
-- of storage images that can be accessible to a single shader
-- stage in a pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- pipeline shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. See
-- {html_spec_relative}#descriptorsets-storageimage, and
-- {html_spec_relative}#descriptorsets-storagetexelbuffer.
-- - maxPerStageDescriptorInputAttachments is the maximum
-- number of input attachments that can be accessible to a single
-- shader stage in a pipeline layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT count against this limit.
-- Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. A descriptor is accessible to a
-- pipeline shader stage when the stageFlags member of the
-- VkDescriptorSetLayoutBinding structure has the bit for that
-- shader stage set. These are only supported for the fragment stage. See
-- {html_spec_relative}#descriptorsets-inputattachment.
-- - maxPerStageResources is the maximum number of resources
-- that can be accessible to a single shader stage in a pipeline
-- layout. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE,
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER,
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC,
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT count against this limit.
-- Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. For the fragment shader stage the
-- framebuffer color attachments also count against this limit.
-- - maxDescriptorSetSamplers is the maximum number of
-- samplers that can be included in descriptor bindings in a
-- pipeline layout across all pipeline shader stages and descriptor set
-- numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_SAMPLER or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-sampler and
-- {html_spec_relative}#descriptorsets-combinedimagesampler.
-- - maxDescriptorSetUniformBuffers is the maximum number of
-- uniform buffers that can be included in descriptor bindings in
-- a pipeline layout across all pipeline shader stages and descriptor set
-- numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-uniformbuffer and
-- {html_spec_relative}#descriptorsets-uniformbufferdynamic.
-- - maxDescriptorSetUniformBuffersDynamic is the maximum
-- number of dynamic uniform buffers that can be included in
-- descriptor bindings in a pipeline layout across all pipeline shader
-- stages and descriptor set numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-uniformbufferdynamic.
-- - maxDescriptorSetStorageBuffers is the maximum number of
-- storage buffers that can be included in descriptor bindings in
-- a pipeline layout across all pipeline shader stages and descriptor set
-- numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-storagebuffer and
-- {html_spec_relative}#descriptorsets-storagebufferdynamic.
-- - maxDescriptorSetStorageBuffersDynamic is the maximum
-- number of dynamic storage buffers that can be included in
-- descriptor bindings in a pipeline layout across all pipeline shader
-- stages and descriptor set numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-storagebufferdynamic.
-- - maxDescriptorSetSampledImages is the maximum number of
-- sampled images that can be included in descriptor bindings in a
-- pipeline layout across all pipeline shader stages and descriptor set
-- numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, or
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-combinedimagesampler,
-- {html_spec_relative}#descriptorsets-sampledimage, and
-- {html_spec_relative}#descriptorsets-uniformtexelbuffer.
-- - maxDescriptorSetStorageImages is the maximum number of
-- storage images that can be included in descriptor bindings in a
-- pipeline layout across all pipeline shader stages and descriptor set
-- numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER count against this
-- limit. Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-storageimage, and
-- {html_spec_relative}#descriptorsets-storagetexelbuffer.
-- - maxDescriptorSetInputAttachments is the maximum number of
-- input attachments that can be included in descriptor bindings
-- in a pipeline layout across all pipeline shader stages and descriptor
-- set numbers. Descriptors with a type of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT count against this limit.
-- Only descriptors in descriptor set layouts created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set count against this limit. See
-- {html_spec_relative}#descriptorsets-inputattachment.
-- - maxVertexInputAttributes is the maximum number of vertex
-- input attributes that can be specified for a graphics pipeline.
-- These are described in the array of
-- VkVertexInputAttributeDescription structures that are
-- provided at graphics pipeline creation time via the
-- pVertexAttributeDescriptions member of the
-- VkPipelineVertexInputStateCreateInfo structure. See
-- {html_spec_relative}#fxvertex-attrib and
-- {html_spec_relative}#fxvertex-input.
-- - maxVertexInputBindings is the maximum number of vertex
-- buffers that can be specified for providing vertex attributes
-- to a graphics pipeline. These are described in the array of
-- VkVertexInputBindingDescription structures that are provided
-- at graphics pipeline creation time via the
-- pVertexBindingDescriptions member of the
-- VkPipelineVertexInputStateCreateInfo structure. The
-- binding member of VkVertexInputBindingDescription
-- must be less than this limit. See
-- {html_spec_relative}#fxvertex-input.
-- - maxVertexInputAttributeOffset is the maximum vertex input
-- attribute offset that can be added to the vertex input binding
-- stride. The offset member of the
-- VkVertexInputAttributeDescription structure must be
-- less than or equal to this limit. See
-- {html_spec_relative}#fxvertex-input.
-- - maxVertexInputBindingStride is the maximum vertex input
-- binding stride that can be specified in a vertex input binding.
-- The stride member of the
-- VkVertexInputBindingDescription structure must be less
-- than or equal to this limit. See
-- {html_spec_relative}#fxvertex-input.
-- - maxVertexOutputComponents is the maximum number of
-- components of output variables which can be output by a vertex
-- shader. See {html_spec_relative}#shaders-vertex.
-- - maxTessellationGenerationLevel is the maximum
-- tessellation generation level supported by the fixed-function
-- tessellation primitive generator. See
-- {html_spec_relative}#tessellation.
-- - maxTessellationPatchSize is the maximum patch size, in
-- vertices, of patches that can be processed by the tessellation
-- control shader and tessellation primitive generator. The
-- patchControlPoints member of the
-- VkPipelineTessellationStateCreateInfo structure specified at
-- pipeline creation time and the value provided in the
-- OutputVertices execution mode of shader modules must
-- be less than or equal to this limit. See
-- {html_spec_relative}#tessellation.
-- - maxTessellationControlPerVertexInputComponents is the
-- maximum number of components of input variables which can be
-- provided as per-vertex inputs to the tessellation control shader
-- stage.
-- - maxTessellationControlPerVertexOutputComponents is the
-- maximum number of components of per-vertex output variables which
-- can be output from the tessellation control shader stage.
-- - maxTessellationControlPerPatchOutputComponents is the
-- maximum number of components of per-patch output variables which
-- can be output from the tessellation control shader stage.
-- - maxTessellationControlTotalOutputComponents is the
-- maximum total number of components of per-vertex and per-patch output
-- variables which can be output from the tessellation control
-- shader stage.
-- - maxTessellationEvaluationInputComponents is the maximum
-- number of components of input variables which can be provided
-- as per-vertex inputs to the tessellation evaluation shader stage.
-- - maxTessellationEvaluationOutputComponents is the maximum
-- number of components of per-vertex output variables which can
-- be output from the tessellation evaluation shader stage.
-- - maxGeometryShaderInvocations is the maximum invocation
-- count supported for instanced geometry shaders. The value provided in
-- the Invocations execution mode of shader modules must
-- be less than or equal to this limit. See
-- {html_spec_relative}#geometry.
-- - maxGeometryInputComponents is the maximum number of
-- components of input variables which can be provided as inputs
-- to the geometry shader stage.
-- - maxGeometryOutputComponents is the maximum number of
-- components of output variables which can be output from the
-- geometry shader stage.
-- - maxGeometryOutputVertices is the maximum number of
-- vertices which can be emitted by any geometry shader.
-- - maxGeometryTotalOutputComponents is the maximum total
-- number of components of output, across all emitted vertices, which
-- can be output from the geometry shader stage.
-- - maxFragmentInputComponents is the maximum number of
-- components of input variables which can be provided as inputs
-- to the fragment shader stage.
-- - maxFragmentOutputAttachments is the maximum number of
-- output attachments which can be written to by the fragment
-- shader stage.
-- - maxFragmentDualSrcAttachments is the maximum number of
-- output attachments which can be written to by the fragment
-- shader stage when blending is enabled and one of the dual source blend
-- modes is in use. See {html_spec_relative}#framebuffer-dsb and
-- dualSrcBlend.
-- - maxFragmentCombinedOutputResources is the total number of
-- storage buffers, storage images, and output buffers which can
-- be used in the fragment shader stage.
-- - maxComputeSharedMemorySize is the maximum total storage
-- size, in bytes, of all variables declared with the
-- WorkgroupLocal storage class in shader modules (or with the
-- shared storage qualifier in GLSL) in the compute shader
-- stage.
-- - maxComputeWorkGroupCount[3] is the maximum number of
-- local workgroups that can be dispatched by a single dispatch
-- command. These three values represent the maximum number of local
-- workgroups for the X, Y, and Z dimensions, respectively. The workgroup
-- count parameters to the dispatch commands must be less than or
-- equal to the corresponding limit. See
-- {html_spec_relative}#dispatch.
-- - maxComputeWorkGroupInvocations is the maximum total
-- number of compute shader invocations in a single local workgroup. The
-- product of the X, Y, and Z sizes as specified by the
-- LocalSize execution mode in shader modules and by the object
-- decorated by the WorkgroupSize decoration must be less
-- than or equal to this limit.
-- - maxComputeWorkGroupSize[3] is the maximum size of a local
-- compute workgroup, per dimension. These three values represent the
-- maximum local workgroup size in the X, Y, and Z dimensions,
-- respectively. The x, y, and z sizes
-- specified by the LocalSize execution mode and by the object
-- decorated by the WorkgroupSize decoration in shader modules
-- must be less than or equal to the corresponding limit.
-- - subPixelPrecisionBits is the number of bits of subpixel
-- precision in framebuffer coordinates xf and yf. See
-- {html_spec_relative}#primsrast.
-- - subTexelPrecisionBits is the number of bits of precision
-- in the division along an axis of an image used for minification and
-- magnification filters. 2subTexelPrecisionBits is the actual
-- number of divisions along each axis of the image represented.
-- Sub-texel values calculated during image sampling will snap to these
-- locations when generating the filtered results.
-- - mipmapPrecisionBits is the number of bits of division
-- that the LOD calculation for mipmap fetching get snapped to when
-- determining the contribution from each mip level to the mip filtered
-- results. 2mipmapPrecisionBits is the actual number of
-- divisions.NoteFor example, if this value is 2 bits then when
-- linearly filtering between two levels, each level could: contribute:
-- 0%, 33%, 66%, or 100% (this is just an example and the amount of
-- contribution should be covered by different equations in the
-- spec).
-- - maxDrawIndexedIndexValue is the maximum index value that
-- can be used for indexed draw calls when using 32-bit indices.
-- This excludes the primitive restart index value of 0xFFFFFFFF. See
-- fullDrawIndexUint32.
-- - maxDrawIndirectCount is the maximum draw count that is
-- supported for indirect draw calls. See multiDrawIndirect.
-- - maxSamplerLodBias is the maximum absolute sampler LOD
-- bias. The sum of the mipLodBias member of the
-- VkSamplerCreateInfo structure and the Bias operand
-- of image sampling operations in shader modules (or 0 if no
-- Bias operand is provided to an image sampling operation) are
-- clamped to the range
-- [-maxSamplerLodBias,+maxSamplerLodBias]. See
-- {html_spec_relative}#samplers-mipLodBias.
-- - maxSamplerAnisotropy is the maximum degree of sampler
-- anisotropy. The maximum degree of anisotropic filtering used for an
-- image sampling operation is the minimum of the maxAnisotropy
-- member of the VkSamplerCreateInfo structure and this limit.
-- See {html_spec_relative}#samplers-maxAnisotropy.
-- - maxViewports is the maximum number of active viewports.
-- The viewportCount member of the
-- VkPipelineViewportStateCreateInfo structure that is provided
-- at pipeline creation must be less than or equal to this
-- limit.
-- - maxViewportDimensions[2] are the maximum viewport
-- dimensions in the X (width) and Y (height) dimensions, respectively.
-- The maximum viewport dimensions must be greater than or equal
-- to the largest image which can be created and used as a
-- framebuffer attachment. See Controlling the Viewport.
-- - viewportBoundsRange[2] is the [minimum, maximum] range
-- that the corners of a viewport must be contained in. This range
-- must be at least [-2 × size, 2 × size - 1],
-- where size = max(maxViewportDimensions[0],
-- maxViewportDimensions[1]). See Controlling the
-- Viewport.NoteThe intent of the viewportBoundsRange
-- limit is to allow a maximum sized viewport to be arbitrarily shifted
-- relative to the output target as long as at least some portion
-- intersects. This would give a bounds limit of [-size + 1, 2 ×
-- size - 1] which would allow all possible non-empty-set
-- intersections of the output target and the viewport. Since these
-- numbers are typically powers of two, picking the signed number range
-- using the smallest possible number of bits ends up with the specified
-- range.
-- - viewportSubPixelBits is the number of bits of subpixel
-- precision for viewport bounds. The subpixel precision that
-- floating-point viewport bounds are interpreted at is given by this
-- limit.
-- - minMemoryMapAlignment is the minimum required
-- alignment, in bytes, of host visible memory allocations within the
-- host address space. When mapping a memory allocation with
-- vkMapMemory, subtracting offset bytes from the
-- returned pointer will always produce an integer multiple of this
-- limit. See {html_spec_relative}#memory-device-hostaccess.
-- - minTexelBufferOffsetAlignment is the minimum
-- required alignment, in bytes, for the offset member of
-- the VkBufferViewCreateInfo structure for texel buffers. When
-- a buffer view is created for a buffer which was created with
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT set in the
-- usage member of the VkBufferCreateInfo structure,
-- the offset must be an integer multiple of this
-- limit.
-- - minUniformBufferOffsetAlignment is the minimum
-- required alignment, in bytes, for the offset member of
-- the VkDescriptorBufferInfo structure for uniform buffers.
-- When a descriptor of type VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER
-- or VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC is updated, the
-- offset must be an integer multiple of this limit.
-- Similarly, dynamic offsets for uniform buffers must be
-- multiples of this limit.
-- - minStorageBufferOffsetAlignment is the minimum
-- required alignment, in bytes, for the offset member of
-- the VkDescriptorBufferInfo structure for storage buffers.
-- When a descriptor of type VK_DESCRIPTOR_TYPE_STORAGE_BUFFER
-- or VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC is updated, the
-- offset must be an integer multiple of this limit.
-- Similarly, dynamic offsets for storage buffers must be
-- multiples of this limit.
-- - minTexelOffset is the minimum offset value for the
-- ConstOffset image operand of any of the
-- OpImageSample* or OpImageFetch* image
-- instructions.
-- - maxTexelOffset is the maximum offset value for the
-- ConstOffset image operand of any of the
-- OpImageSample* or OpImageFetch* image
-- instructions.
-- - minTexelGatherOffset is the minimum offset value for the
-- Offset or ConstOffsets image operands of any of the
-- OpImage*Gather image instructions.
-- - maxTexelGatherOffset is the maximum offset value for the
-- Offset or ConstOffsets image operands of any of the
-- OpImage*Gather image instructions.
-- - minInterpolationOffset is the minimum negative offset
-- value for the offset operand of the
-- InterpolateAtOffset extended instruction.
-- - maxInterpolationOffset is the maximum positive offset
-- value for the offset operand of the
-- InterpolateAtOffset extended instruction.
-- - subPixelInterpolationOffsetBits is the number of subpixel
-- fractional bits that the x and y offsets to the
-- InterpolateAtOffset extended instruction may be
-- rounded to as fixed-point values.
-- - maxFramebufferWidth is the maximum width for a
-- framebuffer. The width member of the
-- VkFramebufferCreateInfo structure must be less than or
-- equal to this limit.
-- - maxFramebufferHeight is the maximum height for a
-- framebuffer. The height member of the
-- VkFramebufferCreateInfo structure must be less than or
-- equal to this limit.
-- - maxFramebufferLayers is the maximum layer count for a
-- layered framebuffer. The layers member of the
-- VkFramebufferCreateInfo structure must be less than or
-- equal to this limit.
-- - framebufferColorSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the color sample counts that
-- are supported for all framebuffer color attachments with floating- or
-- fixed-point formats. There is no limit that specifies the color sample
-- counts that are supported for all color attachments with integer
-- formats.
-- - framebufferDepthSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the supported depth sample
-- counts for all framebuffer depth/stencil attachments, when the format
-- includes a depth component.
-- - framebufferStencilSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the supported stencil sample
-- counts for all framebuffer depth/stencil attachments, when the format
-- includes a stencil component.
-- - framebufferNoAttachmentsSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the supported sample counts
-- for a framebuffer with no attachments.
-- - maxColorAttachments is the maximum number of color
-- attachments that can be used by a subpass in a render pass. The
-- colorAttachmentCount member of the
-- VkSubpassDescription structure must be less than or
-- equal to this limit.
-- - sampledImageColorSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the sample counts supported
-- for all 2D images created with VK_IMAGE_TILING_OPTIMAL,
-- usage containing VK_IMAGE_USAGE_SAMPLED_BIT, and a
-- non-integer color format.
-- - sampledImageIntegerSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the sample counts supported
-- for all 2D images created with VK_IMAGE_TILING_OPTIMAL,
-- usage containing VK_IMAGE_USAGE_SAMPLED_BIT, and an
-- integer color format.
-- - sampledImageDepthSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the sample counts supported
-- for all 2D images created with VK_IMAGE_TILING_OPTIMAL,
-- usage containing VK_IMAGE_USAGE_SAMPLED_BIT, and a
-- depth format.
-- - sampledImageStencilSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the sample supported for all
-- 2D images created with VK_IMAGE_TILING_OPTIMAL,
-- usage containing VK_IMAGE_USAGE_SAMPLED_BIT, and a
-- stencil format.
-- - storageImageSampleCounts is a bitmask1 of
-- VkSampleCountFlagBits indicating the sample counts supported
-- for all 2D images created with VK_IMAGE_TILING_OPTIMAL, and
-- usage containing VK_IMAGE_USAGE_STORAGE_BIT.
-- - maxSampleMaskWords is the maximum number of array
-- elements of a variable decorated with the SampleMask built-in
-- decoration.
-- - timestampComputeAndGraphics specifies support for
-- timestamps on all graphics and compute queues. If this limit is set to
-- VK_TRUE, all queues that advertise the
-- VK_QUEUE_GRAPHICS_BIT or VK_QUEUE_COMPUTE_BIT in the
-- VkQueueFamilyProperties::queueFlags support
-- VkQueueFamilyProperties::timestampValidBits of at
-- least 36. See Timestamp Queries.
-- - timestampPeriod is the number of nanoseconds
-- required for a timestamp query to be incremented by 1. See
-- Timestamp Queries.
-- - maxClipDistances is the maximum number of clip distances
-- that can be used in a single shader stage. The size of any
-- array declared with the ClipDistance built-in decoration in a
-- shader module must be less than or equal to this limit.
-- - maxCullDistances is the maximum number of cull distances
-- that can be used in a single shader stage. The size of any
-- array declared with the CullDistance built-in decoration in a
-- shader module must be less than or equal to this limit.
-- - maxCombinedClipAndCullDistances is the maximum combined
-- number of clip and cull distances that can be used in a single
-- shader stage. The sum of the sizes of any pair of arrays declared with
-- the ClipDistance and CullDistance built-in
-- decoration used by a single shader stage in a shader module
-- must be less than or equal to this limit.
-- - discreteQueuePriorities is the number of discrete
-- priorities that can be assigned to a queue based on the value
-- of each member of
-- VkDeviceQueueCreateInfo::pQueuePriorities. This
-- must be at least 2, and levels must be spread evenly
-- over the range, with at least one level at 1.0, and another at 0.0.
-- See {html_spec_relative}#devsandqueues-priority.
-- - pointSizeRange[2] is the range
-- [minimum,maximum] of supported sizes for points.
-- Values written to variables decorated with the PointSize
-- built-in decoration are clamped to this range.
-- - lineWidthRange[2] is the range
-- [minimum,maximum] of supported widths for lines.
-- Values specified by the lineWidth member of the
-- VkPipelineRasterizationStateCreateInfo or the
-- lineWidth parameter to vkCmdSetLineWidth are clamped
-- to this range.
-- - pointSizeGranularity is the granularity of supported
-- point sizes. Not all point sizes in the range defined by
-- pointSizeRange are supported. This limit specifies the
-- granularity (or increment) between successive supported point
-- sizes.
-- - lineWidthGranularity is the granularity of supported line
-- widths. Not all line widths in the range defined by
-- lineWidthRange are supported. This limit specifies the
-- granularity (or increment) between successive supported line
-- widths.
-- - strictLines specifies whether lines are rasterized
-- according to the preferred method of rasterization. If set to
-- VK_FALSE, lines may be rasterized under a relaxed set
-- of rules. If set to VK_TRUE, lines are rasterized as per the
-- strict definition. See Basic Line Segment Rasterization.
-- - standardSampleLocations specifies whether rasterization
-- uses the standard sample locations as documented in
-- Multisampling. If set to VK_TRUE, the implementation
-- uses the documented sample locations. If set to VK_FALSE, the
-- implementation may use different sample locations.
-- - optimalBufferCopyOffsetAlignment is the optimal buffer
-- offset alignment in bytes for vkCmdCopyBufferToImage and
-- vkCmdCopyImageToBuffer. The per texel alignment requirements
-- are enforced, but applications should use the optimal alignment
-- for optimal performance and power use.
-- - optimalBufferCopyRowPitchAlignment is the optimal buffer
-- row pitch alignment in bytes for vkCmdCopyBufferToImage and
-- vkCmdCopyImageToBuffer. Row pitch is the number of bytes
-- between texels with the same X coordinate in adjacent rows (Y
-- coordinates differ by one). The per texel alignment requirements are
-- enforced, but applications should use the optimal alignment for
-- optimal performance and power use.
-- - nonCoherentAtomSize is the size and alignment in bytes
-- that bounds concurrent access to host-mapped device
-- memory.
--
-- - VkPhysicalDeviceDiscardRectanglePropertiesEXT::maxDiscardRectangles
-- is the maximum number of active discard rectangles. This limit can be
-- queried by setting the pNext pointer from a
-- VkPhysicalDeviceProperties2 object to an instance of
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT and using
-- vkGetPhysicalDeviceProperties2 to fill out the members.
--
-- - VkPhysicalDevicePointClippingProperties::pointClippingBehavior
-- defines the clipping behavior of points. This limit can be queried by
-- setting the pNext pointer from a
-- VkPhysicalDeviceProperties2 object to an instance of
-- VkPhysicalDevicePointClippingProperties and using
-- vkGetPhysicalDeviceProperties2 to fill out the members.
--
-- - VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT::maxVertexAttribDivisor
-- is the maximum value of the number of instances that will repeat the
-- value of vertex attribute data when instanced rendering is enabled.
-- This limit can be queried by setting the pNext pointer from a
-- VkPhysicalDeviceProperties2 object to an instance of
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT and using
-- vkGetPhysicalDeviceProperties2 to fill out the members.
--
--
-- Description
--
--
--
-- See Also
--
-- VkBool32, VkDeviceSize,
-- VkPhysicalDeviceProperties, VkSampleCountFlags
data VkPhysicalDeviceLimits
VkPhysicalDeviceLimits :: Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> VkDeviceSize -> VkDeviceSize -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Vector 3 Word32 -> Word32 -> Vector 3 Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> CFloat -> CFloat -> Word32 -> Vector 2 Word32 -> Vector 2 CFloat -> Word32 -> CSize -> VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> Int32 -> Word32 -> Int32 -> Word32 -> CFloat -> CFloat -> Word32 -> Word32 -> Word32 -> Word32 -> VkSampleCountFlags -> VkSampleCountFlags -> VkSampleCountFlags -> VkSampleCountFlags -> Word32 -> VkSampleCountFlags -> VkSampleCountFlags -> VkSampleCountFlags -> VkSampleCountFlags -> VkSampleCountFlags -> Word32 -> VkBool32 -> CFloat -> Word32 -> Word32 -> Word32 -> Word32 -> Vector 2 CFloat -> Vector 2 CFloat -> CFloat -> CFloat -> VkBool32 -> VkBool32 -> VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkPhysicalDeviceLimits
[$sel:vkMaxImageDimension1D:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxImageDimension2D:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxImageDimension3D:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxImageDimensionCube:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxImageArrayLayers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTexelBufferElements:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxUniformBufferRange:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxStorageBufferRange:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPushConstantsSize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxMemoryAllocationCount:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxSamplerAllocationCount:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkBufferImageGranularity:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkSparseAddressSpaceSize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkMaxBoundDescriptorSets:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorSamplers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorUniformBuffers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorStorageBuffers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorSampledImages:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorStorageImages:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageDescriptorInputAttachments:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxPerStageResources:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetSamplers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetUniformBuffers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetUniformBuffersDynamic:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetStorageBuffers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetStorageBuffersDynamic:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetSampledImages:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetStorageImages:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDescriptorSetInputAttachments:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxVertexInputAttributes:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxVertexInputBindings:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxVertexInputAttributeOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxVertexInputBindingStride:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxVertexOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationGenerationLevel:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationPatchSize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationControlPerVertexInputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationControlPerVertexOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationControlPerPatchOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationControlTotalOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationEvaluationInputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxTessellationEvaluationOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxGeometryShaderInvocations:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxGeometryInputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxGeometryOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxGeometryOutputVertices:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxGeometryTotalOutputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFragmentInputComponents:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFragmentOutputAttachments:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFragmentDualSrcAttachments:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFragmentCombinedOutputResources:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxComputeSharedMemorySize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxComputeWorkGroupCount:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 3 Word32
[$sel:vkMaxComputeWorkGroupInvocations:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxComputeWorkGroupSize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 3 Word32
[$sel:vkSubPixelPrecisionBits:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkSubTexelPrecisionBits:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMipmapPrecisionBits:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDrawIndexedIndexValue:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxDrawIndirectCount:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxSamplerLodBias:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkMaxSamplerAnisotropy:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkMaxViewports:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxViewportDimensions:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 2 Word32
[$sel:vkViewportBoundsRange:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 2 CFloat
[$sel:vkViewportSubPixelBits:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMinMemoryMapAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CSize
[$sel:vkMinTexelBufferOffsetAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkMinUniformBufferOffsetAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkMinStorageBufferOffsetAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkMinTexelOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Int32
[$sel:vkMaxTexelOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMinTexelGatherOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Int32
[$sel:vkMaxTexelGatherOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMinInterpolationOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkMaxInterpolationOffset:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkSubPixelInterpolationOffsetBits:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFramebufferWidth:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFramebufferHeight:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxFramebufferLayers:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkFramebufferColorSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkFramebufferDepthSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkFramebufferStencilSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkFramebufferNoAttachmentsSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkMaxColorAttachments:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkSampledImageColorSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkSampledImageIntegerSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkSampledImageDepthSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkSampledImageStencilSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkStorageImageSampleCounts:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkSampleCountFlags
[$sel:vkMaxSampleMaskWords:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkTimestampComputeAndGraphics:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkBool32
[$sel:vkTimestampPeriod:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkMaxClipDistances:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxCullDistances:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkMaxCombinedClipAndCullDistances:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkDiscreteQueuePriorities:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Word32
[$sel:vkPointSizeRange:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 2 CFloat
[$sel:vkLineWidthRange:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> Vector 2 CFloat
[$sel:vkPointSizeGranularity:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkLineWidthGranularity:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> CFloat
[$sel:vkStrictLines:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkBool32
[$sel:vkStandardSampleLocations:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkBool32
[$sel:vkOptimalBufferCopyOffsetAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkOptimalBufferCopyRowPitchAlignment:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
[$sel:vkNonCoherentAtomSize:VkPhysicalDeviceLimits] :: VkPhysicalDeviceLimits -> VkDeviceSize
-- | VkQueueFlags - Bitmask of VkQueueFlagBits
--
-- Description
--
-- VkQueueFlags is a bitmask type for setting a mask of zero or
-- more VkQueueFlagBits.
--
-- See Also
--
-- VkQueueFamilyProperties, VkQueueFlagBits
type VkQueueFlags = VkQueueFlagBits
-- | VkMemoryPropertyFlags - Bitmask of VkMemoryPropertyFlagBits
--
-- Description
--
-- VkMemoryPropertyFlags is a bitmask type for setting a mask of
-- zero or more VkMemoryPropertyFlagBits.
--
-- See Also
--
-- VkMemoryPropertyFlagBits, VkMemoryType
type VkMemoryPropertyFlags = VkMemoryPropertyFlagBits
-- | VkMemoryHeapFlags - Bitmask of VkMemoryHeapFlagBits
--
-- Description
--
-- VkMemoryHeapFlags is a bitmask type for setting a mask of
-- zero or more VkMemoryHeapFlagBits.
--
-- See Also
--
-- VkMemoryHeap, VkMemoryHeapFlagBits
type VkMemoryHeapFlags = VkMemoryHeapFlagBits
-- | VkImageUsageFlags - Bitmask of VkImageUsageFlagBits
--
-- Description
--
-- VkImageUsageFlags is a bitmask type for setting a mask of
-- zero or more VkImageUsageFlagBits.
--
-- See Also
--
-- VkImageCreateInfo, VkImageUsageFlagBits,
-- VkImageViewUsageCreateInfo,
-- VkPhysicalDeviceImageFormatInfo2,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- VkSharedPresentSurfaceCapabilitiesKHR,
-- VkSurfaceCapabilities2EXT, VkSurfaceCapabilitiesKHR,
-- VkSwapchainCreateInfoKHR,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceImageFormatProperties,
-- vkGetPhysicalDeviceSparseImageFormatProperties
type VkImageUsageFlags = VkImageUsageFlagBits
-- | VkImageCreateFlags - Bitmask of VkImageCreateFlagBits
--
-- Description
--
-- VkImageCreateFlags is a bitmask type for setting a mask of
-- zero or more VkImageCreateFlagBits.
--
-- See Also
--
-- VkImageCreateFlagBits, VkImageCreateInfo,
-- VkPhysicalDeviceImageFormatInfo2,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV,
-- vkGetPhysicalDeviceImageFormatProperties
type VkImageCreateFlags = VkImageCreateFlagBits
-- | VkFormatFeatureFlags - Bitmask of VkFormatFeatureFlagBits
--
-- Description
--
-- VkFormatFeatureFlags is a bitmask type for setting a mask of
-- zero or more VkFormatFeatureFlagBits.
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkFormatFeatureFlagBits, VkFormatProperties
type VkFormatFeatureFlags = VkFormatFeatureFlagBits
-- | VkSampleCountFlags - Bitmask of VkSampleCountFlagBits
--
-- Description
--
-- VkSampleCountFlags is a bitmask type for setting a mask of
-- zero or more VkSampleCountFlagBits.
--
-- See Also
--
-- VkImageFormatProperties, VkPhysicalDeviceLimits,
-- VkPhysicalDeviceSampleLocationsPropertiesEXT,
-- VkSampleCountFlagBits
type VkSampleCountFlags = VkSampleCountFlagBits
-- | VkDeviceSize - Vulkan device memory size and offsets
--
-- Description
--
-- See Also
--
-- VkAndroidHardwareBufferPropertiesANDROID,
-- VkBindBufferMemoryInfo, VkBindImageMemoryInfo,
-- VkBufferCopy, VkBufferCreateInfo,
-- VkBufferImageCopy, VkBufferMemoryBarrier,
-- VkBufferViewCreateInfo, VkCmdProcessCommandsInfoNVX,
-- VkDescriptorBufferInfo, VkImageFormatProperties,
-- VkIndirectCommandsTokenNVX, VkMappedMemoryRange,
-- VkMemoryAllocateInfo, VkMemoryHeap,
-- VkMemoryRequirements,
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT,
-- VkPhysicalDeviceLimits,
-- VkPhysicalDeviceMaintenance3Properties,
-- VkSparseImageMemoryBind,
-- VkSparseImageMemoryRequirements, VkSparseMemoryBind,
-- VkSubresourceLayout, vkBindBufferMemory,
-- vkBindImageMemory, vkCmdBindIndexBuffer,
-- vkCmdBindVertexBuffers, vkCmdCopyQueryPoolResults,
-- vkCmdDispatchIndirect, vkCmdDrawIndexedIndirect,
-- vkCmdDrawIndexedIndirectCountAMD, vkCmdDrawIndirect,
-- vkCmdDrawIndirectCountAMD, vkCmdFillBuffer,
-- vkCmdUpdateBuffer, vkCmdWriteBufferMarkerAMD,
-- vkGetDeviceMemoryCommitment, vkGetQueryPoolResults,
-- vkMapMemory
type VkDeviceSize = Word64
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceMemoryProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceMemoryProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeap
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeap
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkImageFormatProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkImageFormatProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceLimits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceLimits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkFormatProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkFormatProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryType
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFamilyProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFamilyProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceSparseProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceSparseProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceFeatures
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkAllocationCallbacks
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkAllocationCallbacks
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkApplicationInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkApplicationInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkExtent3D
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkExtent3D
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkInternalAllocationType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkInternalAllocationType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkInternalAllocationType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkSystemAllocationScope
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkSystemAllocationScope
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkSystemAllocationScope
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkImageType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkImageType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkImageType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkImageTiling
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DeviceInitialization.VkImageTiling
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DeviceInitialization.VkImageTiling
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceMemoryProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeap
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkImageFormatProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceLimits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkFormatProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFamilyProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceSparseProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkAllocationCallbacks
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkApplicationInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DeviceInitialization.VkExtent3D
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkSampleCountFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkFormatFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkImageCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkImageUsageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryHeapFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkMemoryPropertyFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkQueueFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkInstanceCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkInternalAllocationType
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkInternalAllocationType
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkSystemAllocationScope
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkSystemAllocationScope
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceType
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkPhysicalDeviceType
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkImageType
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkImageType
instance GHC.Show.Show Graphics.Vulkan.Core10.DeviceInitialization.VkImageTiling
instance GHC.Read.Read Graphics.Vulkan.Core10.DeviceInitialization.VkImageTiling
module Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities
-- | VkExternalMemoryHandleTypeFlagBitsNV - Bitmask specifying external
-- memory handle types
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagsNV
newtype VkExternalMemoryHandleTypeFlagBitsNV
VkExternalMemoryHandleTypeFlagBitsNV :: VkFlags -> VkExternalMemoryHandleTypeFlagBitsNV
-- | VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_NV specifies
-- a handle to memory returned by vkGetMemoryWin32HandleNV, or one
-- duplicated from such a handle using DuplicateHandle().
-- | VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_NV
-- specifies a handle to memory returned by
-- vkGetMemoryWin32HandleNV.
-- | VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_BIT_NV specifies a
-- valid NT handle to memory returned by
-- IDXGIResource1::CreateSharedHandle(), or a handle duplicated
-- from such a handle using DuplicateHandle().
-- | VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_IMAGE_KMT_BIT_NV
-- specifies a handle to memory returned by
-- IDXGIResource::GetSharedHandle().
-- | VkExternalMemoryFeatureFlagBitsNV - Bitmask specifying external memory
-- features
--
-- See Also
--
-- VkExternalImageFormatPropertiesNV,
-- VkExternalMemoryFeatureFlagsNV,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV
newtype VkExternalMemoryFeatureFlagBitsNV
VkExternalMemoryFeatureFlagBitsNV :: VkFlags -> VkExternalMemoryFeatureFlagBitsNV
-- | VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT_NV specifies
-- that external memory of the specified type must be created as a
-- dedicated allocation when used in the manner specified.
-- | VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT_NV specifies that
-- the implementation supports exporting handles of the specified type.
-- | VK_EXTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT_NV specifies that
-- the implementation supports importing handles of the specified type.
-- | vkGetPhysicalDeviceExternalImageFormatPropertiesNV - determine image
-- capabilities compatible with external memory handle types
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the image capabilities
--
--
--
--
-- Description
--
-- If externalHandleType is 0,
-- pExternalImageFormatProperties::imageFormatProperties will
-- return the same values as a call to
-- vkGetPhysicalDeviceImageFormatProperties, and the other members
-- of pExternalImageFormatProperties will all be 0. Otherwise,
-- they are filled in as described for
-- VkExternalImageFormatPropertiesNV.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkExternalImageFormatPropertiesNV,
-- VkExternalMemoryHandleTypeFlagsNV, VkFormat,
-- VkImageCreateFlags, VkImageTiling, VkImageType,
-- VkImageUsageFlags, VkPhysicalDevice
vkGetPhysicalDeviceExternalImageFormatPropertiesNV :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("type" ::: VkImageType) -> ("tiling" ::: VkImageTiling) -> ("usage" ::: VkImageUsageFlags) -> ("flags" ::: VkImageCreateFlags) -> ("externalHandleType" ::: VkExternalMemoryHandleTypeFlagsNV) -> ("pExternalImageFormatProperties" ::: Ptr VkExternalImageFormatPropertiesNV) -> IO VkResult
-- | VkExternalImageFormatPropertiesNV - Structure specifying external
-- image format properties
--
-- Description
--
-- See Also
--
-- VkExternalMemoryFeatureFlagsNV,
-- VkExternalMemoryHandleTypeFlagsNV,
-- VkImageFormatProperties,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV
data VkExternalImageFormatPropertiesNV
VkExternalImageFormatPropertiesNV :: VkImageFormatProperties -> VkExternalMemoryFeatureFlagsNV -> VkExternalMemoryHandleTypeFlagsNV -> VkExternalMemoryHandleTypeFlagsNV -> VkExternalImageFormatPropertiesNV
-- | imageFormatProperties will be filled in as when calling
-- vkGetPhysicalDeviceImageFormatProperties, but the values
-- returned may vary depending on the external handle type
-- requested.
[$sel:vkImageFormatProperties:VkExternalImageFormatPropertiesNV] :: VkExternalImageFormatPropertiesNV -> VkImageFormatProperties
-- | externalMemoryFeatures is a bitmask of
-- VkExternalMemoryFeatureFlagBitsNV, indicating properties of the
-- external memory handle type
-- (vkGetPhysicalDeviceExternalImageFormatPropertiesNV::externalHandleType)
-- being queried, or 0 if the external memory handle type is 0.
[$sel:vkExternalMemoryFeatures:VkExternalImageFormatPropertiesNV] :: VkExternalImageFormatPropertiesNV -> VkExternalMemoryFeatureFlagsNV
-- | exportFromImportedHandleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBitsNV containing a bit set for
-- every external handle type that may be used to create memory
-- from which the handles of the type specified in
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV::externalHandleType
-- can be exported, or 0 if the external memory handle type is 0.
[$sel:vkExportFromImportedHandleTypes:VkExternalImageFormatPropertiesNV] :: VkExternalImageFormatPropertiesNV -> VkExternalMemoryHandleTypeFlagsNV
-- | compatibleHandleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBitsNV containing a bit set for
-- every external handle type that may be specified simultaneously
-- with the handle type specified by
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV::externalHandleType
-- when calling vkAllocateMemory, or 0 if the external memory
-- handle type is 0. compatibleHandleTypes will always contain
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV::externalHandleType
[$sel:vkCompatibleHandleTypes:VkExternalImageFormatPropertiesNV] :: VkExternalImageFormatPropertiesNV -> VkExternalMemoryHandleTypeFlagsNV
-- | VkExternalMemoryHandleTypeFlagsNV - Bitmask of
-- VkExternalMemoryHandleTypeFlagBitsNV
--
-- Description
--
-- VkExternalMemoryHandleTypeFlagsNV is a bitmask type for
-- setting a mask of zero or more
-- VkExternalMemoryHandleTypeFlagBitsNV.
--
-- See Also
--
-- VkExportMemoryAllocateInfoNV,
-- VkExternalImageFormatPropertiesNV,
-- VkExternalMemoryHandleTypeFlagBitsNV,
-- VkExternalMemoryImageCreateInfoNV,
-- VkImportMemoryWin32HandleInfoNV,
-- vkGetMemoryWin32HandleNV,
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV
type VkExternalMemoryHandleTypeFlagsNV = VkExternalMemoryHandleTypeFlagBitsNV
-- | VkExternalMemoryFeatureFlagsNV - Bitmask of
-- VkExternalMemoryFeatureFlagBitsNV
--
-- Description
--
-- VkExternalMemoryFeatureFlagsNV is a bitmask type for setting
-- a mask of zero or more VkExternalMemoryFeatureFlagBitsNV.
--
-- See Also
--
-- VkExternalImageFormatPropertiesNV,
-- VkExternalMemoryFeatureFlagBitsNV
type VkExternalMemoryFeatureFlagsNV = VkExternalMemoryFeatureFlagBitsNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalImageFormatPropertiesNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalImageFormatPropertiesNV
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalImageFormatPropertiesNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryFeatureFlagBitsNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NV_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBitsNV
module Graphics.Vulkan.Extensions.VK_NV_external_memory
-- | VkExternalMemoryImageCreateInfoNV - Specify that an image may be
-- backed by external memory
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO_NV
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagsNV, VkStructureType
data VkExternalMemoryImageCreateInfoNV
VkExternalMemoryImageCreateInfoNV :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlagsNV -> VkExternalMemoryImageCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkExternalMemoryImageCreateInfoNV] :: VkExternalMemoryImageCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExternalMemoryImageCreateInfoNV] :: VkExternalMemoryImageCreateInfoNV -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBitsNV specifying one or more
-- external memory handle types.
[$sel:vkHandleTypes:VkExternalMemoryImageCreateInfoNV] :: VkExternalMemoryImageCreateInfoNV -> VkExternalMemoryHandleTypeFlagsNV
-- | VkExportMemoryAllocateInfoNV - Specify memory handle types that may be
-- exported
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO_NV
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagsNV, VkStructureType
data VkExportMemoryAllocateInfoNV
VkExportMemoryAllocateInfoNV :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlagsNV -> VkExportMemoryAllocateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkExportMemoryAllocateInfoNV] :: VkExportMemoryAllocateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExportMemoryAllocateInfoNV] :: VkExportMemoryAllocateInfoNV -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBitsNV specifying one or more
-- memory handle types that may be exported. Multiple handle types
-- may be requested for the same allocation as long as they are
-- compatible, as reported by
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV.
[$sel:vkHandleTypes:VkExportMemoryAllocateInfoNV] :: VkExportMemoryAllocateInfoNV -> VkExternalMemoryHandleTypeFlagsNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExportMemoryAllocateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExportMemoryAllocateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExternalMemoryImageCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExternalMemoryImageCreateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExportMemoryAllocateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_external_memory.VkExternalMemoryImageCreateInfoNV
module Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax
-- | VkSamplerReductionModeEXT - Specify reduction mode for texture
-- filtering
--
-- See Also
--
-- VkSamplerReductionModeCreateInfoEXT
newtype VkSamplerReductionModeEXT
VkSamplerReductionModeEXT :: Int32 -> VkSamplerReductionModeEXT
-- | VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT specifies that
-- texel values are combined by computing a weighted average of values in
-- the footprint, using weights as specified in the image operations
-- chapter.
-- | VK_SAMPLER_REDUCTION_MODE_MIN_EXT specifies that texel values
-- are combined by taking the component-wise minimum of values in the
-- footprint with non-zero weights.
-- | VK_SAMPLER_REDUCTION_MODE_MAX_EXT specifies that texel values
-- are combined by taking the component-wise maximum of values in the
-- footprint with non-zero weights.
-- | VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT - Structure
-- describing sampler filter minmax limits that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - filterMinmaxSingleComponentFormats is a boolean value
-- indicating whether a minimum set of required formats support min/max
-- filtering.
--
--
--
-- - filterMinmaxImageComponentMapping is a boolean value
-- indicating whether the implementation supports non-identity component
-- mapping of the image when doing min/max filtering.
--
--
-- If the VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- If filterMinmaxSingleComponentFormats is VK_TRUE,
-- the following formats must support the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_MINMAX_BIT_EXT feature
-- with VK_IMAGE_TILING_OPTIMAL, if they support
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT.
--
--
-- VK_FORMAT_R8_UNORM
-- VK_FORMAT_R8_SNORM
-- VK_FORMAT_R16_UNORM
-- VK_FORMAT_R16_SNORM
-- VK_FORMAT_R16_SFLOAT
-- VK_FORMAT_R32_SFLOAT
-- VK_FORMAT_D16_UNORM
-- VK_FORMAT_X8_D24_UNORM_PACK32
-- VK_FORMAT_D32_SFLOAT
-- VK_FORMAT_D16_UNORM_S8_UINT
-- VK_FORMAT_D24_UNORM_S8_UINT
-- VK_FORMAT_D32_SFLOAT_S8_UINT
--
--
-- If the format is a depth/stencil format, this bit only specifies that
-- the depth aspect (not the stencil aspect) of an image of this format
-- supports min/max filtering, and that min/max filtering of the depth
-- aspect is supported when depth compare is disabled in the sampler.
--
-- If filterMinmaxImageComponentMapping is VK_FALSE the
-- component mapping of the image view used with min/max filtering
-- must have been created with the r component set to
-- VK_COMPONENT_SWIZZLE_IDENTITY. Only the r component
-- of the sampled image value is defined and the other component values
-- are undefined. If filterMinmaxImageComponentMapping is
-- VK_TRUE this restriction does not apply and image component
-- mapping works as normal.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_FILTER_MINMAX_PROPERTIES_EXT
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT] :: VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT] :: VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT -> Ptr ()
[$sel:vkFilterMinmaxSingleComponentFormats:VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT] :: VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT -> VkBool32
[$sel:vkFilterMinmaxImageComponentMapping:VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT] :: VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT -> VkBool32
-- | VkSamplerReductionModeCreateInfoEXT - Structure specifying sampler
-- reduction mode
--
-- Description
--
-- If this structure is not present, reductionMode is considered
-- to be VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLER_REDUCTION_MODE_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkSamplerReductionModeEXT, VkStructureType
data VkSamplerReductionModeCreateInfoEXT
VkSamplerReductionModeCreateInfoEXT :: VkStructureType -> Ptr () -> VkSamplerReductionModeEXT -> VkSamplerReductionModeCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkSamplerReductionModeCreateInfoEXT] :: VkSamplerReductionModeCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSamplerReductionModeCreateInfoEXT] :: VkSamplerReductionModeCreateInfoEXT -> Ptr ()
-- | reductionMode is an enum of type
-- VkSamplerReductionModeEXT that controls how texture filtering
-- combines texel values.
[$sel:vkReductionMode:VkSamplerReductionModeCreateInfoEXT] :: VkSamplerReductionModeCreateInfoEXT -> VkSamplerReductionModeEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_sampler_filter_minmax.VkSamplerReductionModeEXT
module Graphics.Vulkan.Extensions.VK_EXT_debug_report
-- | VkDebugReportObjectTypeEXT - Specify the type of an object handle
--
-- Description
--
--
-- +------------------------------------------+---------------------------+
-- | 'VkDebugReportObjectTypeEXT' | Vulkan Handle Type |
-- +==========================================+===========================+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT | Unknown\/Undefined Handle |
-- | @ | |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_INSTANCE_EX | 'Graphics.Vulkan.Core10.D |
-- | T@ | eviceInitialization.VkIns |
-- | | tance' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_PHYSICAL_DE | 'Graphics.Vulkan.Core10.D |
-- | VICE_EXT@ | eviceInitialization.VkPhy |
-- | | sicalDevice' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_EXT@ | 'Graphics.Vulkan.Core10.D |
-- | | eviceInitialization.VkDev |
-- | | ice' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_QUEUE_EXT@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkQueue' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_SEMAPHORE_E | 'Graphics.Vulkan.Core10.Q |
-- | XT@ | ueue.VkSemaphore' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_BUF | 'Graphics.Vulkan.Core10.Q |
-- | FER_EXT@ | ueue.VkCommandBuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_FENCE_EXT@ | 'Graphics.Vulkan.Core10.Q |
-- | | ueue.VkFence' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DEVICE_MEMO | 'Graphics.Vulkan.Core10.M |
-- | RY_EXT@ | emory.VkDeviceMemory' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_EXT@ | 'Graphics.Vulkan.Core10.M |
-- | | emoryManagement.VkBuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_EXT@ | 'Graphics.Vulkan.Core10.M |
-- | | emoryManagement.VkImage' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_EVENT_EXT@ | 'Graphics.Vulkan.Core10.E |
-- | | vent.VkEvent' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_QUERY_POOL_ | 'Graphics.Vulkan.Core10.Q |
-- | EXT@ | uery.VkQueryPool' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_BUFFER_VIEW | 'Graphics.Vulkan.Core10.B |
-- | _EXT@ | ufferView.VkBufferView' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_IMAGE_VIEW_ | 'Graphics.Vulkan.Core10.I |
-- | EXT@ | mageView.VkImageView' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_SHADER_MODU | 'Graphics.Vulkan.Core10.S |
-- | LE_EXT@ | hader.VkShaderModule' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_CA | 'Graphics.Vulkan.Core10.P |
-- | CHE_EXT@ | ipelineCache.VkPipelineCa |
-- | | che' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_LA | 'Graphics.Vulkan.Core10.P |
-- | YOUT_EXT@ | ipeline.VkPipelineLayout' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_RENDER_PASS | 'Graphics.Vulkan.Core10.P |
-- | _EXT@ | ipeline.VkRenderPass' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_PIPELINE_EX | 'Graphics.Vulkan.Core10.P |
-- | T@ | ipeline.VkPipeline' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_ | 'Graphics.Vulkan.Core10.P |
-- | SET_LAYOUT_EXT@ | ipelineLayout.VkDescripto |
-- | | rSetLayout' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_SAMPLER_EXT | 'Graphics.Vulkan.Core10.S |
-- | @ | ampler.VkSampler' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_ | 'Graphics.Vulkan.Core10.D |
-- | POOL_EXT@ | escriptorSet.VkDescriptor |
-- | | Pool' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_ | 'Graphics.Vulkan.Core10.D |
-- | SET_EXT@ | escriptorSet.VkDescriptor |
-- | | Set' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_FRAMEBUFFER | 'Graphics.Vulkan.Core10.P |
-- | _EXT@ | ass.VkFramebuffer' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_COMMAND_POO | 'Graphics.Vulkan.Core10.C |
-- | L_EXT@ | ommandPool.VkCommandPool' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_SURFACE_KHR | 'Graphics.Vulkan.Extensio |
-- | _EXT@ | ns.VK_KHR_surface.VkSurfa |
-- | | ceKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_SWAPCHAIN_K | 'Graphics.Vulkan.Extensio |
-- | HR_EXT@ | ns.VK_KHR_swapchain.VkSwa |
-- | | pchainKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DEBUG_REPOR | 'VkDebugReportCallbackEXT |
-- | T_CALLBACK_EXT_EXT@ | ' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_KHR | 'Graphics.Vulkan.Extensio |
-- | _EXT@ | ns.VK_KHR_display.VkDispl |
-- | | ayKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DISPLAY_MOD | 'Graphics.Vulkan.Extensio |
-- | E_KHR_EXT@ | ns.VK_KHR_display.VkDispl |
-- | | ayModeKHR' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_OBJECT_TABL | 'Graphics.Vulkan.Extensio |
-- | E_NVX_EXT@ | ns.VK_NVX_device_generate |
-- | | d_commands.VkObjectTableN |
-- | | VX' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_INDIRECT_CO | 'Graphics.Vulkan.Extensio |
-- | MMANDS_LAYOUT_NVX_EXT@ | ns.VK_NVX_device_generate |
-- | | d_commands.VkIndirectComm |
-- | | andsLayoutNVX' |
-- +------------------------------------------+---------------------------+
-- | @VK_DEBUG_REPORT_OBJECT_TYPE_DESCRIPTOR_ | 'Graphics.Vulkan.Core11.P |
-- | UPDATE_TEMPLATE_KHR_EXT@ | romoted_from_VK_KHR_descr |
-- | | iptor_update_template.VkD |
-- | | escriptorUpdateTemplate' |
-- +------------------------------------------+---------------------------+
--
-- VkDebugReportObjectTypeEXT and Vulkan Handle Relationship
--
--
-- Note
--
-- The primary expected use of VK_ERROR_VALIDATION_FAILED_EXT is
-- for validation layer testing. It is not expected that an application
-- would see this error code during normal use of the validation layers.
--
-- See Also
--
-- VkDebugMarkerObjectNameInfoEXT,
-- VkDebugMarkerObjectTagInfoEXT, vkDebugReportMessageEXT
newtype VkDebugReportObjectTypeEXT
VkDebugReportObjectTypeEXT :: Int32 -> VkDebugReportObjectTypeEXT
-- | VkDebugReportFlagBitsEXT - Bitmask specifying events which cause a
-- debug report callback
--
-- See Also
--
-- VkDebugReportFlagsEXT
newtype VkDebugReportFlagBitsEXT
VkDebugReportFlagBitsEXT :: VkFlags -> VkDebugReportFlagBitsEXT
-- | VK_DEBUG_REPORT_INFORMATION_BIT_EXT specifies an
-- informational message such as resource details that may be handy when
-- debugging an application.
-- | VK_DEBUG_REPORT_WARNING_BIT_EXT specifies use of Vulkan that
-- may expose an app bug. Such cases may not be immediately
-- harmful, such as a fragment shader outputting to a location with no
-- attachment. Other cases may point to behavior that is almost
-- certainly bad when unintended such as using an image whose memory has
-- not been filled. In general if you see a warning but you know that the
-- behavior is intended/desired, then simply ignore the warning.
-- | VK_DEBUG_REPORT_PERFORMANCE_WARNING_BIT_EXT specifies a
-- potentially non-optimal use of Vulkan, e.g. using
-- vkCmdClearColorImage when setting
-- VkAttachmentDescription::loadOp to
-- VK_ATTACHMENT_LOAD_OP_CLEAR would have worked.
-- | VK_DEBUG_REPORT_ERROR_BIT_EXT specifies that an error that
-- may cause undefined results, including an application crash.
-- | VK_DEBUG_REPORT_DEBUG_BIT_EXT specifies diagnostic
-- information from the implementation and layers.
-- | PFN_vkDebugReportCallbackEXT - Application-defined debug report
-- callback function
--
-- Parameters
--
--
--
--
-- - objectType is a VkDebugReportObjectTypeEXT value
-- specifying the type of object being used or created at the time the
-- event was triggered.
-- - object is the object where the issue was detected. If
-- objectType is
-- VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT, object is
-- undefined.
-- - location is a component (layer, driver, loader) defined
-- value that specifies the location of the trigger. This is an
-- optional value.
-- - messageCode is a layer-defined value indicating what test
-- triggered this callback.
-- - pLayerPrefix is a null-terminated string that is an
-- abbreviation of the name of the component making the callback.
-- pLayerPrefix is only valid for the duration of the
-- callback.
-- - pMessage is a null-terminated string detailing the
-- trigger conditions. pMessage is only valid for the duration
-- of the callback.
-- - pUserData is the user data given when the
-- VkDebugReportCallbackEXT was created.
--
--
-- Description
--
-- The callback must not call
-- vkDestroyDebugReportCallbackEXT.
--
-- The callback returns a VkBool32, which is interpreted in a
-- layer-specified manner. The application should always return
-- VK_FALSE. The VK_TRUE value is reserved for use in
-- layer development.
--
-- object must be a Vulkan object or
-- VK_NULL_HANDLE. If objectType is not
-- VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT and object
-- is not VK_NULL_HANDLE, object must be a
-- Vulkan object of the corresponding type associated with
-- objectType as defined in
-- {html_spec_relative}#debug-report-object-types.
--
-- See Also
--
-- VkDebugReportCallbackCreateInfoEXT
type PFN_vkDebugReportCallbackEXT = Ptr (("flags" ::: VkDebugReportFlagsEXT) -> ("objectType" ::: VkDebugReportObjectTypeEXT) -> ("object" ::: Word64) -> ("location" ::: CSize) -> ("messageCode" ::: Int32) -> ("pLayerPrefix" ::: Ptr CChar) -> ("pMessage" ::: Ptr CChar) -> ("pUserData" ::: Ptr ()) -> IO VkBool32)
-- | VkDebugReportCallbackEXT - Opaque handle to a debug report callback
-- object
--
-- Description
--
-- See Also
--
-- vkCreateDebugReportCallbackEXT,
-- vkDestroyDebugReportCallbackEXT
type VkDebugReportCallbackEXT = Ptr VkDebugReportCallbackEXT_T
-- | vkCreateDebugReportCallbackEXT - Create a debug report callback object
--
-- Parameters
--
--
-- - instance the instance the callback will be logged
-- on.
--
--
--
-- - pCreateInfo points to a
-- VkDebugReportCallbackCreateInfoEXT structure which defines the
-- conditions under which this callback will be called.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pCallback is a pointer to record the
-- VkDebugReportCallbackEXT object created.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDebugReportCallbackCreateInfoEXT structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pCallback must be a valid pointer to a
-- VkDebugReportCallbackEXT handle
--
--
-- Return Codes
--
--
--
--
-- - Failure - VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks,
-- VkDebugReportCallbackCreateInfoEXT,
-- VkDebugReportCallbackEXT, VkInstance
vkCreateDebugReportCallbackEXT :: ("instance" ::: VkInstance) -> ("pCreateInfo" ::: Ptr VkDebugReportCallbackCreateInfoEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pCallback" ::: Ptr VkDebugReportCallbackEXT) -> IO VkResult
-- | vkDestroyDebugReportCallbackEXT - Destroy a debug report callback
-- object
--
-- Parameters
--
--
-- - instance the instance where the callback was
-- created.
--
--
--
-- - callback the VkDebugReportCallbackEXT object to
-- destroy. callback is an externally synchronized object and
-- must not be used on more than one thread at a time. This means
-- that vkDestroyDebugReportCallbackEXT must not be
-- called when a callback is active.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- callback was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- callback was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - callback must be a valid
-- VkDebugReportCallbackEXT handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - callback must have been created, allocated, or
-- retrieved from instance
--
--
-- Host Synchronization
--
--
-- - Host access to callback must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDebugReportCallbackEXT,
-- VkInstance
vkDestroyDebugReportCallbackEXT :: ("instance" ::: VkInstance) -> ("callback" ::: VkDebugReportCallbackEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkDebugReportMessageEXT - Inject a message into a debug stream
--
-- Parameters
--
--
-- - instance is the debug stream’s VkInstance.
--
--
--
-- - flags specifies the VkDebugReportFlagBitsEXT
-- classification of this event/message.
-- - objectType is a VkDebugReportObjectTypeEXT
-- specifying the type of object being used or created at the time the
-- event was triggered.
-- - object this is the object where the issue was detected.
-- object can be VK_NULL_HANDLE if there is no
-- object associated with the event.
-- - location is an application defined value.
-- - messageCode is an application defined value.
-- - pLayerPrefix is the abbreviation of the component making
-- this event/message.
-- - pMessage is a null-terminated string detailing the
-- trigger conditions.
--
--
-- Description
--
-- The call will propagate through the layers and generate callback(s) as
-- indicated by the message’s flags. The parameters are passed on to the
-- callback in addition to the pUserData value that was defined
-- at the time the callback was registered.
--
-- Valid Usage
--
--
-- - object must be a Vulkan object or
-- VK_NULL_HANDLE
--
--
--
-- - If objectType is not
-- VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT and object
-- is not VK_NULL_HANDLE, object must be a
-- Vulkan object of the corresponding type associated with
-- objectType as defined in
-- {html_spec_relative}#debug-report-object-types.
--
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - flags must be a valid combination of
-- VkDebugReportFlagBitsEXT values
-- - flags must not be 0
-- - objectType must be a valid
-- VkDebugReportObjectTypeEXT value
-- - pLayerPrefix must be a null-terminated UTF-8
-- string
-- - pMessage must be a null-terminated UTF-8
-- string
--
--
-- See Also
--
-- VkDebugReportFlagsEXT, VkDebugReportObjectTypeEXT,
-- VkInstance
vkDebugReportMessageEXT :: ("instance" ::: VkInstance) -> ("flags" ::: VkDebugReportFlagsEXT) -> ("objectType" ::: VkDebugReportObjectTypeEXT) -> ("object" ::: Word64) -> ("location" ::: CSize) -> ("messageCode" ::: Int32) -> ("pLayerPrefix" ::: Ptr CChar) -> ("pMessage" ::: Ptr CChar) -> IO ()
-- | VkDebugReportCallbackCreateInfoEXT - Structure specifying parameters
-- of a newly created debug report callback
--
-- Description
--
-- For each VkDebugReportCallbackEXT that is created the
-- VkDebugReportCallbackCreateInfoEXT::flags determine
-- when that
-- VkDebugReportCallbackCreateInfoEXT::pfnCallback is
-- called. When an event happens, the implementation will do a bitwise
-- AND of the event’s VkDebugReportFlagBitsEXT flags to each
-- VkDebugReportCallbackEXT object’s flags. For each non-zero
-- result the corresponding callback will be called. The callback will
-- come directly from the component that detected the event, unless some
-- other layer intercepts the calls for its own purposes (filter them in
-- a different way, log to a system error log, etc.).
--
-- An application may receive multiple callbacks if multiple
-- VkDebugReportCallbackEXT objects were created. A callback
-- will always be executed in the same thread as the originating Vulkan
-- call.
--
-- A callback may be called from multiple threads simultaneously (if the
-- application is making Vulkan calls from multiple threads).
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_REPORT_CALLBACK_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- PFN_vkDebugReportCallbackEXT, VkDebugReportFlagsEXT,
-- VkStructureType, vkCreateDebugReportCallbackEXT
data VkDebugReportCallbackCreateInfoEXT
VkDebugReportCallbackCreateInfoEXT :: VkStructureType -> Ptr () -> VkDebugReportFlagsEXT -> PFN_vkDebugReportCallbackEXT -> Ptr () -> VkDebugReportCallbackCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugReportCallbackCreateInfoEXT] :: VkDebugReportCallbackCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugReportCallbackCreateInfoEXT] :: VkDebugReportCallbackCreateInfoEXT -> Ptr ()
-- | flags is a bitmask of VkDebugReportFlagBitsEXT
-- specifying which event(s) will cause this callback to be called.
[$sel:vkFlags:VkDebugReportCallbackCreateInfoEXT] :: VkDebugReportCallbackCreateInfoEXT -> VkDebugReportFlagsEXT
-- | pfnCallback is the application callback function to call.
[$sel:vkPfnCallback:VkDebugReportCallbackCreateInfoEXT] :: VkDebugReportCallbackCreateInfoEXT -> PFN_vkDebugReportCallbackEXT
-- | pUserData is user data to be passed to the callback.
[$sel:vkPUserData:VkDebugReportCallbackCreateInfoEXT] :: VkDebugReportCallbackCreateInfoEXT -> Ptr ()
-- | VkDebugReportFlagsEXT - Bitmask of VkDebugReportFlagBitsEXT
--
-- Description
--
-- VkDebugReportFlagsEXT is a bitmask type for setting a mask of
-- zero or more VkDebugReportFlagBitsEXT.
--
-- See Also
--
-- VkDebugReportCallbackCreateInfoEXT,
-- VkDebugReportFlagBitsEXT, vkDebugReportMessageEXT
type VkDebugReportFlagsEXT = VkDebugReportFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportCallbackCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportCallbackCreateInfoEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportObjectTypeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportObjectTypeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportObjectTypeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportCallbackCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportObjectTypeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_report.VkDebugReportObjectTypeEXT
module Graphics.Vulkan.Extensions.VK_EXT_validation_cache
-- | VkValidationCacheHeaderVersionEXT - Encode validation cache version
--
-- See Also
--
-- UNKNOWN:vkCreateValdiationCacheEXT, vkGetValidationCacheDataEXT
newtype VkValidationCacheHeaderVersionEXT
VkValidationCacheHeaderVersionEXT :: Int32 -> VkValidationCacheHeaderVersionEXT
-- | VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT specifies version
-- one of the validation cache.
-- | VkValidationCacheCreateFlagsEXT - Reserved for future use
--
-- Description
--
-- VkValidationCacheCreateFlagsEXT is a bitmask type for setting
-- a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkValidationCacheCreateInfoEXT
newtype VkValidationCacheCreateFlagsEXT
VkValidationCacheCreateFlagsEXT :: VkFlags -> VkValidationCacheCreateFlagsEXT
-- | VkValidationCacheEXT - Opaque handle to a validation cache object
--
-- Description
--
-- See Also
--
-- VkShaderModuleValidationCacheCreateInfoEXT,
-- vkCreateValidationCacheEXT, vkDestroyValidationCacheEXT,
-- vkGetValidationCacheDataEXT, vkMergeValidationCachesEXT
type VkValidationCacheEXT = Ptr VkValidationCacheEXT_T
-- | vkCreateValidationCacheEXT - Creates a new validation cache
--
-- Parameters
--
--
-- - device is the logical device that creates the validation
-- cache object.
--
--
--
-- - pCreateInfo is a pointer to a
-- VkValidationCacheCreateInfoEXT structure that contains the
-- initial parameters for the validation cache object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pValidationCache is a pointer to a
-- VkValidationCacheEXT handle in which the resulting validation
-- cache object is returned.
--
--
-- Description
--
-- Note
--
-- Applications can track and manage the total host memory size of
-- a validation cache object using the pAllocator. Applications
-- can limit the amount of data retrieved from a validation cache
-- object in vkGetValidationCacheDataEXT. Implementations
-- should not internally limit the total number of entries added
-- to a validation cache object or the total host memory consumed.
--
-- Once created, a validation cache can be passed to the
-- vkCreateShaderModule command as part of the
-- VkShaderModuleCreateInfo pNext chain. If a
-- VkShaderModuleValidationCacheCreateInfoEXT object is part of
-- the VkShaderModuleCreateInfo::pNext chain, and its
-- validationCache field is not VK_NULL_HANDLE, the
-- implementation will query it for possible reuse opportunities and
-- update it with new content. The use of the validation cache object in
-- these commands is internally synchronized, and the same validation
-- cache object can be used in multiple threads simultaneously.
--
-- Note
--
-- Implementations should make every effort to limit any critical
-- sections to the actual accesses to the cache, which is expected to be
-- significantly shorter than the duration of the
-- vkCreateShaderModule command.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkValidationCacheCreateInfoEXT structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pValidationCache must be a valid pointer to a
-- VkValidationCacheEXT handle
--
--
-- Return Codes
--
--
--
--
-- - Failure - VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkValidationCacheCreateInfoEXT, VkValidationCacheEXT
vkCreateValidationCacheEXT :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkValidationCacheCreateInfoEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pValidationCache" ::: Ptr VkValidationCacheEXT) -> IO VkResult
-- | vkDestroyValidationCacheEXT - Destroy a validation cache object
--
-- Parameters
--
--
-- - device is the logical device that destroys the validation
-- cache object.
--
--
--
-- - validationCache is the handle of the validation cache to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- validationCache was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- validationCache was created, pAllocator must
-- be NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If validationCache is not VK_NULL_HANDLE,
-- validationCache must be a valid
-- VkValidationCacheEXT handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If validationCache is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to validationCache must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkValidationCacheEXT
vkDestroyValidationCacheEXT :: ("device" ::: VkDevice) -> ("validationCache" ::: VkValidationCacheEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetValidationCacheDataEXT - Get the data store from a validation
-- cache
--
-- Parameters
--
--
-- - device is the logical device that owns the validation
-- cache.
--
--
--
-- - validationCache is the validation cache to retrieve data
-- from.
-- - pDataSize is a pointer to a value related to the amount
-- of data in the validation cache, as described below.
-- - pData is either NULL or a pointer to a
-- buffer.
--
--
-- Description
--
-- If pData is NULL, then the maximum size of the data
-- that can be retrieved from the validation cache, in bytes, is
-- returned in pDataSize. Otherwise, pDataSize
-- must point to a variable set by the user to the size of the
-- buffer, in bytes, pointed to by pData, and on return the
-- variable is overwritten with the amount of data actually written to
-- pData.
--
-- If pDataSize is less than the maximum size that can be
-- retrieved by the validation cache, at most pDataSize bytes
-- will be written to pData, and
-- vkGetValidationCacheDataEXT will return
-- VK_INCOMPLETE. Any data written to pData is valid
-- and can be provided as the pInitialData member of the
-- VkValidationCacheCreateInfoEXT structure passed to
-- vkCreateValidationCacheEXT.
--
-- Two calls to vkGetValidationCacheDataEXT with the same
-- parameters must retrieve the same data unless a command that
-- modifies the contents of the cache is called between them.
--
-- Applications can store the data retrieved from the validation
-- cache, and use these data, possibly in a future run of the
-- application, to populate new validation cache objects. The results of
-- validation, however, may depend on the vendor ID, device ID,
-- driver version, and other details of the device. To enable
-- applications to detect when previously retrieved data is incompatible
-- with the device, the initial bytes written to pData
-- must be a header consisting of the following members:
--
--
-- +----+--------------+--------------------------------------------------+
-- | Of | Size | Meaning |
-- | fs | | |
-- | et | | |
-- +====+==============+==================================================+
-- | 0 | 4 | length in bytes of the entire validation cache |
-- | | | header written as a stream of bytes, with the |
-- | | | least significant byte first |
-- +----+--------------+--------------------------------------------------+
-- | 4 | 4 | a 'VkValidationCacheHeaderVersionEXT' value |
-- | | | written as a stream of bytes, with the least |
-- | | | significant byte first |
-- +----+--------------+--------------------------------------------------+
-- | 8 | @VK_UUID_SIZ | a layer commit ID expressed as a UUID, which |
-- | | E@ | uniquely identifies the version of the |
-- | | | validation layers used to generate these |
-- | | | validation results |
-- +----+--------------+--------------------------------------------------+
--
-- Layout for validation cache header version
-- @VK_VALIDATION_CACHE_HEADER_VERSION_ONE_EXT@
--
--
-- The first four bytes encode the length of the entire validation cache
-- header, in bytes. This value includes all fields in the header
-- including the validation cache version field and the size of the
-- length field.
--
-- The next four bytes encode the validation cache version, as described
-- for VkValidationCacheHeaderVersionEXT. A consumer of the
-- validation cache should use the cache version to interpret the
-- remainder of the cache header.
--
-- If pDataSize is less than what is necessary to store this
-- header, nothing will be written to pData and zero will be
-- written to pDataSize.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - validationCache must be a valid
-- VkValidationCacheEXT handle
-- - pDataSize must be a valid pointer to a
-- size_t value
-- - If the value referenced by pDataSize is not 0,
-- and pData is not NULL, pData must be
-- a valid pointer to an array of pDataSize bytes
-- - validationCache must have been created, allocated,
-- or retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkValidationCacheEXT
vkGetValidationCacheDataEXT :: ("device" ::: VkDevice) -> ("validationCache" ::: VkValidationCacheEXT) -> ("pDataSize" ::: Ptr CSize) -> ("pData" ::: Ptr ()) -> IO VkResult
-- | vkMergeValidationCachesEXT - Combine the data stores of validation
-- caches
--
-- Parameters
--
--
-- - device is the logical device that owns the validation
-- cache objects.
--
--
--
-- - dstCache is the handle of the validation cache to merge
-- results into.
-- - srcCacheCount is the length of the pSrcCaches
-- array.
-- - pSrcCaches is an array of validation cache handles, which
-- will be merged into dstCache. The previous contents of
-- dstCache are included after the merge.
--
--
-- Description
--
-- Note
--
-- The details of the merge operation are implementation dependent, but
-- implementations should merge the contents of the specified
-- validation caches and prune duplicate entries.
--
-- Valid Usage
--
--
-- - dstCache must not appear in the list of source
-- caches
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - dstCache must be a valid
-- VkValidationCacheEXT handle
-- - pSrcCaches must be a valid pointer to an array of
-- srcCacheCount valid VkValidationCacheEXT
-- handles
-- - srcCacheCount must be greater than 0
-- - dstCache must have been created, allocated, or
-- retrieved from device
-- - Each element of pSrcCaches must have been created,
-- allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to dstCache must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkValidationCacheEXT
vkMergeValidationCachesEXT :: ("device" ::: VkDevice) -> ("dstCache" ::: VkValidationCacheEXT) -> ("srcCacheCount" ::: Word32) -> ("pSrcCaches" ::: Ptr VkValidationCacheEXT) -> IO VkResult
-- | VkValidationCacheCreateInfoEXT - Structure specifying parameters of a
-- newly created validation cache
--
-- Description
--
-- Valid Usage
--
--
-- - If initialDataSize is not 0, it must be
-- equal to the size of pInitialData, as returned by
-- vkGetValidationCacheDataEXT when pInitialData was
-- originally retrieved
--
--
--
-- - If initialDataSize is not 0,
-- pInitialData must have been retrieved from a previous
-- call to vkGetValidationCacheDataEXT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_VALIDATION_CACHE_CREATE_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - If initialDataSize is not 0,
-- pInitialData must be a valid pointer to an array of
-- initialDataSize bytes
--
--
-- See Also
--
-- VkStructureType, VkValidationCacheCreateFlagsEXT,
-- vkCreateValidationCacheEXT
data VkValidationCacheCreateInfoEXT
VkValidationCacheCreateInfoEXT :: VkStructureType -> Ptr () -> VkValidationCacheCreateFlagsEXT -> CSize -> Ptr () -> VkValidationCacheCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkValidationCacheCreateInfoEXT] :: VkValidationCacheCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkValidationCacheCreateInfoEXT] :: VkValidationCacheCreateInfoEXT -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkValidationCacheCreateInfoEXT] :: VkValidationCacheCreateInfoEXT -> VkValidationCacheCreateFlagsEXT
-- | initialDataSize is the number of bytes in
-- pInitialData. If initialDataSize is zero, the
-- validation cache will initially be empty.
[$sel:vkInitialDataSize:VkValidationCacheCreateInfoEXT] :: VkValidationCacheCreateInfoEXT -> CSize
-- | pInitialData is a pointer to previously retrieved validation
-- cache data. If the validation cache data is incompatible (as defined
-- below) with the device, the validation cache will be initially empty.
-- If initialDataSize is zero, pInitialData is ignored.
[$sel:vkPInitialData:VkValidationCacheCreateInfoEXT] :: VkValidationCacheCreateInfoEXT -> Ptr ()
-- | VkShaderModuleValidationCacheCreateInfoEXT - Specify validation cache
-- to use during shader module creation
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SHADER_MODULE_VALIDATION_CACHE_CREATE_INFO_EXT
--
--
--
-- - validationCache must be a valid
-- VkValidationCacheEXT handle
--
--
-- See Also
--
-- VkStructureType, VkValidationCacheEXT
data VkShaderModuleValidationCacheCreateInfoEXT
VkShaderModuleValidationCacheCreateInfoEXT :: VkStructureType -> Ptr () -> VkValidationCacheEXT -> VkShaderModuleValidationCacheCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkShaderModuleValidationCacheCreateInfoEXT] :: VkShaderModuleValidationCacheCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkShaderModuleValidationCacheCreateInfoEXT] :: VkShaderModuleValidationCacheCreateInfoEXT -> Ptr ()
-- | validationCache is the validation cache object from which the
-- results of prior validation attempts will be written, and to which new
-- validation results for this VkShaderModule will be written (if not
-- already present).
[$sel:vkValidationCache:VkShaderModuleValidationCacheCreateInfoEXT] :: VkShaderModuleValidationCacheCreateInfoEXT -> VkValidationCacheEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkShaderModuleValidationCacheCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkShaderModuleValidationCacheCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateInfoEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheHeaderVersionEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheHeaderVersionEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheHeaderVersionEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkShaderModuleValidationCacheCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheCreateFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheHeaderVersionEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_validation_cache.VkValidationCacheHeaderVersionEXT
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities
-- | VkExternalSemaphoreHandleTypeFlagBits - Bitmask of valid external
-- semaphore handle types
--
-- Description
--
--
-- - VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT specifies
-- a POSIX file descriptor handle that has only limited valid usage
-- outside of Vulkan and other compatible APIs. It must be
-- compatible with the POSIX system calls dup, dup2,
-- close, and the non-standard system call dup3.
-- Additionally, it must be transportable over a socket using an
-- SCM_RIGHTS control message. It owns a reference to the
-- underlying synchronization primitive represented by its Vulkan
-- semaphore object.
--
--
--
-- - VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_BIT
-- specifies an NT handle that has only limited valid usage outside of
-- Vulkan and other compatible APIs. It must be compatible with
-- the functions DuplicateHandle, CloseHandle,
-- CompareObjectHandles, GetHandleInformation, and
-- SetHandleInformation. It owns a reference to the underlying
-- synchronization primitive represented by its Vulkan semaphore
-- object.
-- - VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT
-- specifies a global share handle that has only limited valid usage
-- outside of Vulkan and other compatible APIs. It is not compatible with
-- any native APIs. It does not own a reference to the underlying
-- synchronization primitive represented its Vulkan semaphore object, and
-- will therefore become invalid when all Vulkan semaphore objects
-- associated with it are destroyed.
-- - VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_D3D12_FENCE_BIT
-- specifies an NT handle returned by
-- ID3D12Device::CreateSharedHandle referring to a
-- Direct3D 12 fence. It owns a reference to the underlying
-- synchronization primitive associated with the Direct3D fence.
-- - VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT specifies a
-- POSIX file descriptor handle to a Linux Sync File or Android Fence
-- object. It can be used with any native API accepting a valid sync file
-- or fence as input. It owns a reference to the underlying
-- synchronization primitive associated with the file descriptor.
-- Implementations which support importing this handle type must
-- accept any type of sync or fence FD supported by the native system
-- they are running on.
--
--
-- Note
--
-- Handles of type VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT
-- generated by the implementation may represent either Linux Sync Files
-- or Android Fences at the implementation’s discretion. Applications
-- should only use operations defined for both types of file
-- descriptors, unless they know via means external to Vulkan the type of
-- the file descriptor, or are prepared to deal with the system-defined
-- operation failures resulting from using the wrong type.
--
-- Some external semaphore handle types can only be shared within the
-- same underlying physical device and/or the same driver version, as
-- defined in the following table:
--
--
-- +----------------------+----------------------+-----------------------+
-- | Handle type | @VkPhysicalDeviceIDP | @VkPhysicalDeviceIDPr |
-- | | roperties@::@driverU | operties@::@deviceUUI |
-- | | UID@ | D@ |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHO | Must match | Must match |
-- | RE_HANDLE_TYPE_OPAQU | | |
-- | E_FD_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHO | Must match | Must match |
-- | RE_HANDLE_TYPE_OPAQU | | |
-- | E_WIN32_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHO | Must match | Must match |
-- | RE_HANDLE_TYPE_OPAQU | | |
-- | E_WIN32_KMT_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHO | Must match | Must match |
-- | RE_HANDLE_TYPE_D3D12 | | |
-- | _FENCE_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHO | No restriction | No restriction |
-- | RE_HANDLE_TYPE_SYNC_ | | |
-- | FD_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
--
-- External semaphore handle types compatibility
--
--
-- See Also
--
-- VkExternalSemaphoreHandleTypeFlags,
-- VkImportSemaphoreFdInfoKHR,
-- VkImportSemaphoreWin32HandleInfoKHR,
-- VkPhysicalDeviceExternalSemaphoreInfo,
-- VkSemaphoreGetFdInfoKHR,
-- VkSemaphoreGetWin32HandleInfoKHR
newtype VkExternalSemaphoreHandleTypeFlagBits
VkExternalSemaphoreHandleTypeFlagBits :: VkFlags -> VkExternalSemaphoreHandleTypeFlagBits
-- | VkExternalSemaphoreFeatureFlagBits - Bitfield describing features of
-- an external semaphore handle type
--
-- See Also
--
-- VkExternalSemaphoreFeatureFlags
newtype VkExternalSemaphoreFeatureFlagBits
VkExternalSemaphoreFeatureFlagBits :: VkFlags -> VkExternalSemaphoreFeatureFlagBits
-- | VK_EXTERNAL_SEMAPHORE_FEATURE_EXPORTABLE_BIT specifies that
-- handles of this type can be exported from Vulkan semaphore
-- objects.
-- | VK_EXTERNAL_SEMAPHORE_FEATURE_IMPORTABLE_BIT specifies that
-- handles of this type can be imported as Vulkan semaphore
-- objects.
-- | vkGetPhysicalDeviceExternalSemaphoreProperties - Function for querying
-- external semaphore handle capabilities.
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the semaphore capabilities.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pExternalSemaphoreInfo must be a valid pointer to
-- a valid VkPhysicalDeviceExternalSemaphoreInfo structure
-- - pExternalSemaphoreProperties must be a valid
-- pointer to a VkExternalSemaphoreProperties structure
--
--
-- See Also
--
-- VkExternalSemaphoreProperties, VkPhysicalDevice,
-- VkPhysicalDeviceExternalSemaphoreInfo
vkGetPhysicalDeviceExternalSemaphoreProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalSemaphoreInfo" ::: Ptr VkPhysicalDeviceExternalSemaphoreInfo) -> ("pExternalSemaphoreProperties" ::: Ptr VkExternalSemaphoreProperties) -> IO ()
-- | VkPhysicalDeviceExternalSemaphoreInfo - Structure specifying semaphore
-- creation parameters.
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_SEMAPHORE_INFO
--
--
--
--
-- See Also
--
-- VkExternalSemaphoreHandleTypeFlagBits, VkStructureType,
-- vkGetPhysicalDeviceExternalSemaphoreProperties,
-- vkGetPhysicalDeviceExternalSemaphorePropertiesKHR
data VkPhysicalDeviceExternalSemaphoreInfo
VkPhysicalDeviceExternalSemaphoreInfo :: VkStructureType -> Ptr () -> VkExternalSemaphoreHandleTypeFlagBits -> VkPhysicalDeviceExternalSemaphoreInfo
-- | sType is the type of this structure
[$sel:vkSType:VkPhysicalDeviceExternalSemaphoreInfo] :: VkPhysicalDeviceExternalSemaphoreInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceExternalSemaphoreInfo] :: VkPhysicalDeviceExternalSemaphoreInfo -> Ptr ()
-- | handleType is a VkExternalSemaphoreHandleTypeFlagBits
-- value specifying the external semaphore handle type for which
-- capabilities will be returned.
[$sel:vkHandleType:VkPhysicalDeviceExternalSemaphoreInfo] :: VkPhysicalDeviceExternalSemaphoreInfo -> VkExternalSemaphoreHandleTypeFlagBits
-- | VkExternalSemaphoreProperties - Structure describing supported
-- external semaphore handle features
--
-- Description
--
-- If handleType is not supported by the implementation, then
-- VkExternalSemaphoreProperties::externalSemaphoreFeatures
-- will be set to zero.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_SEMAPHORE_PROPERTIES
--
--
--
--
-- See Also
--
-- VkExternalSemaphoreFeatureFlags,
-- VkExternalSemaphoreHandleTypeFlags, VkStructureType,
-- vkGetPhysicalDeviceExternalSemaphoreProperties,
-- vkGetPhysicalDeviceExternalSemaphorePropertiesKHR
data VkExternalSemaphoreProperties
VkExternalSemaphoreProperties :: VkStructureType -> Ptr () -> VkExternalSemaphoreHandleTypeFlags -> VkExternalSemaphoreHandleTypeFlags -> VkExternalSemaphoreFeatureFlags -> VkExternalSemaphoreProperties
[$sel:vkSType:VkExternalSemaphoreProperties] :: VkExternalSemaphoreProperties -> VkStructureType
[$sel:vkPNext:VkExternalSemaphoreProperties] :: VkExternalSemaphoreProperties -> Ptr ()
-- | exportFromImportedHandleTypes is a bitmask of
-- VkExternalSemaphoreHandleTypeFlagBits specifying which types of
-- imported handle handleType can be exported from.
[$sel:vkExportFromImportedHandleTypes:VkExternalSemaphoreProperties] :: VkExternalSemaphoreProperties -> VkExternalSemaphoreHandleTypeFlags
-- | compatibleHandleTypes is a bitmask of
-- VkExternalSemaphoreHandleTypeFlagBits specifying handle types
-- which can be specified at the same time as handleType
-- when creating a semaphore.
[$sel:vkCompatibleHandleTypes:VkExternalSemaphoreProperties] :: VkExternalSemaphoreProperties -> VkExternalSemaphoreHandleTypeFlags
-- | externalSemaphoreFeatures is a bitmask of
-- VkExternalSemaphoreFeatureFlagBits describing the features of
-- handleType.
[$sel:vkExternalSemaphoreFeatures:VkExternalSemaphoreProperties] :: VkExternalSemaphoreProperties -> VkExternalSemaphoreFeatureFlags
-- | VkExternalSemaphoreHandleTypeFlags - Bitmask of
-- VkExternalSemaphoreHandleTypeFlagBits
--
-- Description
--
-- VkExternalSemaphoreHandleTypeFlags is a bitmask type for
-- setting a mask of zero or more
-- VkExternalSemaphoreHandleTypeFlagBits.
--
-- See Also
--
-- VkExportSemaphoreCreateInfo,
-- VkExternalSemaphoreHandleTypeFlagBits,
-- VkExternalSemaphoreProperties
type VkExternalSemaphoreHandleTypeFlags = VkExternalSemaphoreHandleTypeFlagBits
-- | VkExternalSemaphoreFeatureFlags - Bitmask of
-- VkExternalSemaphoreFeatureFlagBitsKHR
--
-- Description
--
-- VkExternalSemaphoreFeatureFlags is a bitmask type for setting
-- a mask of zero or more VkExternalSemaphoreFeatureFlagBits.
--
-- See Also
--
-- VkExternalSemaphoreFeatureFlagBits,
-- VkExternalSemaphoreProperties
type VkExternalSemaphoreFeatureFlags = VkExternalSemaphoreFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkPhysicalDeviceExternalSemaphoreInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkPhysicalDeviceExternalSemaphoreInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkPhysicalDeviceExternalSemaphoreInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore_capabilities.VkExternalSemaphoreHandleTypeFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_capabilities
vkGetPhysicalDeviceExternalSemaphorePropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalSemaphoreInfo" ::: Ptr VkPhysicalDeviceExternalSemaphoreInfo) -> ("pExternalSemaphoreProperties" ::: Ptr VkExternalSemaphoreProperties) -> IO ()
type VkExternalSemaphoreHandleTypeFlagBitsKHR = VkExternalSemaphoreHandleTypeFlagBits
type VkExternalSemaphoreFeatureFlagBitsKHR = VkExternalSemaphoreFeatureFlagBits
type VkExternalSemaphoreHandleTypeFlagsKHR = VkExternalSemaphoreHandleTypeFlags
type VkExternalSemaphoreFeatureFlagsKHR = VkExternalSemaphoreFeatureFlags
type VkPhysicalDeviceExternalSemaphoreInfoKHR = VkPhysicalDeviceExternalSemaphoreInfo
type VkExternalSemaphorePropertiesKHR = VkExternalSemaphoreProperties
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore
-- | VkSemaphoreImportFlagBits - Bitmask specifying additional parameters
-- of semaphore payload import
--
-- Description
--
-- These bits have the following meanings:
--
--
-- - VK_SEMAPHORE_IMPORT_TEMPORARY_BIT specifies that the
-- semaphore payload will be imported only temporarily, as described in
-- Importing Semaphore Payloads, regardless of the permanence of
-- handleType.
--
--
-- See Also
--
-- VkSemaphoreImportFlags
newtype VkSemaphoreImportFlagBits
VkSemaphoreImportFlagBits :: VkFlags -> VkSemaphoreImportFlagBits
-- | VkExportSemaphoreCreateInfo - Structure specifying handle types that
-- can be exported from a semaphore
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXPORT_SEMAPHORE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkExternalSemaphoreHandleTypeFlags, VkStructureType
data VkExportSemaphoreCreateInfo
VkExportSemaphoreCreateInfo :: VkStructureType -> Ptr () -> VkExternalSemaphoreHandleTypeFlags -> VkExportSemaphoreCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkExportSemaphoreCreateInfo] :: VkExportSemaphoreCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExportSemaphoreCreateInfo] :: VkExportSemaphoreCreateInfo -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalSemaphoreHandleTypeFlagBits specifying one or more
-- semaphore handle types the application can export from the
-- resulting semaphore. The application can request multiple
-- handle types for the same semaphore.
[$sel:vkHandleTypes:VkExportSemaphoreCreateInfo] :: VkExportSemaphoreCreateInfo -> VkExternalSemaphoreHandleTypeFlags
-- | VkSemaphoreImportFlags - Bitmask of VkSemaphoreImportFlagBits
--
-- Description
--
-- VkSemaphoreImportFlags is a bitmask type for setting a mask
-- of zero or more VkSemaphoreImportFlagBits.
--
-- See Also
--
-- VkImportSemaphoreFdInfoKHR,
-- VkImportSemaphoreWin32HandleInfoKHR,
-- VkSemaphoreImportFlagBits
type VkSemaphoreImportFlags = VkSemaphoreImportFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkExportSemaphoreCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkExportSemaphoreCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkExportSemaphoreCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_semaphore.VkSemaphoreImportFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_semaphore
type VkSemaphoreImportFlagBitsKHR = VkSemaphoreImportFlagBits
type VkSemaphoreImportFlagsKHR = VkSemaphoreImportFlags
type VkExportSemaphoreCreateInfoKHR = VkExportSemaphoreCreateInfo
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities
-- | VkExternalFenceHandleTypeFlagBits - Bitmask of valid external fence
-- handle types
--
-- Description
--
--
-- - VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_FD_BIT specifies a
-- POSIX file descriptor handle that has only limited valid usage outside
-- of Vulkan and other compatible APIs. It must be compatible with
-- the POSIX system calls dup, dup2, close,
-- and the non-standard system call dup3. Additionally, it
-- must be transportable over a socket using an
-- SCM_RIGHTS control message. It owns a reference to the
-- underlying synchronization primitive represented by its Vulkan fence
-- object.
--
--
--
-- - VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_BIT specifies
-- an NT handle that has only limited valid usage outside of Vulkan and
-- other compatible APIs. It must be compatible with the functions
-- DuplicateHandle, CloseHandle,
-- CompareObjectHandles, GetHandleInformation, and
-- SetHandleInformation. It owns a reference to the underlying
-- synchronization primitive represented by its Vulkan fence object.
-- - VK_EXTERNAL_FENCE_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT
-- specifies a global share handle that has only limited valid usage
-- outside of Vulkan and other compatible APIs. It is not compatible with
-- any native APIs. It does not own a reference to the underlying
-- synchronization primitive represented by its Vulkan fence object, and
-- will therefore become invalid when all Vulkan fence objects associated
-- with it are destroyed.
-- - VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT specifies a
-- POSIX file descriptor handle to a Linux Sync File or Android Fence. It
-- can be used with any native API accepting a valid sync file or fence
-- as input. It owns a reference to the underlying synchronization
-- primitive associated with the file descriptor. Implementations which
-- support importing this handle type must accept any type of sync
-- or fence FD supported by the native system they are running on.
--
--
-- Some external fence handle types can only be shared within the same
-- underlying physical device and/or the same driver version, as defined
-- in the following table:
--
--
-- +----------------------+----------------------+-----------------------+
-- | Handle type | @VkPhysicalDeviceIDP | @VkPhysicalDeviceIDPr |
-- | | roperties@::@driverU | operties@::@deviceUUI |
-- | | UID@ | D@ |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_FENCE_H | Must match | Must match |
-- | ANDLE_TYPE_OPAQUE_FD | | |
-- | _BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_FENCE_H | Must match | Must match |
-- | ANDLE_TYPE_OPAQUE_WI | | |
-- | N32_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_FENCE_H | Must match | Must match |
-- | ANDLE_TYPE_OPAQUE_WI | | |
-- | N32_KMT_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_FENCE_H | No restriction | No restriction |
-- | ANDLE_TYPE_SYNC_FD_B | | |
-- | IT@ | | |
-- +----------------------+----------------------+-----------------------+
--
-- External fence handle types compatibility
--
--
-- See Also
--
-- VkExternalFenceHandleTypeFlags, VkFenceGetFdInfoKHR,
-- VkFenceGetWin32HandleInfoKHR, VkImportFenceFdInfoKHR,
-- VkImportFenceWin32HandleInfoKHR,
-- VkPhysicalDeviceExternalFenceInfo
newtype VkExternalFenceHandleTypeFlagBits
VkExternalFenceHandleTypeFlagBits :: VkFlags -> VkExternalFenceHandleTypeFlagBits
-- | VkExternalFenceFeatureFlagBits - Bitfield describing features of an
-- external fence handle type
--
-- See Also
--
-- VkExternalFenceFeatureFlags
newtype VkExternalFenceFeatureFlagBits
VkExternalFenceFeatureFlagBits :: VkFlags -> VkExternalFenceFeatureFlagBits
-- | VK_EXTERNAL_FENCE_FEATURE_EXPORTABLE_BIT specifies handles of
-- this type can be exported from Vulkan fence objects.
-- | VK_EXTERNAL_FENCE_FEATURE_IMPORTABLE_BIT specifies handles of
-- this type can be imported to Vulkan fence objects.
-- | vkGetPhysicalDeviceExternalFenceProperties - Function for querying
-- external fence handle capabilities.
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the fence capabilities.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pExternalFenceInfo must be a valid pointer to a
-- valid VkPhysicalDeviceExternalFenceInfo structure
-- - pExternalFenceProperties must be a valid pointer
-- to a VkExternalFenceProperties structure
--
--
-- See Also
--
-- VkExternalFenceProperties, VkPhysicalDevice,
-- VkPhysicalDeviceExternalFenceInfo
vkGetPhysicalDeviceExternalFenceProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalFenceInfo" ::: Ptr VkPhysicalDeviceExternalFenceInfo) -> ("pExternalFenceProperties" ::: Ptr VkExternalFenceProperties) -> IO ()
-- | VkPhysicalDeviceExternalFenceInfo - Structure specifying fence
-- creation parameters.
--
-- Description
--
-- Note
--
-- Handles of type VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT
-- generated by the implementation may represent either Linux Sync Files
-- or Android Fences at the implementation’s discretion. Applications
-- should only use operations defined for both types of file
-- descriptors, unless they know via means external to Vulkan the type of
-- the file descriptor, or are prepared to deal with the system-defined
-- operation failures resulting from using the wrong type.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_FENCE_INFO
--
--
--
--
-- See Also
--
-- VkExternalFenceHandleTypeFlagBits, VkStructureType,
-- vkGetPhysicalDeviceExternalFenceProperties,
-- vkGetPhysicalDeviceExternalFencePropertiesKHR
data VkPhysicalDeviceExternalFenceInfo
VkPhysicalDeviceExternalFenceInfo :: VkStructureType -> Ptr () -> VkExternalFenceHandleTypeFlagBits -> VkPhysicalDeviceExternalFenceInfo
-- | sType is the type of this structure
[$sel:vkSType:VkPhysicalDeviceExternalFenceInfo] :: VkPhysicalDeviceExternalFenceInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceExternalFenceInfo] :: VkPhysicalDeviceExternalFenceInfo -> Ptr ()
-- | handleType is a VkExternalFenceHandleTypeFlagBits
-- value indicating an external fence handle type for which capabilities
-- will be returned.
[$sel:vkHandleType:VkPhysicalDeviceExternalFenceInfo] :: VkPhysicalDeviceExternalFenceInfo -> VkExternalFenceHandleTypeFlagBits
-- | VkExternalFenceProperties - Structure describing supported external
-- fence handle features
--
-- Description
--
-- If handleType is not supported by the implementation, then
-- VkExternalFenceProperties::externalFenceFeatures will
-- be set to zero.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_FENCE_PROPERTIES
--
--
--
--
-- See Also
--
-- VkExternalFenceFeatureFlags,
-- VkExternalFenceHandleTypeFlags, VkStructureType,
-- vkGetPhysicalDeviceExternalFenceProperties,
-- vkGetPhysicalDeviceExternalFencePropertiesKHR
data VkExternalFenceProperties
VkExternalFenceProperties :: VkStructureType -> Ptr () -> VkExternalFenceHandleTypeFlags -> VkExternalFenceHandleTypeFlags -> VkExternalFenceFeatureFlags -> VkExternalFenceProperties
[$sel:vkSType:VkExternalFenceProperties] :: VkExternalFenceProperties -> VkStructureType
[$sel:vkPNext:VkExternalFenceProperties] :: VkExternalFenceProperties -> Ptr ()
-- | exportFromImportedHandleTypes is a bitmask of
-- VkExternalFenceHandleTypeFlagBits indicating which types of
-- imported handle handleType can be exported from.
[$sel:vkExportFromImportedHandleTypes:VkExternalFenceProperties] :: VkExternalFenceProperties -> VkExternalFenceHandleTypeFlags
-- | compatibleHandleTypes is a bitmask of
-- VkExternalFenceHandleTypeFlagBits specifying handle types which
-- can be specified at the same time as handleType when
-- creating a fence.
[$sel:vkCompatibleHandleTypes:VkExternalFenceProperties] :: VkExternalFenceProperties -> VkExternalFenceHandleTypeFlags
-- | externalFenceFeatures is a bitmask of
-- VkExternalFenceFeatureFlagBits indicating the features of
-- handleType.
[$sel:vkExternalFenceFeatures:VkExternalFenceProperties] :: VkExternalFenceProperties -> VkExternalFenceFeatureFlags
-- | VkExternalFenceHandleTypeFlags - Bitmask of
-- VkExternalFenceHandleTypeFlagBits
--
-- Description
--
-- VkExternalFenceHandleTypeFlags is a bitmask type for setting
-- a mask of zero or more VkExternalFenceHandleTypeFlagBits.
--
-- See Also
--
-- VkExportFenceCreateInfo,
-- VkExternalFenceHandleTypeFlagBits,
-- VkExternalFenceProperties
type VkExternalFenceHandleTypeFlags = VkExternalFenceHandleTypeFlagBits
-- | VkExternalFenceFeatureFlags - Bitmask of
-- VkExternalFenceFeatureFlagBits
--
-- Description
--
-- VkExternalFenceFeatureFlags is a bitmask type for setting a
-- mask of zero or more VkExternalFenceFeatureFlagBits.
--
-- See Also
--
-- VkExternalFenceFeatureFlagBits,
-- VkExternalFenceProperties
type VkExternalFenceFeatureFlags = VkExternalFenceFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkPhysicalDeviceExternalFenceInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkPhysicalDeviceExternalFenceInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkPhysicalDeviceExternalFenceInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence_capabilities.VkExternalFenceHandleTypeFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_fence_capabilities
vkGetPhysicalDeviceExternalFencePropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalFenceInfo" ::: Ptr VkPhysicalDeviceExternalFenceInfo) -> ("pExternalFenceProperties" ::: Ptr VkExternalFenceProperties) -> IO ()
type VkExternalFenceHandleTypeFlagBitsKHR = VkExternalFenceHandleTypeFlagBits
type VkExternalFenceFeatureFlagBitsKHR = VkExternalFenceFeatureFlagBits
type VkExternalFenceHandleTypeFlagsKHR = VkExternalFenceHandleTypeFlags
type VkExternalFenceFeatureFlagsKHR = VkExternalFenceFeatureFlags
type VkPhysicalDeviceExternalFenceInfoKHR = VkPhysicalDeviceExternalFenceInfo
type VkExternalFencePropertiesKHR = VkExternalFenceProperties
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence
-- | VkFenceImportFlagBits - Bitmask specifying additional parameters of
-- fence payload import
--
-- See Also
--
-- VkFenceImportFlags
newtype VkFenceImportFlagBits
VkFenceImportFlagBits :: VkFlags -> VkFenceImportFlagBits
-- | VK_FENCE_IMPORT_TEMPORARY_BIT specifies that the fence
-- payload will be imported only temporarily, as described in
-- Importing Fence Payloads, regardless of the permanence of
-- handleType.
-- | VkExportFenceCreateInfo - Structure specifying handle types that can
-- be exported from a fence
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXPORT_FENCE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkExternalFenceHandleTypeFlags, VkStructureType
data VkExportFenceCreateInfo
VkExportFenceCreateInfo :: VkStructureType -> Ptr () -> VkExternalFenceHandleTypeFlags -> VkExportFenceCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkExportFenceCreateInfo] :: VkExportFenceCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExportFenceCreateInfo] :: VkExportFenceCreateInfo -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalFenceHandleTypeFlagBits specifying one or more fence
-- handle types the application can export from the resulting
-- fence. The application can request multiple handle types for
-- the same fence.
[$sel:vkHandleTypes:VkExportFenceCreateInfo] :: VkExportFenceCreateInfo -> VkExternalFenceHandleTypeFlags
-- | VkFenceImportFlags - Bitmask of VkFenceImportFlagBits
--
-- Description
--
-- VkFenceImportFlags is a bitmask type for setting a mask of
-- zero or more VkFenceImportFlagBits.
--
-- See Also
--
-- VkFenceImportFlagBits, VkImportFenceFdInfoKHR,
-- VkImportFenceWin32HandleInfoKHR
type VkFenceImportFlags = VkFenceImportFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkExportFenceCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkExportFenceCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkExportFenceCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_fence.VkFenceImportFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_fence
type VkFenceImportFlagBitsKHR = VkFenceImportFlagBits
type VkFenceImportFlagsKHR = VkFenceImportFlags
type VkExportFenceCreateInfoKHR = VkExportFenceCreateInfo
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation
-- | VK_MEMORY_HEAP_MULTI_INSTANCE_BIT specifies that in a logical
-- device representing more than one physical device, there is a
-- per-physical device instance of the heap memory. By default, an
-- allocation from such a heap will be replicated to each physical
-- device’s instance of the heap.
type VK_MAX_DEVICE_GROUP_SIZE = 32
-- | vkEnumeratePhysicalDeviceGroups - Enumerates groups of physical
-- devices that can be used to create a single logical device
--
-- Parameters
--
--
-- - instance is a handle to a Vulkan instance previously
-- created with vkCreateInstance.
--
--
--
-- - pPhysicalDeviceGroupCount is a pointer to an integer
-- related to the number of device groups available or queried, as
-- described below.
-- - pPhysicalDeviceGroupProperties is either NULL or
-- a pointer to an array of VkPhysicalDeviceGroupProperties
-- structures.
--
--
-- Description
--
-- If pPhysicalDeviceGroupProperties is NULL, then the
-- number of device groups available is returned in
-- pPhysicalDeviceGroupCount. Otherwise,
-- pPhysicalDeviceGroupCount must point to a variable set
-- by the user to the number of elements in the
-- pPhysicalDeviceGroupProperties array, and on return the
-- variable is overwritten with the number of structures actually written
-- to pPhysicalDeviceGroupProperties. If
-- pPhysicalDeviceGroupCount is less than the number of device
-- groups available, at most pPhysicalDeviceGroupCount
-- structures will be written. If pPhysicalDeviceGroupCount is
-- smaller than the number of device groups available,
-- VK_INCOMPLETE will be returned instead of
-- VK_SUCCESS, to indicate that not all the available device
-- groups were returned.
--
-- Every physical device must be in exactly one device group.
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - pPhysicalDeviceGroupCount must be a valid pointer
-- to a uint32_t value
-- - If the value referenced by pPhysicalDeviceGroupCount is
-- not 0, and pPhysicalDeviceGroupProperties is not
-- NULL, pPhysicalDeviceGroupProperties must be
-- a valid pointer to an array of pPhysicalDeviceGroupCount
-- VkPhysicalDeviceGroupProperties structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkInstance, VkPhysicalDeviceGroupProperties
vkEnumeratePhysicalDeviceGroups :: ("instance" ::: VkInstance) -> ("pPhysicalDeviceGroupCount" ::: Ptr Word32) -> ("pPhysicalDeviceGroupProperties" ::: Ptr VkPhysicalDeviceGroupProperties) -> IO VkResult
-- | VkPhysicalDeviceGroupProperties - Structure specifying physical device
-- group properties
--
-- Description
--
-- See Also
--
-- VkBool32, VkPhysicalDevice, VkStructureType,
-- vkEnumeratePhysicalDeviceGroups,
-- vkEnumeratePhysicalDeviceGroupsKHR
data VkPhysicalDeviceGroupProperties
VkPhysicalDeviceGroupProperties :: VkStructureType -> Ptr () -> Word32 -> Vector VK_MAX_DEVICE_GROUP_SIZE VkPhysicalDevice -> VkBool32 -> VkPhysicalDeviceGroupProperties
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceGroupProperties] :: VkPhysicalDeviceGroupProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceGroupProperties] :: VkPhysicalDeviceGroupProperties -> Ptr ()
-- | physicalDeviceCount is the number of physical devices in the
-- group.
[$sel:vkPhysicalDeviceCount:VkPhysicalDeviceGroupProperties] :: VkPhysicalDeviceGroupProperties -> Word32
-- | physicalDevices is an array of physical device handles
-- representing all physical devices in the group. The first
-- physicalDeviceCount elements of the array will be valid.
[$sel:vkPhysicalDevices:VkPhysicalDeviceGroupProperties] :: VkPhysicalDeviceGroupProperties -> Vector VK_MAX_DEVICE_GROUP_SIZE VkPhysicalDevice
-- | subsetAllocation specifies whether logical devices created
-- from the group support allocating device memory on a subset of
-- devices, via the deviceMask member of the
-- VkMemoryAllocateFlagsInfo. If this is VK_FALSE, then
-- all device memory allocations are made across all physical devices in
-- the group. If physicalDeviceCount is 1, then
-- subsetAllocation must be VK_FALSE.
[$sel:vkSubsetAllocation:VkPhysicalDeviceGroupProperties] :: VkPhysicalDeviceGroupProperties -> VkBool32
-- | VkDeviceGroupDeviceCreateInfo - Create a logical device from multiple
-- physical devices
--
-- Description
--
-- The elements of the pPhysicalDevices array are an ordered
-- list of the physical devices that the logical device represents. These
-- must be a subset of a single device group, and need not be in
-- the same order as they were enumerated. The order of the physical
-- devices in the pPhysicalDevices array determines the
-- device index of each physical device, with element i being
-- assigned a device index of i. Certain commands and structures refer to
-- one or more physical devices by using device indices or device
-- masks formed using device indices.
--
-- A logical device created without using
-- VkDeviceGroupDeviceCreateInfo, or with
-- physicalDeviceCount equal to zero, is equivalent to a
-- physicalDeviceCount of one and pPhysicalDevices
-- pointing to the physicalDevice parameter to
-- vkCreateDevice. In particular, the device index of that
-- physical device is zero.
--
-- Valid Usage
--
--
-- - Each element of pPhysicalDevices must be
-- unique
--
--
--
-- - All elements of pPhysicalDevices must be in the
-- same device group as enumerated by
-- vkEnumeratePhysicalDeviceGroups
-- - If physicalDeviceCount is not 0, the
-- physicalDevice parameter of vkCreateDevice must
-- be an element of pPhysicalDevices.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_DEVICE_CREATE_INFO
--
--
--
-- - If physicalDeviceCount is not 0,
-- pPhysicalDevices must be a valid pointer to an array
-- of physicalDeviceCount valid VkPhysicalDevice
-- handles
--
--
-- See Also
--
-- VkPhysicalDevice, VkStructureType
data VkDeviceGroupDeviceCreateInfo
VkDeviceGroupDeviceCreateInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr VkPhysicalDevice -> VkDeviceGroupDeviceCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupDeviceCreateInfo] :: VkDeviceGroupDeviceCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupDeviceCreateInfo] :: VkDeviceGroupDeviceCreateInfo -> Ptr ()
-- | physicalDeviceCount is the number of elements in the
-- pPhysicalDevices array.
[$sel:vkPhysicalDeviceCount:VkDeviceGroupDeviceCreateInfo] :: VkDeviceGroupDeviceCreateInfo -> Word32
-- | pPhysicalDevices is an array of physical device handles
-- belonging to the same device group.
[$sel:vkPPhysicalDevices:VkDeviceGroupDeviceCreateInfo] :: VkDeviceGroupDeviceCreateInfo -> Ptr VkPhysicalDevice
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkDeviceGroupDeviceCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkDeviceGroupDeviceCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkPhysicalDeviceGroupProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkPhysicalDeviceGroupProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkDeviceGroupDeviceCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_creation.VkPhysicalDeviceGroupProperties
module Graphics.Vulkan.Extensions.VK_KHR_device_group_creation
vkEnumeratePhysicalDeviceGroupsKHR :: ("instance" ::: VkInstance) -> ("pPhysicalDeviceGroupCount" ::: Ptr Word32) -> ("pPhysicalDeviceGroupProperties" ::: Ptr VkPhysicalDeviceGroupProperties) -> IO VkResult
type VkPhysicalDeviceGroupPropertiesKHR = VkPhysicalDeviceGroupProperties
type VkDeviceGroupDeviceCreateInfoKHR = VkDeviceGroupDeviceCreateInfo
type VK_MAX_DEVICE_GROUP_SIZE_KHR = VK_MAX_DEVICE_GROUP_SIZE
module Graphics.Vulkan.Core10.Shader
-- | VkShaderModuleCreateFlags - Reserved for future use
--
-- Description
--
-- VkShaderModuleCreateFlags is a bitmask type for setting a
-- mask, but is currently reserved for future use.
--
-- See Also
--
-- VkShaderModuleCreateInfo
newtype VkShaderModuleCreateFlags
VkShaderModuleCreateFlags :: VkFlags -> VkShaderModuleCreateFlags
-- | VkShaderModule - Opaque handle to a shader module object
--
-- Description
--
-- See Also
--
-- VkPipelineShaderStageCreateInfo, vkCreateShaderModule,
-- vkDestroyShaderModule
type VkShaderModule = Ptr VkShaderModule_T
-- | vkCreateShaderModule - Creates a new shader module object
--
-- Parameters
--
--
-- - device is the logical device that creates the shader
-- module.
--
--
--
-- - pCreateInfo parameter is a pointer to an instance of the
-- VkShaderModuleCreateInfo structure.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pShaderModule points to a VkShaderModule handle
-- in which the resulting shader module object is returned.
--
--
-- Description
--
-- Once a shader module has been created, any entry points it contains
-- can be used in pipeline shader stages as described in
-- Compute Pipelines and Graphics Pipelines.
--
-- If the shader stage fails to compile
-- VK_ERROR_INVALID_SHADER_NV will be generated and the compile
-- log will be reported back to the application by
-- {html_spec_relative}#VK_EXT_debug_report if enabled.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkShaderModuleCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pShaderModule must be a valid pointer to a
-- VkShaderModule handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkShaderModule,
-- VkShaderModuleCreateInfo
vkCreateShaderModule :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkShaderModuleCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pShaderModule" ::: Ptr VkShaderModule) -> IO VkResult
-- | vkDestroyShaderModule - Destroy a shader module module
--
-- Parameters
--
--
-- - device is the logical device that destroys the shader
-- module.
--
--
--
-- - shaderModule is the handle of the shader module to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- A shader module can be destroyed while pipelines created using
-- its shaders are still in use.
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- shaderModule was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- shaderModule was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If shaderModule is not VK_NULL_HANDLE,
-- shaderModule must be a valid VkShaderModule
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If shaderModule is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to shaderModule must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkShaderModule
vkDestroyShaderModule :: ("device" ::: VkDevice) -> ("shaderModule" ::: VkShaderModule) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkShaderModuleCreateInfo - Structure specifying parameters of a newly
-- created shader module
--
-- Description
--
-- Valid Usage
--
--
-- - codeSize must be greater than 0
--
--
--
-- - If pCode points to SPIR-V code, codeSize
-- must be a multiple of 4
-- - pCode must point to either valid SPIR-V code,
-- formatted and packed as described by the Khronos SPIR-V
-- Specification or valid GLSL code which must be written to
-- the GL_KHR_vulkan_glsl extension specification
-- - If pCode points to SPIR-V code, that code must
-- adhere to the validation rules described by the Validation Rules
-- within a Module section of the SPIR-V Environment
-- appendix
-- - If pCode points to GLSL code, it must be valid
-- GLSL code written to the GL_KHR_vulkan_glsl GLSL extension
-- specification
-- - pCode must declare the Shader capability
-- for SPIR-V code
-- - pCode must not declare any capability that is not
-- supported by the API, as described by the Capabilities section
-- of the SPIR-V Environment appendix
-- - If pCode declares any of the capabilities listed as
-- optional in the SPIR-V Environment appendix, the
-- corresponding feature(s) must be enabled.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkShaderModuleCreateFlags, VkStructureType,
-- vkCreateShaderModule
data VkShaderModuleCreateInfo
VkShaderModuleCreateInfo :: VkStructureType -> Ptr () -> VkShaderModuleCreateFlags -> CSize -> Ptr Word32 -> VkShaderModuleCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkShaderModuleCreateInfo] :: VkShaderModuleCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkShaderModuleCreateInfo] :: VkShaderModuleCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkShaderModuleCreateInfo] :: VkShaderModuleCreateInfo -> VkShaderModuleCreateFlags
-- | codeSize is the size, in bytes, of the code pointed to by
-- pCode.
[$sel:vkCodeSize:VkShaderModuleCreateInfo] :: VkShaderModuleCreateInfo -> CSize
-- | pCode points to code that is used to create the shader
-- module. The type and format of the code is determined from the content
-- of the memory addressed by pCode.
[$sel:vkPCode:VkShaderModuleCreateInfo] :: VkShaderModuleCreateInfo -> Ptr Word32
instance GHC.Show.Show Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Shader.VkShaderModuleCreateFlags
module Graphics.Vulkan.Core10.Queue
-- | VkPipelineStageFlagBits - Bitmask specifying pipeline stages
--
-- Description
--
--
-- - VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT specifies the stage of
-- the pipeline where any commands are initially received by the
-- queue.
--
--
--
-- - VK_PIPELINE_STAGE_COMMAND_PROCESS_BIT_NVX specifies the
-- stage of the pipeline where device-side generation of commands via
-- vkCmdProcessCommandsNVX is handled.
-- - VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT specifies the stage
-- of the pipeline where Draw/DispatchIndirect data structures are
-- consumed. This stage also includes reading commands written by
-- vkCmdProcessCommandsNVX.
-- - VK_PIPELINE_STAGE_VERTEX_INPUT_BIT specifies the stage of
-- the pipeline where vertex and index buffers are consumed.
-- - VK_PIPELINE_STAGE_VERTEX_SHADER_BIT specifies the vertex
-- shader stage.
-- - VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT
-- specifies the tessellation control shader stage.
-- - VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- specifies the tessellation evaluation shader stage.
-- - VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT specifies the
-- geometry shader stage.
-- - VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT specifies the
-- fragment shader stage.
-- - VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT specifies the
-- stage of the pipeline where early fragment tests (depth and stencil
-- tests before fragment shading) are performed. This stage also includes
-- subpass load operations for framebuffer attachments with a
-- depth/stencil format.
-- - VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT specifies the
-- stage of the pipeline where late fragment tests (depth and stencil
-- tests after fragment shading) are performed. This stage also includes
-- subpass store operations for framebuffer attachments with a
-- depth/stencil format.
-- - VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT specifies
-- the stage of the pipeline after blending where the final color values
-- are output from the pipeline. This stage also includes subpass load
-- and store operations and multisample resolve operations for
-- framebuffer attachments with a color format.
-- - VK_PIPELINE_STAGE_TRANSFER_BIT specifies the execution of
-- copy commands. This includes the operations resulting from all copy
-- commands, clear commands (with the exception of
-- vkCmdClearAttachments), and
-- vkCmdCopyQueryPoolResults.
-- - VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT specifies the
-- execution of a compute shader.
-- - VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT specifies the final
-- stage in the pipeline where operations generated by all commands
-- complete execution.
-- - VK_PIPELINE_STAGE_HOST_BIT specifies a pseudo-stage
-- indicating execution on the host of reads/writes of device memory.
-- This stage is not invoked by any commands recorded in a command
-- buffer.
-- - VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT specifies the
-- execution of all graphics pipeline stages, and is equivalent to the
-- logical OR
-- of:
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT
VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT
VK_PIPELINE_STAGE_VERTEX_INPUT_BIT
VK_PIPELINE_STAGE_VERTEX_SHADER_BIT
VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT
VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT
VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT
VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT
VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT
-- - VK_PIPELINE_STAGE_ALL_COMMANDS_BIT is equivalent to the
-- logical OR of every other pipeline stage flag that is supported on the
-- queue it is used with.
--
--
-- Note
--
-- An execution dependency with only
-- VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT in the destination stage
-- mask will only prevent that stage from executing in subsequently
-- submitted commands. As this stage does not perform any actual
-- execution, this is not observable - in effect, it does not delay
-- processing of subsequent commands. Similarly an execution dependency
-- with only VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT in the source
-- stage mask will effectively not wait for any prior commands to
-- complete.
--
-- When defining a memory dependency, using only
-- VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT or
-- VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT would never make any
-- accesses available and/or visible because these stages do not access
-- memory.
--
-- VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT and
-- VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT are useful for
-- accomplishing layout transitions and queue ownership operations when
-- the required execution dependency is satisfied by other means - for
-- example, semaphore operations between queues.
--
-- See Also
--
-- VkPipelineStageFlags, vkCmdWriteBufferMarkerAMD,
-- vkCmdWriteTimestamp
newtype VkPipelineStageFlagBits
VkPipelineStageFlagBits :: VkFlags -> VkPipelineStageFlagBits
-- | VkQueue - Opaque handle to a queue object
--
-- Description
--
-- See Also
--
-- vkGetDeviceQueue, vkGetDeviceQueue2,
-- vkQueueBeginDebugUtilsLabelEXT, vkQueueBindSparse,
-- vkQueueEndDebugUtilsLabelEXT,
-- vkQueueInsertDebugUtilsLabelEXT, vkQueuePresentKHR,
-- vkQueueSubmit, vkQueueWaitIdle
type VkQueue = Ptr VkQueue_T
-- | VkCommandBuffer - Opaque handle to a command buffer object
--
-- Description
--
-- See Also
--
-- VkCmdProcessCommandsInfoNVX, VkSubmitInfo,
-- vkAllocateCommandBuffers, vkBeginCommandBuffer,
-- vkCmdBeginDebugUtilsLabelEXT, vkCmdBeginQuery,
-- vkCmdBeginRenderPass, vkCmdBindDescriptorSets,
-- vkCmdBindIndexBuffer, vkCmdBindPipeline,
-- vkCmdBindVertexBuffers, vkCmdBlitImage,
-- vkCmdClearAttachments, vkCmdClearColorImage,
-- vkCmdClearDepthStencilImage, vkCmdCopyBuffer,
-- vkCmdCopyBufferToImage, vkCmdCopyImage,
-- vkCmdCopyImageToBuffer, vkCmdCopyQueryPoolResults,
-- vkCmdDebugMarkerBeginEXT, vkCmdDebugMarkerEndEXT,
-- vkCmdDebugMarkerInsertEXT, vkCmdDispatch,
-- vkCmdDispatchBase, vkCmdDispatchBaseKHR,
-- vkCmdDispatchIndirect, vkCmdDraw,
-- vkCmdDrawIndexed, vkCmdDrawIndexedIndirect,
-- vkCmdDrawIndexedIndirectCountAMD, vkCmdDrawIndirect,
-- vkCmdDrawIndirectCountAMD, vkCmdEndDebugUtilsLabelEXT,
-- vkCmdEndQuery, vkCmdEndRenderPass,
-- vkCmdExecuteCommands, vkCmdFillBuffer,
-- vkCmdInsertDebugUtilsLabelEXT, vkCmdNextSubpass,
-- vkCmdPipelineBarrier, vkCmdProcessCommandsNVX,
-- vkCmdPushConstants, vkCmdPushDescriptorSetKHR,
-- vkCmdPushDescriptorSetWithTemplateKHR,
-- vkCmdReserveSpaceForCommandsNVX, vkCmdResetEvent,
-- vkCmdResetQueryPool, vkCmdResolveImage,
-- vkCmdSetBlendConstants, vkCmdSetDepthBias,
-- vkCmdSetDepthBounds, vkCmdSetDeviceMask,
-- vkCmdSetDeviceMaskKHR, vkCmdSetDiscardRectangleEXT,
-- vkCmdSetEvent, vkCmdSetLineWidth,
-- vkCmdSetSampleLocationsEXT, vkCmdSetScissor,
-- vkCmdSetStencilCompareMask, vkCmdSetStencilReference,
-- vkCmdSetStencilWriteMask, vkCmdSetViewport,
-- vkCmdSetViewportWScalingNV, vkCmdUpdateBuffer,
-- vkCmdWaitEvents, vkCmdWriteBufferMarkerAMD,
-- vkCmdWriteTimestamp, vkEndCommandBuffer,
-- vkFreeCommandBuffers, vkResetCommandBuffer
type VkCommandBuffer = Ptr VkCommandBuffer_T
-- | VkFence - Opaque handle to a fence object
--
-- Description
--
-- See Also
--
-- VkAcquireNextImageInfoKHR, VkFenceGetFdInfoKHR,
-- VkFenceGetWin32HandleInfoKHR, VkImportFenceFdInfoKHR,
-- VkImportFenceWin32HandleInfoKHR, vkAcquireNextImageKHR,
-- vkCreateFence, vkDestroyFence, vkGetFenceStatus,
-- vkQueueBindSparse, vkQueueSubmit,
-- vkRegisterDeviceEventEXT, vkRegisterDisplayEventEXT,
-- vkResetFences, vkWaitForFences
type VkFence = Ptr VkFence_T
-- | VkSemaphore - Opaque handle to a semaphore object
--
-- Description
--
-- See Also
--
-- VkAcquireNextImageInfoKHR, VkBindSparseInfo,
-- VkImportSemaphoreFdInfoKHR,
-- VkImportSemaphoreWin32HandleInfoKHR, VkPresentInfoKHR,
-- VkSemaphoreGetFdInfoKHR,
-- VkSemaphoreGetWin32HandleInfoKHR, VkSubmitInfo,
-- vkAcquireNextImageKHR, vkCreateSemaphore,
-- vkDestroySemaphore
type VkSemaphore = Ptr VkSemaphore_T
-- | vkGetDeviceQueue - Get a queue handle from a device
--
-- Parameters
--
--
-- - device is the logical device that owns the queue.
--
--
--
-- - queueFamilyIndex is the index of the queue family to
-- which the queue belongs.
-- - queueIndex is the index within this queue family of the
-- queue to retrieve.
-- - pQueue is a pointer to a VkQueue object that
-- will be filled with the handle for the requested queue.
--
--
-- Description
--
-- Valid Usage
--
--
-- - queueFamilyIndex must be one of the queue family
-- indices specified when device was created, via the
-- VkDeviceQueueCreateInfo structure
--
--
--
-- - queueIndex must be less than the number of queues
-- created for the specified queue family index when device was
-- created, via the queueCount member of the
-- VkDeviceQueueCreateInfo structure
-- - VkDeviceQueueCreateInfo::flags must have
-- been set to zero when device was created
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pQueue must be a valid pointer to a
-- VkQueue handle
--
--
-- See Also
--
-- VkDevice, VkQueue
vkGetDeviceQueue :: ("device" ::: VkDevice) -> ("queueFamilyIndex" ::: Word32) -> ("queueIndex" ::: Word32) -> ("pQueue" ::: Ptr VkQueue) -> IO ()
-- | vkQueueSubmit - Submits a sequence of semaphores or command buffers to
-- a queue
--
-- Parameters
--
--
-- - queue is the queue that the command buffers will be
-- submitted to.
--
--
--
-- - submitCount is the number of elements in the
-- pSubmits array.
-- - pSubmits is a pointer to an array of VkSubmitInfo
-- structures, each specifying a command buffer submission batch.
-- - fence is an optional handle to a fence to be
-- signaled once all submitted command buffers have completed execution.
-- If fence is not VK_NULL_HANDLE, it defines a fence
-- signal operation.
--
--
-- Description
--
-- Note
--
-- Submission can be a high overhead operation, and applications
-- should attempt to batch work together into as few calls to
-- vkQueueSubmit as possible.
--
-- vkQueueSubmit is a queue submission command, with each
-- batch defined by an element of pSubmits as an instance of the
-- VkSubmitInfo structure. Batches begin execution in the order
-- they appear in pSubmits, but may complete out of
-- order.
--
-- Fence and semaphore operations submitted with vkQueueSubmit
-- have additional ordering constraints compared to other submission
-- commands, with dependencies involving previous and subsequent queue
-- operations. Information about these additional constraints can be
-- found in the semaphore and fence sections of the
-- synchronization chapter.
--
-- Details on the interaction of pWaitDstStageMask with
-- synchronization are described in the semaphore wait operation
-- section of the synchronization chapter.
--
-- The order that batches appear in pSubmits is used to
-- determine submission order, and thus all the implicit
-- ordering guarantees that respect it. Other than these implicit
-- ordering guarantees and any explicit synchronization
-- primitives, these batches may overlap or otherwise execute
-- out of order.
--
-- If any command buffer submitted to this queue is in the executable
-- state, it is moved to the pending state. Once execution of
-- all submissions of a command buffer complete, it moves from the
-- pending state, back to the executable state. If a
-- command buffer was recorded with the
-- VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT flag, it instead
-- moves back to the invalid state.
--
-- If vkQueueSubmit fails, it may return
-- VK_ERROR_OUT_OF_HOST_MEMORY or
-- VK_ERROR_OUT_OF_DEVICE_MEMORY. If it does, the implementation
-- must ensure that the state and contents of any resources or
-- synchronization primitives referenced by the submitted command buffers
-- and any semaphores referenced by pSubmits is unaffected by
-- the call or its failure. If vkQueueSubmit fails in such a way
-- that the implementation is unable to make that guarantee, the
-- implementation must return VK_ERROR_DEVICE_LOST. See
-- Lost Device.
--
-- Valid Usage
--
--
--
--
-- - If fence is not VK_NULL_HANDLE, fence
-- must not be associated with any other queue command that has
-- not yet completed execution on that queue
-- - Any calls to vkCmdSetEvent, vkCmdResetEvent or
-- vkCmdWaitEvents that have been recorded into any of the command
-- buffer elements of the pCommandBuffers member of any element
-- of pSubmits, must not reference any VkEvent
-- that is referenced by any of those commands in a command buffer that
-- has been submitted to another queue and is still in the pending
-- state.
-- - Any stage flag included in any element of the
-- pWaitDstStageMask member of any element of pSubmits
-- must be a pipeline stage supported by one of the capabilities
-- of queue, as specified in the table of supported pipeline
-- stages.
-- - Each element of the pSignalSemaphores member of any
-- element of pSubmits must be unsignaled when the
-- semaphore signal operation it defines is executed on the device
-- - When a semaphore unsignal operation defined by any element of the
-- pWaitSemaphores member of any element of pSubmits
-- executes on queue, no other queue must be waiting on
-- the same semaphore.
-- - All elements of the pWaitSemaphores member of all
-- elements of pSubmits must be semaphores that are
-- signaled, or have semaphore signal operations previously
-- submitted for execution.
-- - Each element of the pCommandBuffers member of each
-- element of pSubmits must be in the pending or
-- executable state.
-- - If any element of the pCommandBuffers member of any
-- element of pSubmits was not recorded with the
-- VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT, it must
-- not be in the pending state.
-- - Any secondary command buffers recorded into any element of
-- the pCommandBuffers member of any element of
-- pSubmits must be in the pending or executable
-- state.
-- - If any secondary command buffers recorded into any element
-- of the pCommandBuffers member of any element of
-- pSubmits was not recorded with the
-- VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT, it must
-- not be in the pending state.
-- - Each element of the pCommandBuffers member of each
-- element of pSubmits must have been allocated from a
-- VkCommandPool that was created for the same queue family
-- queue belongs to.
--
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
--
-- - If submitCount is not 0, pSubmits
-- must be a valid pointer to an array of submitCount
-- valid VkSubmitInfo structures
-- - If fence is not VK_NULL_HANDLE, fence
-- must be a valid VkFence handle
-- - Both of fence, and queue that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to queue must be externally
-- synchronized
--
--
--
-- - Host access to pSubmits[].pWaitSemaphores[] must
-- be externally synchronized
-- - Host access to pSubmits[].pSignalSemaphores[] must
-- be externally synchronized
-- - Host access to fence must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkFence, VkQueue, VkSubmitInfo
vkQueueSubmit :: ("queue" ::: VkQueue) -> ("submitCount" ::: Word32) -> ("pSubmits" ::: Ptr VkSubmitInfo) -> ("fence" ::: VkFence) -> IO VkResult
-- | vkQueueWaitIdle - Wait for a queue to become idle
--
-- Parameters
--
--
-- - queue is the queue on which to wait.
--
--
-- Description
--
-- vkQueueWaitIdle is equivalent to submitting a fence to a
-- queue and waiting with an infinite timeout for that fence to signal.
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkQueue
vkQueueWaitIdle :: ("queue" ::: VkQueue) -> IO VkResult
-- | vkDeviceWaitIdle - Wait for a device to become idle
--
-- Parameters
--
--
-- - device is the logical device to idle.
--
--
-- Description
--
-- vkDeviceWaitIdle is equivalent to calling
-- vkQueueWaitIdle for all queues owned by device.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
-- Host Synchronization
--
--
-- - Host access to all VkQueue objects created from
-- device must be externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice
vkDeviceWaitIdle :: ("device" ::: VkDevice) -> IO VkResult
-- | VkSubmitInfo - Structure specifying a queue submit operation
--
-- Description
--
-- The order that command buffers appear in pCommandBuffers is
-- used to determine submission order, and thus all the
-- implicit ordering guarantees that respect it. Other than these
-- implicit ordering guarantees and any explicit synchronization
-- primitives, these command buffers may overlap or otherwise
-- execute out of order.
--
-- Valid Usage
--
--
-- - Each element of pCommandBuffers must not have been
-- allocated with VK_COMMAND_BUFFER_LEVEL_SECONDARY
--
--
--
-- - If the geometry shaders feature is not enabled, each
-- element of pWaitDstStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled, each
-- element of pWaitDstStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - Each element of pWaitDstStageMask must not include
-- VK_PIPELINE_STAGE_HOST_BIT.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SUBMIT_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of VkD3D12FenceSubmitInfoKHR,
-- VkDeviceGroupSubmitInfo, VkProtectedSubmitInfo,
-- VkWin32KeyedMutexAcquireReleaseInfoKHR, or
-- VkWin32KeyedMutexAcquireReleaseInfoNV
-- - Each sType member in the pNext chain must
-- be unique
-- - If waitSemaphoreCount is not 0,
-- pWaitSemaphores must be a valid pointer to an array of
-- waitSemaphoreCount valid VkSemaphore handles
-- - If waitSemaphoreCount is not 0,
-- pWaitDstStageMask must be a valid pointer to an array
-- of waitSemaphoreCount valid combinations of
-- VkPipelineStageFlagBits values
-- - Each element of pWaitDstStageMask must not be
-- 0
-- - If commandBufferCount is not 0,
-- pCommandBuffers must be a valid pointer to an array of
-- commandBufferCount valid VkCommandBuffer
-- handles
-- - If signalSemaphoreCount is not 0,
-- pSignalSemaphores must be a valid pointer to an array
-- of signalSemaphoreCount valid VkSemaphore
-- handles
-- - Each of the elements of pCommandBuffers, the elements of
-- pSignalSemaphores, and the elements of
-- pWaitSemaphores that are valid handles must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkCommandBuffer, VkPipelineStageFlags,
-- VkSemaphore, VkStructureType, vkQueueSubmit
data VkSubmitInfo
VkSubmitInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr VkSemaphore -> Ptr VkPipelineStageFlags -> Word32 -> Ptr VkCommandBuffer -> Word32 -> Ptr VkSemaphore -> VkSubmitInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkSubmitInfo] :: VkSubmitInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSubmitInfo] :: VkSubmitInfo -> Ptr ()
-- | waitSemaphoreCount is the number of semaphores upon which to
-- wait before executing the command buffers for the batch.
[$sel:vkWaitSemaphoreCount:VkSubmitInfo] :: VkSubmitInfo -> Word32
-- | pWaitSemaphores is a pointer to an array of semaphores upon
-- which to wait before the command buffers for this batch begin
-- execution. If semaphores to wait on are provided, they define a
-- semaphore wait operation.
[$sel:vkPWaitSemaphores:VkSubmitInfo] :: VkSubmitInfo -> Ptr VkSemaphore
-- | pWaitDstStageMask is a pointer to an array of pipeline stages
-- at which each corresponding semaphore wait will occur.
[$sel:vkPWaitDstStageMask:VkSubmitInfo] :: VkSubmitInfo -> Ptr VkPipelineStageFlags
-- | commandBufferCount is the number of command buffers to
-- execute in the batch.
[$sel:vkCommandBufferCount:VkSubmitInfo] :: VkSubmitInfo -> Word32
-- | pCommandBuffers is a pointer to an array of command buffers
-- to execute in the batch.
[$sel:vkPCommandBuffers:VkSubmitInfo] :: VkSubmitInfo -> Ptr VkCommandBuffer
-- | signalSemaphoreCount is the number of semaphores to be
-- signaled once the commands specified in pCommandBuffers have
-- completed execution.
[$sel:vkSignalSemaphoreCount:VkSubmitInfo] :: VkSubmitInfo -> Word32
-- | pSignalSemaphores is a pointer to an array of semaphores
-- which will be signaled when the command buffers for this batch have
-- completed execution. If semaphores to be signaled are provided, they
-- define a semaphore signal operation.
[$sel:vkPSignalSemaphores:VkSubmitInfo] :: VkSubmitInfo -> Ptr VkSemaphore
-- | VkPipelineStageFlags - Bitmask of VkPipelineStageFlagBits
--
-- Description
--
-- VkPipelineStageFlags is a bitmask type for setting a mask of
-- zero or more VkPipelineStageFlagBits.
--
-- See Also
--
-- VkPipelineStageFlagBits, VkSubmitInfo,
-- VkSubpassDependency, vkCmdPipelineBarrier,
-- vkCmdResetEvent, vkCmdSetEvent, vkCmdWaitEvents
type VkPipelineStageFlags = VkPipelineStageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Queue.VkSubmitInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Queue.VkSubmitInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Queue.VkSubmitInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Queue.VkPipelineStageFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd
-- | vkGetSemaphoreFdKHR - Get a POSIX file descriptor handle for a
-- semaphore
--
-- Parameters
--
--
-- - device is the logical device that created the semaphore
-- being exported.
--
--
--
-- - pGetFdInfo is a pointer to an instance of the
-- VkSemaphoreGetFdInfoKHR structure containing parameters of the
-- export operation.
-- - pFd will return the file descriptor representing the
-- semaphore payload.
--
--
-- Description
--
-- Each call to vkGetSemaphoreFdKHR must create a new
-- file descriptor and transfer ownership of it to the application. To
-- avoid leaking resources, the application must release ownership
-- of the file descriptor when it is no longer needed.
--
-- Note
--
-- Ownership can be released in many ways. For example, the application
-- can call close() on the file descriptor, or transfer
-- ownership back to Vulkan by using the file descriptor to import a
-- semaphore payload.
--
-- Where supported by the operating system, the implementation
-- must set the file descriptor to be closed automatically when an
-- execve system call is made.
--
-- Exporting a file descriptor from a semaphore may have side
-- effects depending on the transference of the specified handle type, as
-- described in Importing Semaphore State.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pGetFdInfo must be a valid pointer to a valid
-- VkSemaphoreGetFdInfoKHR structure
-- - pFd must be a valid pointer to a int
-- value
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_TOO_MANY_OBJECTS
--
--
-- See Also
--
-- VkDevice, VkSemaphoreGetFdInfoKHR
vkGetSemaphoreFdKHR :: ("device" ::: VkDevice) -> ("pGetFdInfo" ::: Ptr VkSemaphoreGetFdInfoKHR) -> ("pFd" ::: Ptr CInt) -> IO VkResult
-- | vkImportSemaphoreFdKHR - Import a semaphore from a POSIX file
-- descriptor
--
-- Parameters
--
--
-- - device is the logical device that created the
-- semaphore.
--
--
--
-- - pImportSemaphoreFdInfo points to a
-- VkImportSemaphoreFdInfoKHR structure specifying the semaphore
-- and import parameters.
--
--
-- Description
--
-- Importing a semaphore payload from a file descriptor transfers
-- ownership of the file descriptor from the application to the Vulkan
-- implementation. The application must not perform any operations
-- on the file descriptor after a successful import.
--
-- Applications can import the same semaphore payload into
-- multiple instances of Vulkan, into the same instance from which it was
-- exported, and multiple times into a given Vulkan instance.
--
-- Valid Usage
--
--
-- - semaphore must not be associated with any queue
-- command that has not yet completed execution on that queue
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pImportSemaphoreFdInfo must be a valid pointer to
-- a valid VkImportSemaphoreFdInfoKHR structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkImportSemaphoreFdInfoKHR
vkImportSemaphoreFdKHR :: ("device" ::: VkDevice) -> ("pImportSemaphoreFdInfo" ::: Ptr VkImportSemaphoreFdInfoKHR) -> IO VkResult
-- | VkImportSemaphoreFdInfoKHR - Structure specifying POSIX file
-- descriptor to import to a semaphore
--
-- Description
--
-- The handle types supported by handleType are:
--
--
-- +-----------------------+-----------------------+-----------------------+
-- | Handle Type | Transference | Permanence Supported |
-- +=======================+=======================+=======================+
-- | @VK_EXTERNAL_SEMAPHOR | Reference | Temporary,Permanent |
-- | E_HANDLE_TYPE_OPAQUE_ | | |
-- | FD_BIT@ | | |
-- +-----------------------+-----------------------+-----------------------+
-- | @VK_EXTERNAL_SEMAPHOR | Copy | Temporary |
-- | E_HANDLE_TYPE_SYNC_FD | | |
-- | _BIT@ | | |
-- +-----------------------+-----------------------+-----------------------+
--
-- Handle Types Supported by VkImportSemaphoreFdInfoKHR
--
--
-- Valid Usage
--
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMPORT_SEMAPHORE_FD_INFO_KHR
--
--
--
--
-- Host Synchronization
--
--
-- - Host access to semaphore must be externally
-- synchronized
--
--
-- See Also
--
-- VkExternalSemaphoreHandleTypeFlagBits, VkSemaphore,
-- VkSemaphoreImportFlags, VkStructureType,
-- vkImportSemaphoreFdKHR
data VkImportSemaphoreFdInfoKHR
VkImportSemaphoreFdInfoKHR :: VkStructureType -> Ptr () -> VkSemaphore -> VkSemaphoreImportFlags -> VkExternalSemaphoreHandleTypeFlagBits -> CInt -> VkImportSemaphoreFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> Ptr ()
-- | semaphore is the semaphore into which the payload will be
-- imported.
[$sel:vkSemaphore:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> VkSemaphore
-- | flags is a bitmask of VkSemaphoreImportFlagBits
-- specifying additional parameters for the semaphore payload import
-- operation.
[$sel:vkFlags:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> VkSemaphoreImportFlags
-- | handleType specifies the type of fd.
[$sel:vkHandleType:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> VkExternalSemaphoreHandleTypeFlagBits
-- | fd is the external handle to import.
[$sel:vkFd:VkImportSemaphoreFdInfoKHR] :: VkImportSemaphoreFdInfoKHR -> CInt
-- | VkSemaphoreGetFdInfoKHR - Structure describing a POSIX FD semaphore
-- export operation
--
-- Description
--
-- The properties of the file descriptor returned depend on the value of
-- handleType. See VkExternalSemaphoreHandleTypeFlagBits
-- for a description of the properties of the defined external semaphore
-- handle types.
--
-- Valid Usage
--
--
-- - handleType must have been included in
-- VkExportSemaphoreCreateInfo::handleTypes when
-- semaphore’s current payload was created.
--
--
--
-- - semaphore must not currently have its payload
-- replaced by an imported payload as described below in Importing
-- Semaphore Payloads unless that imported payload’s handle type was
-- included in
-- VkExternalSemaphoreProperties::exportFromImportedHandleTypes
-- for handleType.
-- - If handleType refers to a handle type with copy payload
-- transference semantics, as defined below in Importing Semaphore
-- Payloads, there must be no queue waiting on
-- semaphore.
-- - If handleType refers to a handle type with copy payload
-- transference semantics, semaphore must be signaled, or
-- have an associated semaphore signal operation pending
-- execution.
-- - handleType must be defined as a POSIX file
-- descriptor handle.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SEMAPHORE_GET_FD_INFO_KHR
--
--
--
--
-- See Also
--
-- VkExternalSemaphoreHandleTypeFlagBits, VkSemaphore,
-- VkStructureType, vkGetSemaphoreFdKHR
data VkSemaphoreGetFdInfoKHR
VkSemaphoreGetFdInfoKHR :: VkStructureType -> Ptr () -> VkSemaphore -> VkExternalSemaphoreHandleTypeFlagBits -> VkSemaphoreGetFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkSemaphoreGetFdInfoKHR] :: VkSemaphoreGetFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSemaphoreGetFdInfoKHR] :: VkSemaphoreGetFdInfoKHR -> Ptr ()
-- | semaphore is the semaphore from which state will be exported.
[$sel:vkSemaphore:VkSemaphoreGetFdInfoKHR] :: VkSemaphoreGetFdInfoKHR -> VkSemaphore
-- | handleType is the type of handle requested.
[$sel:vkHandleType:VkSemaphoreGetFdInfoKHR] :: VkSemaphoreGetFdInfoKHR -> VkExternalSemaphoreHandleTypeFlagBits
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkSemaphoreGetFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkSemaphoreGetFdInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkImportSemaphoreFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkImportSemaphoreFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkSemaphoreGetFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_semaphore_fd.VkImportSemaphoreFdInfoKHR
module Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd
-- | vkGetFenceFdKHR - Get a POSIX file descriptor handle for a fence
--
-- Parameters
--
--
-- - device is the logical device that created the fence being
-- exported.
--
--
--
-- - pGetFdInfo is a pointer to an instance of the
-- VkFenceGetFdInfoKHR structure containing parameters of the
-- export operation.
-- - pFd will return the file descriptor representing the
-- fence payload.
--
--
-- Description
--
-- Each call to vkGetFenceFdKHR must create a new file
-- descriptor and transfer ownership of it to the application. To avoid
-- leaking resources, the application must release ownership of
-- the file descriptor when it is no longer needed.
--
-- Note
--
-- Ownership can be released in many ways. For example, the application
-- can call close() on the file descriptor, or transfer
-- ownership back to Vulkan by using the file descriptor to import a
-- fence payload.
--
-- If pGetFdInfo::handleType is
-- VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT and the fence is
-- signaled at the time vkGetFenceFdKHR is called, pFd
-- may return the value -1 instead of a valid file
-- descriptor.
--
-- Where supported by the operating system, the implementation
-- must set the file descriptor to be closed automatically when an
-- execve system call is made.
--
-- Exporting a file descriptor from a fence may have side effects
-- depending on the transference of the specified handle type, as
-- described in Importing Fence State.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pGetFdInfo must be a valid pointer to a valid
-- VkFenceGetFdInfoKHR structure
-- - pFd must be a valid pointer to a int
-- value
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_TOO_MANY_OBJECTS
--
--
-- See Also
--
-- VkDevice, VkFenceGetFdInfoKHR
vkGetFenceFdKHR :: ("device" ::: VkDevice) -> ("pGetFdInfo" ::: Ptr VkFenceGetFdInfoKHR) -> ("pFd" ::: Ptr CInt) -> IO VkResult
-- | vkImportFenceFdKHR - Import a fence from a POSIX file descriptor
--
-- Parameters
--
--
-- - device is the logical device that created the fence.
--
--
--
-- - pImportFenceFdInfo points to a
-- VkImportFenceFdInfoKHR structure specifying the fence and
-- import parameters.
--
--
-- Description
--
-- Importing a fence payload from a file descriptor transfers ownership
-- of the file descriptor from the application to the Vulkan
-- implementation. The application must not perform any operations
-- on the file descriptor after a successful import.
--
-- Applications can import the same fence payload into multiple
-- instances of Vulkan, into the same instance from which it was
-- exported, and multiple times into a given Vulkan instance.
--
-- Valid Usage
--
--
-- - fence must not be associated with any queue
-- command that has not yet completed execution on that queue
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pImportFenceFdInfo must be a valid pointer to a
-- valid VkImportFenceFdInfoKHR structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkImportFenceFdInfoKHR
vkImportFenceFdKHR :: ("device" ::: VkDevice) -> ("pImportFenceFdInfo" ::: Ptr VkImportFenceFdInfoKHR) -> IO VkResult
-- | VkImportFenceFdInfoKHR - (None)
--
-- Description
--
-- The handle types supported by handleType are:
--
--
-- +-----------------------+-----------------------+-----------------------+
-- | Handle Type | Transference | Permanence Supported |
-- +=======================+=======================+=======================+
-- | @VK_EXTERNAL_FENCE_HA | Reference | Temporary,Permanent |
-- | NDLE_TYPE_OPAQUE_FD_B | | |
-- | IT@ | | |
-- +-----------------------+-----------------------+-----------------------+
-- | @VK_EXTERNAL_FENCE_HA | Copy | Temporary |
-- | NDLE_TYPE_SYNC_FD_BIT | | |
-- | @ | | |
-- +-----------------------+-----------------------+-----------------------+
--
-- Handle Types Supported by VkImportFenceFdInfoKHR
--
--
-- Valid Usage
--
--
--
--
--
-- If handleType is
-- VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT, the special value
-- -1 for fd is treated like a valid sync file
-- descriptor referring to an object that has already signaled. The
-- import operation will succeed and the VkFence will have a
-- temporarily imported payload as if a valid file descriptor had been
-- provided.
--
-- Note
--
-- This special behavior for importing an invalid sync file descriptor
-- allows easier interoperability with other system APIs which use the
-- convention that an invalid sync file descriptor represents work that
-- has already completed and doesn’t need to be waited for. It is
-- consistent with the option for implementations to return a -1
-- file descriptor when exporting a
-- VK_EXTERNAL_FENCE_HANDLE_TYPE_SYNC_FD_BIT from a
-- VkFence which is signaled.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMPORT_FENCE_FD_INFO_KHR
--
--
--
--
-- Host Synchronization
--
--
-- - Host access to fence must be externally
-- synchronized
--
--
-- See Also
--
-- VkExternalFenceHandleTypeFlagBits, VkFence,
-- VkFenceImportFlags, VkStructureType,
-- vkImportFenceFdKHR
data VkImportFenceFdInfoKHR
VkImportFenceFdInfoKHR :: VkStructureType -> Ptr () -> VkFence -> VkFenceImportFlags -> VkExternalFenceHandleTypeFlagBits -> CInt -> VkImportFenceFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> Ptr ()
-- | fence is the fence into which the payload will be imported.
[$sel:vkFence:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> VkFence
-- | flags is a bitmask of VkFenceImportFlagBits specifying
-- additional parameters for the fence payload import operation.
[$sel:vkFlags:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> VkFenceImportFlags
-- | handleType specifies the type of fd.
[$sel:vkHandleType:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> VkExternalFenceHandleTypeFlagBits
-- | fd is the external handle to import.
[$sel:vkFd:VkImportFenceFdInfoKHR] :: VkImportFenceFdInfoKHR -> CInt
-- | VkFenceGetFdInfoKHR - Structure describing a POSIX FD fence export
-- operation
--
-- Description
--
-- The properties of the file descriptor returned depend on the value of
-- handleType. See VkExternalFenceHandleTypeFlagBits for
-- a description of the properties of the defined external fence handle
-- types.
--
-- Valid Usage
--
--
-- - handleType must have been included in
-- VkExportFenceCreateInfo::handleTypes when
-- fence’s current payload was created.
--
--
--
-- - If handleType refers to a handle type with copy payload
-- transference semantics, fence must be signaled, or
-- have an associated fence signal operation pending
-- execution.
-- - fence must not currently have its payload replaced
-- by an imported payload as described below in Importing Fence
-- Payloads unless that imported payload’s handle type was included
-- in
-- VkExternalFenceProperties::exportFromImportedHandleTypes
-- for handleType.
-- - handleType must be defined as a POSIX file
-- descriptor handle.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_FENCE_GET_FD_INFO_KHR
--
--
--
--
-- See Also
--
-- VkExternalFenceHandleTypeFlagBits, VkFence,
-- VkStructureType, vkGetFenceFdKHR
data VkFenceGetFdInfoKHR
VkFenceGetFdInfoKHR :: VkStructureType -> Ptr () -> VkFence -> VkExternalFenceHandleTypeFlagBits -> VkFenceGetFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkFenceGetFdInfoKHR] :: VkFenceGetFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkFenceGetFdInfoKHR] :: VkFenceGetFdInfoKHR -> Ptr ()
-- | fence is the fence from which state will be exported.
[$sel:vkFence:VkFenceGetFdInfoKHR] :: VkFenceGetFdInfoKHR -> VkFence
-- | handleType is the type of handle requested.
[$sel:vkHandleType:VkFenceGetFdInfoKHR] :: VkFenceGetFdInfoKHR -> VkExternalFenceHandleTypeFlagBits
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkFenceGetFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkFenceGetFdInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkImportFenceFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkImportFenceFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkFenceGetFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_fence_fd.VkImportFenceFdInfoKHR
module Graphics.Vulkan.Extensions.VK_EXT_debug_utils
-- | VkDebugUtilsMessageSeverityFlagBitsEXT - Bitmask specifying which
-- severities of events cause a debug messenger callback
--
-- See Also
--
-- VkDebugUtilsMessageSeverityFlagsEXT,
-- vkSubmitDebugUtilsMessageEXT
newtype VkDebugUtilsMessageSeverityFlagBitsEXT
VkDebugUtilsMessageSeverityFlagBitsEXT :: VkFlags -> VkDebugUtilsMessageSeverityFlagBitsEXT
-- | VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT specifies the
-- most verbose output indicating all diagnostic messages from the Vulkan
-- loader, layers, and drivers should be captured.
-- | VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT specifies an
-- informational message such as resource details that may be handy when
-- debugging an application.
-- | VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT specifies use
-- of Vulkan that may expose an app bug. Such cases may not be
-- immediately harmful, such as a fragment shader outputting to a
-- location with no attachment. Other cases may point to behavior
-- that is almost certainly bad when unintended such as using an image
-- whose memory has not been filled. In general if you see a warning but
-- you know that the behavior is intended/desired, then simply ignore the
-- warning.
-- | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT specifies that
-- an error that may cause undefined results, including an application
-- crash.
-- | VkDebugUtilsMessageTypeFlagBitsEXT - Bitmask specifying which types of
-- events cause a debug messenger callback
--
-- See Also
--
-- VkDebugUtilsMessageTypeFlagsEXT
newtype VkDebugUtilsMessageTypeFlagBitsEXT
VkDebugUtilsMessageTypeFlagBitsEXT :: VkFlags -> VkDebugUtilsMessageTypeFlagBitsEXT
-- | VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT specifies that
-- some general event has occurred. This is typically a
-- non-specification, non-performance event.
-- | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT specifies that
-- something has occurred during validation against the Vulkan
-- specification that may indicate invalid behavior.
-- | VK_DEBUG_UTILS_MESSAGE_TYPE_PERFORMANCE_BIT_EXT specifies a
-- potentially non-optimal use of Vulkan, e.g. using
-- vkCmdClearColorImage when setting
-- VkAttachmentDescription::loadOp to
-- VK_ATTACHMENT_LOAD_OP_CLEAR would have worked.
newtype VkDebugUtilsMessengerCreateFlagsEXT
VkDebugUtilsMessengerCreateFlagsEXT :: VkFlags -> VkDebugUtilsMessengerCreateFlagsEXT
newtype VkDebugUtilsMessengerCallbackDataFlagsEXT
VkDebugUtilsMessengerCallbackDataFlagsEXT :: VkFlags -> VkDebugUtilsMessengerCallbackDataFlagsEXT
-- | PFN_vkDebugUtilsMessengerCallbackEXT - Application-defined debug
-- messenger callback function
--
-- Parameters
--
--
--
--
--
-- Description
--
-- The callback must not call
-- vkDestroyDebugUtilsMessengerEXT.
--
-- The callback returns a VkBool32, which is interpreted in a
-- layer-specified manner. The application should always return
-- VK_FALSE. The VK_TRUE value is reserved for use in
-- layer development.
--
-- See Also
--
-- VkDebugUtilsMessengerCreateInfoEXT
type PFN_vkDebugUtilsMessengerCallbackEXT = Ptr (("messageSeverity" ::: VkDebugUtilsMessageSeverityFlagBitsEXT) -> ("messageType" ::: VkDebugUtilsMessageTypeFlagsEXT) -> ("pCallbackData" ::: Ptr VkDebugUtilsMessengerCallbackDataEXT) -> ("pUserData" ::: Ptr ()) -> IO VkBool32)
-- | VkDebugUtilsMessengerEXT - Opaque handle to a debug messenger object
--
-- Description
--
-- The debug messenger will provide detailed feedback on the
-- application’s use of Vulkan when events of interest occur. When an
-- event of interest does occur, the debug messenger will submit a debug
-- message to the debug callback that was provided during its creation.
-- Additionally, the debug messenger is responsible with filtering out
-- debug messages that the callback isn’t interested in and will only
-- provide desired debug messages.
--
-- See Also
--
-- vkCreateDebugUtilsMessengerEXT,
-- vkDestroyDebugUtilsMessengerEXT
type VkDebugUtilsMessengerEXT = Ptr VkDebugUtilsMessengerEXT_T
-- | vkSetDebugUtilsObjectNameEXT - Give a user-friendly name to an object
--
-- Parameters
--
--
-- - device is the device that created the object.
--
--
--
-- - pNameInfo is a pointer to an instance of the
-- VkDebugUtilsObjectNameInfoEXT structure specifying the
-- parameters of the name to set on the object.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pNameInfo must be a valid pointer to a valid
-- VkDebugUtilsObjectNameInfoEXT structure
--
--
-- Host Synchronization
--
--
-- - Host access to pNameInfo.objectHandle must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDebugUtilsObjectNameInfoEXT, VkDevice
vkSetDebugUtilsObjectNameEXT :: ("device" ::: VkDevice) -> ("pNameInfo" ::: Ptr VkDebugUtilsObjectNameInfoEXT) -> IO VkResult
-- | vkSetDebugUtilsObjectTagEXT - Attach arbitrary data to an object
--
-- Parameters
--
--
-- - device is the device that created the object.
--
--
--
-- - pTagInfo is a pointer to an instance of the
-- VkDebugUtilsObjectTagInfoEXT structure specifying the
-- parameters of the tag to attach to the object.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pTagInfo must be a valid pointer to a valid
-- VkDebugUtilsObjectTagInfoEXT structure
--
--
-- Host Synchronization
--
--
-- - Host access to pTagInfo.objectHandle must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDebugUtilsObjectTagInfoEXT, VkDevice
vkSetDebugUtilsObjectTagEXT :: ("device" ::: VkDevice) -> ("pTagInfo" ::: Ptr VkDebugUtilsObjectTagInfoEXT) -> IO VkResult
-- | vkQueueBeginDebugUtilsLabelEXT - Open a queue debug label region
--
-- Parameters
--
--
-- - queue is the queue in which to start a debug label
-- region.
--
--
--
-- - pLabelInfo is a pointer to an instance of the
-- VkDebugUtilsLabelEXT structure specifying the parameters of the
-- label region to open.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
--
-- - pLabelInfo must be a valid pointer to a valid
-- VkDebugUtilsLabelEXT structure
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkDebugUtilsLabelEXT, VkQueue
vkQueueBeginDebugUtilsLabelEXT :: ("queue" ::: VkQueue) -> ("pLabelInfo" ::: Ptr VkDebugUtilsLabelEXT) -> IO ()
-- | vkQueueEndDebugUtilsLabelEXT - Close a queue debug label region
--
-- Parameters
--
--
-- - queue is the queue in which a debug label region should
-- be closed.
--
--
-- Description
--
-- The calls to vkQueueBeginDebugUtilsLabelEXT and
-- vkQueueEndDebugUtilsLabelEXT must be matched and
-- balanced.
--
-- Valid Usage
--
--
-- - There must be an outstanding
-- vkQueueBeginDebugUtilsLabelEXT command prior to the
-- vkQueueEndDebugUtilsLabelEXT on the queue
--
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkQueue
vkQueueEndDebugUtilsLabelEXT :: ("queue" ::: VkQueue) -> IO ()
-- | vkQueueInsertDebugUtilsLabelEXT - Insert a label into a queue
--
-- Parameters
--
--
-- - queue is the queue into which a debug label will be
-- inserted.
--
--
--
-- - pLabelInfo is a pointer to an instance of the
-- VkDebugUtilsLabelEXT structure specifying the parameters of the
-- label to insert.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
--
-- - pLabelInfo must be a valid pointer to a valid
-- VkDebugUtilsLabelEXT structure
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkDebugUtilsLabelEXT, VkQueue
vkQueueInsertDebugUtilsLabelEXT :: ("queue" ::: VkQueue) -> ("pLabelInfo" ::: Ptr VkDebugUtilsLabelEXT) -> IO ()
-- | vkCmdBeginDebugUtilsLabelEXT - Open a command buffer debug label
-- region
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - pLabelInfo is a pointer to an instance of the
-- VkDebugUtilsLabelEXT structure specifying the parameters of the
-- label region to open.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pLabelInfo must be a valid pointer to a valid
-- VkDebugUtilsLabelEXT structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkDebugUtilsLabelEXT
vkCmdBeginDebugUtilsLabelEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("pLabelInfo" ::: Ptr VkDebugUtilsLabelEXT) -> IO ()
-- | vkCmdEndDebugUtilsLabelEXT - Close a command buffer label region
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
-- Description
--
-- An application may open a debug label region in one command
-- buffer and close it in another, or otherwise split debug label regions
-- across multiple command buffers or multiple queue submissions. When
-- viewed from the linear series of submissions to a single queue, the
-- calls to vkCmdBeginDebugUtilsLabelEXT and
-- vkCmdEndDebugUtilsLabelEXT must be matched and balanced.
--
-- Valid Usage
--
--
-- - There must be an outstanding
-- vkCmdBeginDebugUtilsLabelEXT command prior to the
-- vkCmdEndDebugUtilsLabelEXT on the queue that
-- commandBuffer is submitted to
--
--
--
-- - If commandBuffer is a secondary command buffer, there
-- must be an outstanding vkCmdBeginDebugUtilsLabelEXT
-- command recorded to commandBuffer that has not previously
-- been ended by a call to vkCmdEndDebugUtilsLabelEXT.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdEndDebugUtilsLabelEXT :: ("commandBuffer" ::: VkCommandBuffer) -> IO ()
-- | vkCmdInsertDebugUtilsLabelEXT - Insert a label into a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - pInfo is a pointer to an instance of the
-- VkDebugUtilsLabelEXT structure specifying the parameters of the
-- label to insert.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pLabelInfo must be a valid pointer to a valid
-- VkDebugUtilsLabelEXT structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkDebugUtilsLabelEXT
vkCmdInsertDebugUtilsLabelEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("pLabelInfo" ::: Ptr VkDebugUtilsLabelEXT) -> IO ()
-- | vkCreateDebugUtilsMessengerEXT - Create a debug messenger object
--
-- Parameters
--
--
-- - instance the instance the messenger will be used
-- with.
--
--
--
-- - pCreateInfo points to a
-- VkDebugUtilsMessengerCreateInfoEXT structure which contains the
-- callback pointer as well as defines the conditions under which this
-- messenger will trigger the callback.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pMessenger is a pointer to record the
-- VkDebugUtilsMessengerEXT object created.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDebugUtilsMessengerCreateInfoEXT structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pMessenger must be a valid pointer to a
-- VkDebugUtilsMessengerEXT handle
--
--
-- Return Codes
--
--
--
--
-- - Failure - VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks,
-- VkDebugUtilsMessengerCreateInfoEXT,
-- VkDebugUtilsMessengerEXT, VkInstance
vkCreateDebugUtilsMessengerEXT :: ("instance" ::: VkInstance) -> ("pCreateInfo" ::: Ptr VkDebugUtilsMessengerCreateInfoEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pMessenger" ::: Ptr VkDebugUtilsMessengerEXT) -> IO VkResult
-- | vkDestroyDebugUtilsMessengerEXT - Destroy a debug messenger object
--
-- Parameters
--
--
-- - instance the instance where the callback was
-- created.
--
--
--
-- - messenger the VkDebugUtilsMessengerEXT object to
-- destroy. messenger is an externally synchronized object and
-- must not be used on more than one thread at a time. This means
-- that vkDestroyDebugUtilsMessengerEXT must not be
-- called when a callback is active.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- messenger was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- messenger was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - messenger must be a valid
-- VkDebugUtilsMessengerEXT handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - messenger must have been created, allocated, or
-- retrieved from instance
--
--
-- Host Synchronization
--
--
-- - Host access to messenger must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDebugUtilsMessengerEXT,
-- VkInstance
vkDestroyDebugUtilsMessengerEXT :: ("instance" ::: VkInstance) -> ("messenger" ::: VkDebugUtilsMessengerEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkSubmitDebugUtilsMessageEXT - Inject a message into a debug stream
--
-- Parameters
--
--
-- - instance is the debug stream’s VkInstance.
--
--
--
--
-- Description
--
-- The call will propagate through the layers and generate callback(s) as
-- indicated by the message’s flags. The parameters are passed on to the
-- callback in addition to the pUserData value that was defined
-- at the time the messenger was registered.
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
--
-- See Also
--
-- VkDebugUtilsMessageSeverityFlagBitsEXT,
-- VkDebugUtilsMessageTypeFlagsEXT,
-- VkDebugUtilsMessengerCallbackDataEXT, VkInstance
vkSubmitDebugUtilsMessageEXT :: ("instance" ::: VkInstance) -> ("messageSeverity" ::: VkDebugUtilsMessageSeverityFlagBitsEXT) -> ("messageTypes" ::: VkDebugUtilsMessageTypeFlagsEXT) -> ("pCallbackData" ::: Ptr VkDebugUtilsMessengerCallbackDataEXT) -> IO ()
-- | VkDebugUtilsObjectNameInfoEXT - Specify parameters of a name to give
-- to an object
--
-- Description
--
-- Applications may change the name associated with an object
-- simply by calling vkSetDebugUtilsObjectNameEXT again with a
-- new string. If pObjectName is an empty string, then any
-- previously set name is removed.
--
-- Valid Usage
--
--
-- - objectType must not be
-- VK_OBJECT_TYPE_UNKNOWN
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_NAME_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - objectType must be a valid VkObjectType
-- value
-- - If pObjectName is not NULL, pObjectName
-- must be a null-terminated UTF-8 string
--
--
-- See Also
--
-- VkDebugUtilsMessengerCallbackDataEXT, VkObjectType,
-- VkStructureType, vkSetDebugUtilsObjectNameEXT
data VkDebugUtilsObjectNameInfoEXT
VkDebugUtilsObjectNameInfoEXT :: VkStructureType -> Ptr () -> VkObjectType -> Word64 -> Ptr CChar -> VkDebugUtilsObjectNameInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugUtilsObjectNameInfoEXT] :: VkDebugUtilsObjectNameInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugUtilsObjectNameInfoEXT] :: VkDebugUtilsObjectNameInfoEXT -> Ptr ()
-- | objectType is a VkObjectType specifying the type of
-- the object to be named.
[$sel:vkObjectType:VkDebugUtilsObjectNameInfoEXT] :: VkDebugUtilsObjectNameInfoEXT -> VkObjectType
-- | objectHandle is the object to be named.
[$sel:vkObjectHandle:VkDebugUtilsObjectNameInfoEXT] :: VkDebugUtilsObjectNameInfoEXT -> Word64
-- | pObjectName is a null-terminated UTF-8 string specifying the
-- name to apply to objectHandle.
[$sel:vkPObjectName:VkDebugUtilsObjectNameInfoEXT] :: VkDebugUtilsObjectNameInfoEXT -> Ptr CChar
-- | VkDebugUtilsObjectTagInfoEXT - Specify parameters of a tag to attach
-- to an object
--
-- Description
--
-- The tagName parameter gives a name or identifier to the type
-- of data being tagged. This can be used by debugging layers to easily
-- filter for only data that can be used by that implementation.
--
-- Valid Usage
--
--
-- - objectType must not be
-- VK_OBJECT_TYPE_UNKNOWN
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_UTILS_OBJECT_TAG_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - objectType must be a valid VkObjectType
-- value
-- - pTag must be a valid pointer to an array of
-- tagSize bytes
-- - tagSize must be greater than 0
--
--
-- See Also
--
-- VkObjectType, VkStructureType,
-- vkSetDebugUtilsObjectTagEXT
data VkDebugUtilsObjectTagInfoEXT
VkDebugUtilsObjectTagInfoEXT :: VkStructureType -> Ptr () -> VkObjectType -> Word64 -> Word64 -> CSize -> Ptr () -> VkDebugUtilsObjectTagInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> Ptr ()
-- | objectType is a VkObjectType specifying the type of
-- the object to be named.
[$sel:vkObjectType:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> VkObjectType
-- | objectHandle is the object to be tagged.
[$sel:vkObjectHandle:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> Word64
-- | tagName is a numerical identifier of the tag.
[$sel:vkTagName:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> Word64
-- | tagSize is the number of bytes of data to attach to the
-- object.
[$sel:vkTagSize:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> CSize
-- | pTag is an array of tagSize bytes containing the
-- data to be associated with the object.
[$sel:vkPTag:VkDebugUtilsObjectTagInfoEXT] :: VkDebugUtilsObjectTagInfoEXT -> Ptr ()
-- | VkDebugUtilsLabelEXT - Specify parameters of a label region
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_UTILS_LABEL_EXT
--
--
--
-- - pNext must be NULL
-- - pLabelName must be a null-terminated UTF-8
-- string
--
--
-- See Also
--
-- VkDebugUtilsMessengerCallbackDataEXT, VkStructureType,
-- vkCmdBeginDebugUtilsLabelEXT,
-- vkCmdInsertDebugUtilsLabelEXT,
-- vkQueueBeginDebugUtilsLabelEXT,
-- vkQueueInsertDebugUtilsLabelEXT
data VkDebugUtilsLabelEXT
VkDebugUtilsLabelEXT :: VkStructureType -> Ptr () -> Ptr CChar -> Vector 4 CFloat -> VkDebugUtilsLabelEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugUtilsLabelEXT] :: VkDebugUtilsLabelEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugUtilsLabelEXT] :: VkDebugUtilsLabelEXT -> Ptr ()
-- | pLabelName is a pointer to a null-terminated UTF-8 string
-- that contains the name of the label.
[$sel:vkPLabelName:VkDebugUtilsLabelEXT] :: VkDebugUtilsLabelEXT -> Ptr CChar
-- | color is an optional RGBA color value that can be associated
-- with the label. A particular implementation may choose to
-- ignore this color value. The values contain RGBA values in order, in
-- the range 0.0 to 1.0. If all elements in color are set to 0.0
-- then it is ignored.
[$sel:vkColor:VkDebugUtilsLabelEXT] :: VkDebugUtilsLabelEXT -> Vector 4 CFloat
-- | VkDebugUtilsMessengerCreateInfoEXT - Structure specifying parameters
-- of a newly created debug messenger
--
-- Description
--
-- For each VkDebugUtilsMessengerEXT that is created the
-- VkDebugUtilsMessengerCreateInfoEXT::messageSeverity
-- and VkDebugUtilsMessengerCreateInfoEXT::messageTypes
-- determine when that
-- VkDebugUtilsMessengerCreateInfoEXT::pfnUserCallback
-- is called. The process to determine if the user’s pfnUserCallback is
-- triggered when an event occurs is as follows:
--
--
-- - The implementation will perform a bitwise AND of the event’s
-- VkDebugUtilsMessageSeverityFlagBitsEXT with the
-- messageSeverity provided during creation of the
-- VkDebugUtilsMessengerEXT object.
- If the value is 0, the
-- message is skipped.
-- - The implementation will perform bitwise AND of the event’s
-- VkDebugUtilsMessageTypeFlagBitsEXT with the
-- messageType provided during the creation of the
-- VkDebugUtilsMessengerEXT object.
- If the value is 0, the
-- message is skipped.
-- - The callback will trigger a debug message for the current
-- event
--
--
-- The callback will come directly from the component that detected the
-- event, unless some other layer intercepts the calls for its own
-- purposes (filter them in a different way, log to a system error log,
-- etc.).
--
-- An application can receive multiple callbacks if multiple
-- VkDebugUtilsMessengerEXT objects are created. A callback will
-- always be executed in the same thread as the originating Vulkan call.
--
-- A callback can be called from multiple threads simultaneously
-- (if the application is making Vulkan calls from multiple threads).
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- PFN_vkDebugUtilsMessengerCallbackEXT,
-- VkDebugUtilsMessageSeverityFlagsEXT,
-- VkDebugUtilsMessageTypeFlagsEXT,
-- VkDebugUtilsMessengerCreateFlagsEXT, VkStructureType,
-- vkCreateDebugUtilsMessengerEXT
data VkDebugUtilsMessengerCreateInfoEXT
VkDebugUtilsMessengerCreateInfoEXT :: VkStructureType -> Ptr () -> VkDebugUtilsMessengerCreateFlagsEXT -> VkDebugUtilsMessageSeverityFlagsEXT -> VkDebugUtilsMessageTypeFlagsEXT -> PFN_vkDebugUtilsMessengerCallbackEXT -> Ptr () -> VkDebugUtilsMessengerCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> Ptr ()
-- | flags is 0 and reserved for future use.
[$sel:vkFlags:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> VkDebugUtilsMessengerCreateFlagsEXT
-- | messageSeverity is a bitmask of
-- VkDebugUtilsMessageSeverityFlagBitsEXT specifying which
-- severity of event(s) will cause this callback to be called.
[$sel:vkMessageSeverity:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> VkDebugUtilsMessageSeverityFlagsEXT
[$sel:vkMessageType:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> VkDebugUtilsMessageTypeFlagsEXT
-- | pfnUserCallback is the application callback function to call.
[$sel:vkPfnUserCallback:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> PFN_vkDebugUtilsMessengerCallbackEXT
-- | pUserData is user data to be passed to the callback.
[$sel:vkPUserData:VkDebugUtilsMessengerCreateInfoEXT] :: VkDebugUtilsMessengerCreateInfoEXT -> Ptr ()
-- | VkDebugUtilsMessengerCallbackDataEXT - Structure specifying parameters
-- returned to the callback
--
-- Description
--
-- Note
--
-- This structure should only be considered valid during the lifetime of
-- the triggered callback.
--
-- Since adding queue and command buffer labels behaves like pushing and
-- popping onto a stack, the order of both pQueueLabels and
-- pCmdBufLabels is based on the order the labels were defined.
-- The result is that the first label in either pQueueLabels or
-- pCmdBufLabels will be the first defined (and therefore the
-- oldest) while the last label in each list will be the most recent.
--
-- Note
--
-- pQueueLabels will only be non-NULL if one of the objects in
-- pObjects can be related directly to a defined
-- VkQueue which has had one or more labels associated with it.
--
-- Likewise, pCmdBufLabels will only be non-NULL if one of the
-- objects in pObjects can be related directly to a defined
-- VkCommandBuffer which has had one or more labels associated
-- with it. Additionally, while command buffer labels allow for beginning
-- and ending across different command buffers, the debug messaging
-- framework cannot guarantee that labels in
-- pCmdBufLables will contain those defined outside of the
-- associated command buffer. This is partially due to the fact that the
-- association of one command buffer with another may not have been
-- defined at the time the debug message is triggered.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CALLBACK_DATA_EXT
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - If pMessageIdName is not NULL,
-- pMessageIdName must be a null-terminated UTF-8
-- string
-- - pMessage must be a null-terminated UTF-8
-- string
-- - objectCount must be greater than 0
--
--
-- See Also
--
-- VkDebugUtilsLabelEXT,
-- VkDebugUtilsMessengerCallbackDataFlagsEXT,
-- VkDebugUtilsObjectNameInfoEXT, VkStructureType,
-- vkSubmitDebugUtilsMessageEXT
data VkDebugUtilsMessengerCallbackDataEXT
VkDebugUtilsMessengerCallbackDataEXT :: VkStructureType -> Ptr () -> VkDebugUtilsMessengerCallbackDataFlagsEXT -> Ptr CChar -> Int32 -> Ptr CChar -> Word32 -> Ptr VkDebugUtilsLabelEXT -> Word32 -> Ptr VkDebugUtilsLabelEXT -> Word32 -> Ptr VkDebugUtilsObjectNameInfoEXT -> VkDebugUtilsMessengerCallbackDataEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr ()
-- | flags is 0 and reserved for future use.
[$sel:vkFlags:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> VkDebugUtilsMessengerCallbackDataFlagsEXT
-- | pMessageIdName is a null-terminated string that identifies
-- the the particular message ID that is associated with the provided
-- message. If the message corresponds to a validation layer message,
-- then this string may contain the portion of the Vulkan specification
-- that is believed to have been violated.
[$sel:vkPMessageIdName:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr CChar
-- | messageIdNumber is the ID number of the triggering message.
-- If the message corresponds to a validation layer message, then this
-- number is related to the internal number associated with the message
-- being triggered.
[$sel:vkMessageIdNumber:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Int32
-- | pMessage is a null-terminated string detailing the trigger
-- conditions.
[$sel:vkPMessage:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr CChar
-- | queueLabelCount is a count of items contained in the
-- pQueueLabels array.
[$sel:vkQueueLabelCount:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Word32
-- | pQueueLabels is NULL or a pointer to an array of
-- VkDebugUtilsLabelEXT active in the current VkQueue at
-- the time the callback was triggered. Refer to Queue Labels for
-- more information.
[$sel:vkPQueueLabels:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr VkDebugUtilsLabelEXT
-- | cmdBufLabelCount is a count of items contained in the
-- pCmdBufLabels array.
[$sel:vkCmdBufLabelCount:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Word32
-- | pCmdBufLabels is NULL or a pointer to an array of
-- VkDebugUtilsLabelEXT active in the current
-- VkCommandBuffer at the time the callback was triggered. Refer
-- to Command Buffer Labels for more information.
[$sel:vkPCmdBufLabels:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr VkDebugUtilsLabelEXT
-- | objectCount is a count of items contained in the
-- pObjects array.
[$sel:vkObjectCount:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Word32
-- | pObjects is a pointer to an array of
-- VkDebugUtilsObjectNameInfoEXT objects related to the detected
-- issue. The array is roughly in order or importance, but the 0th
-- element is always guaranteed to be the most important object for this
-- message.
[$sel:vkPObjects:VkDebugUtilsMessengerCallbackDataEXT] :: VkDebugUtilsMessengerCallbackDataEXT -> Ptr VkDebugUtilsObjectNameInfoEXT
type VkDebugUtilsMessageSeverityFlagsEXT = VkDebugUtilsMessageSeverityFlagBitsEXT
type VkDebugUtilsMessageTypeFlagsEXT = VkDebugUtilsMessageTypeFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsLabelEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsLabelEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectTagInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectTagInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectNameInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectNameInfoEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsLabelEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectTagInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsObjectNameInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCallbackDataFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessengerCreateFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageTypeFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_debug_utils.VkDebugUtilsMessageSeverityFlagBitsEXT
module Graphics.Vulkan.Extensions.VK_EXT_debug_marker
-- | vkDebugMarkerSetObjectNameEXT - Give a user-friendly name to an object
--
-- Parameters
--
--
-- - device is the device that created the object.
--
--
--
-- - pNameInfo is a pointer to an instance of the
-- VkDebugMarkerObjectNameInfoEXT structure specifying the
-- parameters of the name to set on the object.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pNameInfo must be a valid pointer to a valid
-- VkDebugMarkerObjectNameInfoEXT structure
--
--
-- Host Synchronization
--
--
-- - Host access to pNameInfo.object must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDebugMarkerObjectNameInfoEXT, VkDevice
vkDebugMarkerSetObjectNameEXT :: ("device" ::: VkDevice) -> ("pNameInfo" ::: Ptr VkDebugMarkerObjectNameInfoEXT) -> IO VkResult
-- | vkDebugMarkerSetObjectTagEXT - Attach arbitrary data to an object
--
-- Parameters
--
--
-- - device is the device that created the object.
--
--
--
-- - pTagInfo is a pointer to an instance of the
-- VkDebugMarkerObjectTagInfoEXT structure specifying the
-- parameters of the tag to attach to the object.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pTagInfo must be a valid pointer to a valid
-- VkDebugMarkerObjectTagInfoEXT structure
--
--
-- Host Synchronization
--
--
-- - Host access to pTagInfo.object must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDebugMarkerObjectTagInfoEXT, VkDevice
vkDebugMarkerSetObjectTagEXT :: ("device" ::: VkDevice) -> ("pTagInfo" ::: Ptr VkDebugMarkerObjectTagInfoEXT) -> IO VkResult
-- | vkCmdDebugMarkerBeginEXT - Open a command buffer marker region
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - pMarkerInfo is a pointer to an instance of the
-- VkDebugMarkerMarkerInfoEXT structure specifying the parameters
-- of the marker region to open.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pMarkerInfo must be a valid pointer to a valid
-- VkDebugMarkerMarkerInfoEXT structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkDebugMarkerMarkerInfoEXT
vkCmdDebugMarkerBeginEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("pMarkerInfo" ::: Ptr VkDebugMarkerMarkerInfoEXT) -> IO ()
-- | vkCmdDebugMarkerEndEXT - Close a command buffer marker region
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
-- Description
--
-- An application may open a marker region in one command buffer
-- and close it in another, or otherwise split marker regions across
-- multiple command buffers or multiple queue submissions. When viewed
-- from the linear series of submissions to a single queue, the calls to
-- vkCmdDebugMarkerBeginEXT and vkCmdDebugMarkerEndEXT
-- must be matched and balanced.
--
-- Valid Usage
--
--
-- - There must be an outstanding
-- vkCmdDebugMarkerBeginEXT command prior to the
-- vkCmdDebugMarkerEndEXT on the queue that
-- commandBuffer is submitted to
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdDebugMarkerEndEXT :: ("commandBuffer" ::: VkCommandBuffer) -> IO ()
-- | vkCmdDebugMarkerInsertEXT - Insert a marker label into a command
-- buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - pMarkerInfo is a pointer to an instance of the
-- VkDebugMarkerMarkerInfoEXT structure specifying the parameters
-- of the marker to insert.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pMarkerInfo must be a valid pointer to a valid
-- VkDebugMarkerMarkerInfoEXT structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkDebugMarkerMarkerInfoEXT
vkCmdDebugMarkerInsertEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("pMarkerInfo" ::: Ptr VkDebugMarkerMarkerInfoEXT) -> IO ()
-- | VkDebugMarkerObjectNameInfoEXT - Specify parameters of a name to give
-- to an object
--
-- Description
--
-- Applications may change the name associated with an object
-- simply by calling vkDebugMarkerSetObjectNameEXT again with a
-- new string. To remove a previously set name, pObjectName
-- should be set to an empty string.
--
-- Valid Usage
--
--
-- - objectType must not be
-- VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_NAME_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - objectType must be a valid
-- VkDebugReportObjectTypeEXT value
-- - pObjectName must be a null-terminated UTF-8
-- string
--
--
-- See Also
--
-- VkDebugReportObjectTypeEXT, VkStructureType,
-- vkDebugMarkerSetObjectNameEXT
data VkDebugMarkerObjectNameInfoEXT
VkDebugMarkerObjectNameInfoEXT :: VkStructureType -> Ptr () -> VkDebugReportObjectTypeEXT -> Word64 -> Ptr CChar -> VkDebugMarkerObjectNameInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugMarkerObjectNameInfoEXT] :: VkDebugMarkerObjectNameInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugMarkerObjectNameInfoEXT] :: VkDebugMarkerObjectNameInfoEXT -> Ptr ()
-- | objectType is a VkDebugReportObjectTypeEXT specifying
-- the type of the object to be named.
[$sel:vkObjectType:VkDebugMarkerObjectNameInfoEXT] :: VkDebugMarkerObjectNameInfoEXT -> VkDebugReportObjectTypeEXT
-- | object is the object to be named.
[$sel:vkObject:VkDebugMarkerObjectNameInfoEXT] :: VkDebugMarkerObjectNameInfoEXT -> Word64
-- | pObjectName is a null-terminated UTF-8 string specifying the
-- name to apply to object.
[$sel:vkPObjectName:VkDebugMarkerObjectNameInfoEXT] :: VkDebugMarkerObjectNameInfoEXT -> Ptr CChar
-- | VkDebugMarkerObjectTagInfoEXT - Specify parameters of a tag to attach
-- to an object
--
-- Description
--
-- The tagName parameter gives a name or identifier to the type
-- of data being tagged. This can be used by debugging layers to easily
-- filter for only data that can be used by that implementation.
--
-- Valid Usage
--
--
-- - objectType must not be
-- VK_DEBUG_REPORT_OBJECT_TYPE_UNKNOWN_EXT
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_MARKER_OBJECT_TAG_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - objectType must be a valid
-- VkDebugReportObjectTypeEXT value
-- - pTag must be a valid pointer to an array of
-- tagSize bytes
-- - tagSize must be greater than 0
--
--
-- See Also
--
-- VkDebugReportObjectTypeEXT, VkStructureType,
-- vkDebugMarkerSetObjectTagEXT
data VkDebugMarkerObjectTagInfoEXT
VkDebugMarkerObjectTagInfoEXT :: VkStructureType -> Ptr () -> VkDebugReportObjectTypeEXT -> Word64 -> Word64 -> CSize -> Ptr () -> VkDebugMarkerObjectTagInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> Ptr ()
-- | objectType is a VkDebugReportObjectTypeEXT specifying
-- the type of the object to be named.
[$sel:vkObjectType:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> VkDebugReportObjectTypeEXT
-- | object is the object to be tagged.
[$sel:vkObject:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> Word64
-- | tagName is a numerical identifier of the tag.
[$sel:vkTagName:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> Word64
-- | tagSize is the number of bytes of data to attach to the
-- object.
[$sel:vkTagSize:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> CSize
-- | pTag is an array of tagSize bytes containing the
-- data to be associated with the object.
[$sel:vkPTag:VkDebugMarkerObjectTagInfoEXT] :: VkDebugMarkerObjectTagInfoEXT -> Ptr ()
-- | VkDebugMarkerMarkerInfoEXT - Specify parameters of a command buffer
-- marker region
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT
--
--
--
-- - pNext must be NULL
-- - pMarkerName must be a null-terminated UTF-8
-- string
--
--
-- See Also
--
-- VkStructureType, vkCmdDebugMarkerBeginEXT,
-- vkCmdDebugMarkerInsertEXT
data VkDebugMarkerMarkerInfoEXT
VkDebugMarkerMarkerInfoEXT :: VkStructureType -> Ptr () -> Ptr CChar -> Vector 4 CFloat -> VkDebugMarkerMarkerInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDebugMarkerMarkerInfoEXT] :: VkDebugMarkerMarkerInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDebugMarkerMarkerInfoEXT] :: VkDebugMarkerMarkerInfoEXT -> Ptr ()
-- | pMarkerName is a pointer to a null-terminated UTF-8 string
-- that contains the name of the marker.
[$sel:vkPMarkerName:VkDebugMarkerMarkerInfoEXT] :: VkDebugMarkerMarkerInfoEXT -> Ptr CChar
-- | color is an optional RGBA color value that can be
-- associated with the marker. A particular implementation may
-- choose to ignore this color value. The values contain RGBA values in
-- order, in the range 0.0 to 1.0. If all elements in color are
-- set to 0.0 then it is ignored.
[$sel:vkColor:VkDebugMarkerMarkerInfoEXT] :: VkDebugMarkerMarkerInfoEXT -> Vector 4 CFloat
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerMarkerInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerMarkerInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectTagInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectTagInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectNameInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectNameInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerMarkerInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectTagInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_debug_marker.VkDebugMarkerObjectNameInfoEXT
module Graphics.Vulkan.Core10.QueueSemaphore
-- | VkSemaphoreCreateFlags - Reserved for future use
--
-- Description
--
-- VkSemaphoreCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkSemaphoreCreateInfo
newtype VkSemaphoreCreateFlags
VkSemaphoreCreateFlags :: VkFlags -> VkSemaphoreCreateFlags
-- | vkCreateSemaphore - Create a new queue semaphore object
--
-- Parameters
--
--
-- - device is the logical device that creates the
-- semaphore.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkSemaphoreCreateInfo structure which contains information
-- about how the semaphore is to be created.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pSemaphore points to a handle in which the resulting
-- semaphore object is returned.
--
--
-- Description
--
-- When created, the semaphore is in the unsignaled state.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkSemaphoreCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSemaphore must be a valid pointer to a
-- VkSemaphore handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkSemaphore,
-- VkSemaphoreCreateInfo
vkCreateSemaphore :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkSemaphoreCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSemaphore" ::: Ptr VkSemaphore) -> IO VkResult
-- | vkDestroySemaphore - Destroy a semaphore object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- semaphore.
--
--
--
-- - semaphore is the handle of the semaphore to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted batches that refer to semaphore must
-- have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- semaphore was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- semaphore was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If semaphore is not VK_NULL_HANDLE,
-- semaphore must be a valid VkSemaphore
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If semaphore is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to semaphore must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkSemaphore
vkDestroySemaphore :: ("device" ::: VkDevice) -> ("semaphore" ::: VkSemaphore) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkSemaphoreCreateInfo - Structure specifying parameters of a newly
-- created semaphore
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkSemaphoreCreateFlags, VkStructureType,
-- vkCreateSemaphore
data VkSemaphoreCreateInfo
VkSemaphoreCreateInfo :: VkStructureType -> Ptr () -> VkSemaphoreCreateFlags -> VkSemaphoreCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkSemaphoreCreateInfo] :: VkSemaphoreCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSemaphoreCreateInfo] :: VkSemaphoreCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkSemaphoreCreateInfo] :: VkSemaphoreCreateInfo -> VkSemaphoreCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.QueueSemaphore.VkSemaphoreCreateFlags
module Graphics.Vulkan.Core10.Query
-- | VkQueryType - Specify the type of queries managed by a query pool
--
-- See Also
--
-- VkQueryPoolCreateInfo
newtype VkQueryType
VkQueryType :: Int32 -> VkQueryType
-- | VK_QUERY_TYPE_OCCLUSION specifies an occlusion query.
-- | VK_QUERY_TYPE_PIPELINE_STATISTICS specifies a pipeline
-- statistics query.
-- | VK_QUERY_TYPE_TIMESTAMP specifies a timestamp query.
-- | VkQueryPoolCreateFlags - Reserved for future use
--
-- Description
--
-- VkQueryPoolCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkQueryPoolCreateInfo
newtype VkQueryPoolCreateFlags
VkQueryPoolCreateFlags :: VkFlags -> VkQueryPoolCreateFlags
-- | VkQueryResultFlagBits - Bitmask specifying how and when query results
-- are returned
--
-- See Also
--
-- VkQueryResultFlags
newtype VkQueryResultFlagBits
VkQueryResultFlagBits :: VkFlags -> VkQueryResultFlagBits
-- | VK_QUERY_RESULT_64_BIT specifies the results will be written
-- as an array of 64-bit unsigned integer values. If this bit is not set,
-- the results will be written as an array of 32-bit unsigned integer
-- values.
-- | VK_QUERY_RESULT_WAIT_BIT specifies that Vulkan will wait for
-- each query’s status to become available before retrieving its results.
-- | VK_QUERY_RESULT_WITH_AVAILABILITY_BIT specifies that the
-- availability status accompanies the results.
-- | VK_QUERY_RESULT_PARTIAL_BIT specifies that returning partial
-- results is acceptable.
-- | VkQueryPipelineStatisticFlagBits - Bitmask specifying queried pipeline
-- statistics
--
-- Description
--
--
-- - VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT
-- specifies that queries managed by the pool will count the number of
-- vertices processed by the input assembly stage. Vertices
-- corresponding to incomplete primitives may contribute to the
-- count.
--
--
--
-- - VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT
-- specifies that queries managed by the pool will count the number of
-- primitives processed by the input assembly stage. If primitive
-- restart is enabled, restarting the primitive topology has no effect on
-- the count. Incomplete primitives may be counted.
-- - VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- vertex shader invocations. This counter’s value is incremented each
-- time a vertex shader is invoked.
--
-- - VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- geometry shader invocations. This counter’s value is incremented each
-- time a geometry shader is invoked. In the case of instanced
-- geometry shaders, the geometry shader invocations count is
-- incremented for each separate instanced invocation.
--
-- - VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT
-- specifies that queries managed by the pool will count the number of
-- primitives generated by geometry shader invocations. The counter’s
-- value is incremented each time the geometry shader emits a primitive.
-- Restarting primitive topology using the SPIR-V instructions
-- OpEndPrimitive or OpEndStreamPrimitive has no effect
-- on the geometry shader output primitives count.
-- - VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- primitives processed by the Primitive Clipping stage of the
-- pipeline. The counter’s value is incremented each time a primitive
-- reaches the primitive clipping stage.
-- - VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT
-- specifies that queries managed by the pool will count the number of
-- primitives output by the Primitive Clipping stage of the
-- pipeline. The counter’s value is incremented each time a primitive
-- passes the primitive clipping stage. The actual number of primitives
-- output by the primitive clipping stage for a particular input
-- primitive is implementation-dependent but must satisfy the
-- following conditions:
- If at least one vertex of the input
-- primitive lies inside the clipping volume, the counter is incremented
-- by one or more.
- Otherwise, the counter is incremented by zero
-- or more.
--
-- - VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- fragment shader invocations. The counter’s value is incremented each
-- time the fragment shader is invoked.
--
-- - VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT
-- specifies that queries managed by the pool will count the number of
-- patches processed by the tessellation control shader. The counter’s
-- value is incremented once for each patch for which a tessellation
-- control shader is invoked.
--
-- - VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- invocations of the tessellation evaluation shader. The counter’s value
-- is incremented each time the tessellation evaluation shader is
-- invoked.
--
-- - VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT
-- specifies that queries managed by the pool will count the number of
-- compute shader invocations. The counter’s value is incremented every
-- time the compute shader is invoked. Implementations may skip
-- the execution of certain compute shader invocations or execute
-- additional compute shader invocations for implementation-dependent
-- reasons as long as the results of rendering otherwise remain
-- unchanged.
--
--
-- These values are intended to measure relative statistics on one
-- implementation. Various device architectures will count these values
-- differently. Any or all counters may be affected by the issues
-- described in Query Operation.
--
-- Note
--
-- For example, tile-based rendering devices may need to replay
-- the scene multiple times, affecting some of the counts.
--
-- If a pipeline has rasterizerDiscardEnable enabled,
-- implementations may discard primitives after the final vertex
-- processing stage. As a result, if rasterizerDiscardEnable is
-- enabled, the clipping input and output primitives counters may
-- not be incremented.
--
-- When a pipeline statistics query finishes, the result for that query
-- is marked as available. The application can copy the result to
-- a buffer (via vkCmdCopyQueryPoolResults), or request it be
-- put into host memory (via vkGetQueryPoolResults).
--
-- See Also
--
-- VkQueryPipelineStatisticFlags
newtype VkQueryPipelineStatisticFlagBits
VkQueryPipelineStatisticFlagBits :: VkFlags -> VkQueryPipelineStatisticFlagBits
-- | VkQueryPool - Opaque handle to a query pool object
--
-- Description
--
-- See Also
--
-- vkCmdBeginQuery, vkCmdCopyQueryPoolResults,
-- vkCmdEndQuery, vkCmdResetQueryPool,
-- vkCmdWriteTimestamp, vkCreateQueryPool,
-- vkDestroyQueryPool, vkGetQueryPoolResults
type VkQueryPool = Ptr VkQueryPool_T
-- | vkCreateQueryPool - Create a new query pool object
--
-- Parameters
--
--
-- - device is the logical device that creates the query
-- pool.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkQueryPoolCreateInfo structure containing the number and
-- type of queries to be managed by the pool.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pQueryPool is a pointer to a VkQueryPool handle
-- in which the resulting query pool object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkQueryPoolCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pQueryPool must be a valid pointer to a
-- VkQueryPool handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkQueryPool,
-- VkQueryPoolCreateInfo
vkCreateQueryPool :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkQueryPoolCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pQueryPool" ::: Ptr VkQueryPool) -> IO VkResult
-- | vkDestroyQueryPool - Destroy a query pool object
--
-- Parameters
--
--
-- - device is the logical device that destroys the query
-- pool.
--
--
--
-- - queryPool is the query pool to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to queryPool
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- queryPool was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- queryPool was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If queryPool is not VK_NULL_HANDLE,
-- queryPool must be a valid VkQueryPool
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If queryPool is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to queryPool must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkQueryPool
vkDestroyQueryPool :: ("device" ::: VkDevice) -> ("queryPool" ::: VkQueryPool) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetQueryPoolResults - Copy results of queries in a query pool to a
-- host memory region
--
-- Parameters
--
--
-- - device is the logical device that owns the query
-- pool.
--
--
--
-- - queryPool is the query pool managing the queries
-- containing the desired results.
-- - firstQuery is the initial query index.
-- - queryCount is the number of queries. firstQuery
-- and queryCount together define a range of queries. For
-- pipeline statistics queries, each query index in the pool contains one
-- integer value for each bit that is enabled in
-- VkQueryPoolCreateInfo::pipelineStatistics when the
-- pool is created.
-- - dataSize is the size in bytes of the buffer pointed to by
-- pData.
-- - pData is a pointer to a user-allocated buffer where the
-- results will be written
-- - stride is the stride in bytes between results for
-- individual queries within pData.
-- - flags is a bitmask of VkQueryResultFlagBits
-- specifying how and when results are returned.
--
--
-- Description
--
-- If no bits are set in flags, and all requested queries are in
-- the available state, results are written as an array of 32-bit
-- unsigned integer values. The behavior when not all queries are
-- available, is described below.
--
-- If VK_QUERY_RESULT_64_BIT is not set and the result overflows
-- a 32-bit value, the value may either wrap or saturate.
-- Similarly, if VK_QUERY_RESULT_64_BIT is set and the result
-- overflows a 64-bit value, the value may either wrap or
-- saturate.
--
-- If VK_QUERY_RESULT_WAIT_BIT is set, Vulkan will wait for each
-- query to be in the available state before retrieving the numerical
-- results for that query. In this case, vkGetQueryPoolResults
-- is guaranteed to succeed and return VK_SUCCESS if the queries
-- become available in a finite time (i.e. if they have been issued and
-- not reset). If queries will never finish (e.g. due to being reset but
-- not issued), then vkGetQueryPoolResults may not return
-- in finite time.
--
-- If VK_QUERY_RESULT_WAIT_BIT and
-- VK_QUERY_RESULT_PARTIAL_BIT are both not set then no result
-- values are written to pData for queries that are in the
-- unavailable state at the time of the call, and
-- vkGetQueryPoolResults returns VK_NOT_READY. However,
-- availability state is still written to pData for those
-- queries if VK_QUERY_RESULT_WITH_AVAILABILITY_BIT is set.
--
-- Note
--
-- Applications must take care to ensure that use of the
-- VK_QUERY_RESULT_WAIT_BIT bit has the desired effect.
--
-- For example, if a query has been used previously and a command buffer
-- records the commands vkCmdResetQueryPool,
-- vkCmdBeginQuery, and vkCmdEndQuery for that query,
-- then the query will remain in the available state until the
-- vkCmdResetQueryPool command executes on a queue. Applications
-- can use fences or events to ensure that a query has already
-- been reset before checking for its results or availability status.
-- Otherwise, a stale value could be returned from a previous use of the
-- query.
--
-- The above also applies when VK_QUERY_RESULT_WAIT_BIT is used
-- in combination with VK_QUERY_RESULT_WITH_AVAILABILITY_BIT. In
-- this case, the returned availability status may reflect the
-- result of a previous use of the query unless the
-- vkCmdResetQueryPool command has been executed since the last
-- use of the query.
--
-- Note
--
-- Applications can double-buffer query pool usage, with a pool
-- per frame, and reset queries at the end of the frame in which they are
-- read.
--
-- If VK_QUERY_RESULT_PARTIAL_BIT is set,
-- VK_QUERY_RESULT_WAIT_BIT is not set, and the query’s status
-- is unavailable, an intermediate result value between zero and the
-- final result value is written to pData for that query.
--
-- VK_QUERY_RESULT_PARTIAL_BIT must not be used if the
-- pool’s queryType is VK_QUERY_TYPE_TIMESTAMP.
--
-- If VK_QUERY_RESULT_WITH_AVAILABILITY_BIT is set, the final
-- integer value written for each query is non-zero if the query’s status
-- was available or zero if the status was unavailable. When
-- VK_QUERY_RESULT_WITH_AVAILABILITY_BIT is used,
-- implementations must guarantee that if they return a non-zero
-- availability value then the numerical results must be valid,
-- assuming the results are not reset by a subsequent command.
--
-- Note
--
-- Satisfying this guarantee may require careful ordering by the
-- application, e.g. to read the availability status before reading the
-- results.
--
-- Valid Usage
--
--
-- - firstQuery must be less than the number of queries
-- in queryPool
--
--
--
-- - If VK_QUERY_RESULT_64_BIT is not set in flags
-- then pData and stride must be multiples of
-- 4
-- - If VK_QUERY_RESULT_64_BIT is set in flags then
-- pData and stride must be multiples of
-- 8
-- - The sum of firstQuery and queryCount must
-- be less than or equal to the number of queries in
-- queryPool
-- - dataSize must be large enough to contain the
-- result of each query, as described here
-- - If the queryType used to create queryPool was
-- VK_QUERY_TYPE_TIMESTAMP, flags must not
-- contain VK_QUERY_RESULT_PARTIAL_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - queryPool must be a valid VkQueryPool
-- handle
-- - pData must be a valid pointer to an array of
-- dataSize bytes
-- - flags must be a valid combination of
-- VkQueryResultFlagBits values
-- - dataSize must be greater than 0
-- - queryPool must have been created, allocated, or
-- retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkDeviceSize, VkQueryPool,
-- VkQueryResultFlags
vkGetQueryPoolResults :: ("device" ::: VkDevice) -> ("queryPool" ::: VkQueryPool) -> ("firstQuery" ::: Word32) -> ("queryCount" ::: Word32) -> ("dataSize" ::: CSize) -> ("pData" ::: Ptr ()) -> ("stride" ::: VkDeviceSize) -> ("flags" ::: VkQueryResultFlags) -> IO VkResult
-- | VkQueryPoolCreateInfo - Structure specifying parameters of a newly
-- created query pool
--
-- Description
--
-- pipelineStatistics is ignored if queryType is not
-- VK_QUERY_TYPE_PIPELINE_STATISTICS.
--
-- Valid Usage
--
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - queryType must be a valid VkQueryType
-- value
--
--
-- See Also
--
-- VkQueryPipelineStatisticFlags, VkQueryPoolCreateFlags,
-- VkQueryType, VkStructureType, vkCreateQueryPool
data VkQueryPoolCreateInfo
VkQueryPoolCreateInfo :: VkStructureType -> Ptr () -> VkQueryPoolCreateFlags -> VkQueryType -> Word32 -> VkQueryPipelineStatisticFlags -> VkQueryPoolCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> VkQueryPoolCreateFlags
-- | queryType is a VkQueryType value specifying the type
-- of queries managed by the pool.
[$sel:vkQueryType:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> VkQueryType
-- | queryCount is the number of queries managed by the pool.
[$sel:vkQueryCount:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> Word32
-- | pipelineStatistics is a bitmask of
-- VkQueryPipelineStatisticFlagBits specifying which counters will
-- be returned in queries on the new pool, as described below in
-- {html_spec_relative}#queries-pipestats.
[$sel:vkPipelineStatistics:VkQueryPoolCreateInfo] :: VkQueryPoolCreateInfo -> VkQueryPipelineStatisticFlags
-- | VkQueryResultFlags - Bitmask of VkQueryResultFlagBits
--
-- Description
--
-- VkQueryResultFlags is a bitmask type for setting a mask of
-- zero or more VkQueryResultFlagBits.
--
-- See Also
--
-- VkQueryResultFlagBits, vkCmdCopyQueryPoolResults,
-- vkGetQueryPoolResults
type VkQueryResultFlags = VkQueryResultFlagBits
-- | VkQueryPipelineStatisticFlags - Bitmask of
-- VkQueryPipelineStatisticFlagBits
--
-- Description
--
-- VkQueryPipelineStatisticFlags is a bitmask type for setting a
-- mask of zero or more VkQueryPipelineStatisticFlagBits.
--
-- See Also
--
-- VkCommandBufferInheritanceInfo,
-- VkQueryPipelineStatisticFlagBits, VkQueryPoolCreateInfo
type VkQueryPipelineStatisticFlags = VkQueryPipelineStatisticFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Query.VkQueryPoolCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Query.VkQueryPoolCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Query.VkQueryType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Query.VkQueryType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Query.VkQueryType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Query.VkQueryPoolCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Query.VkQueryPipelineStatisticFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Query.VkQueryResultFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Query.VkQueryPoolCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Query.VkQueryType
instance GHC.Read.Read Graphics.Vulkan.Core10.Query.VkQueryType
module Graphics.Vulkan.Core10.PipelineCache
-- | VkPipelineCacheCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineCacheCreateFlags is a bitmask type for setting a
-- mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineCacheCreateInfo
newtype VkPipelineCacheCreateFlags
VkPipelineCacheCreateFlags :: VkFlags -> VkPipelineCacheCreateFlags
-- | VkPipelineCache - Opaque handle to a pipeline cache object
--
-- Description
--
-- See Also
--
-- vkCreateComputePipelines, vkCreateGraphicsPipelines,
-- vkCreatePipelineCache, vkDestroyPipelineCache,
-- vkGetPipelineCacheData, vkMergePipelineCaches
type VkPipelineCache = Ptr VkPipelineCache_T
-- | vkCreatePipelineCache - Creates a new pipeline cache
--
-- Parameters
--
--
-- - device is the logical device that creates the pipeline
-- cache object.
--
--
--
-- - pCreateInfo is a pointer to a
-- VkPipelineCacheCreateInfo structure that contains the initial
-- parameters for the pipeline cache object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pPipelineCache is a pointer to a VkPipelineCache
-- handle in which the resulting pipeline cache object is returned.
--
--
-- Description
--
-- Note
--
-- Applications can track and manage the total host memory size of
-- a pipeline cache object using the pAllocator. Applications
-- can limit the amount of data retrieved from a pipeline cache
-- object in vkGetPipelineCacheData. Implementations
-- should not internally limit the total number of entries added
-- to a pipeline cache object or the total host memory consumed.
--
-- Once created, a pipeline cache can be passed to the
-- vkCreateGraphicsPipelines and
-- vkCreateComputePipelines commands. If the pipeline cache
-- passed into these commands is not VK_NULL_HANDLE, the
-- implementation will query it for possible reuse opportunities and
-- update it with new content. The use of the pipeline cache object in
-- these commands is internally synchronized, and the same pipeline cache
-- object can be used in multiple threads simultaneously.
--
-- Note
--
-- Implementations should make every effort to limit any critical
-- sections to the actual accesses to the cache, which is expected to be
-- significantly shorter than the duration of the
-- vkCreateGraphicsPipelines and
-- vkCreateComputePipelines commands.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkPipelineCacheCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pPipelineCache must be a valid pointer to a
-- VkPipelineCache handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkPipelineCache,
-- VkPipelineCacheCreateInfo
vkCreatePipelineCache :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkPipelineCacheCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pPipelineCache" ::: Ptr VkPipelineCache) -> IO VkResult
-- | vkDestroyPipelineCache - Destroy a pipeline cache object
--
-- Parameters
--
--
-- - device is the logical device that destroys the pipeline
-- cache object.
--
--
--
-- - pipelineCache is the handle of the pipeline cache to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- pipelineCache was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- pipelineCache was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If pipelineCache is not VK_NULL_HANDLE,
-- pipelineCache must be a valid VkPipelineCache
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If pipelineCache is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to pipelineCache must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkPipelineCache
vkDestroyPipelineCache :: ("device" ::: VkDevice) -> ("pipelineCache" ::: VkPipelineCache) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetPipelineCacheData - Get the data store from a pipeline cache
--
-- Parameters
--
--
-- - device is the logical device that owns the pipeline
-- cache.
--
--
--
-- - pipelineCache is the pipeline cache to retrieve data
-- from.
-- - pDataSize is a pointer to a value related to the amount
-- of data in the pipeline cache, as described below.
-- - pData is either NULL or a pointer to a
-- buffer.
--
--
-- Description
--
-- If pData is NULL, then the maximum size of the data
-- that can be retrieved from the pipeline cache, in bytes, is
-- returned in pDataSize. Otherwise, pDataSize
-- must point to a variable set by the user to the size of the
-- buffer, in bytes, pointed to by pData, and on return the
-- variable is overwritten with the amount of data actually written to
-- pData.
--
-- If pDataSize is less than the maximum size that can be
-- retrieved by the pipeline cache, at most pDataSize bytes will
-- be written to pData, and vkGetPipelineCacheData will
-- return VK_INCOMPLETE. Any data written to pData is
-- valid and can be provided as the pInitialData member
-- of the VkPipelineCacheCreateInfo structure passed to
-- vkCreatePipelineCache.
--
-- Two calls to vkGetPipelineCacheData with the same parameters
-- must retrieve the same data unless a command that modifies the
-- contents of the cache is called between them.
--
-- Applications can store the data retrieved from the pipeline
-- cache, and use these data, possibly in a future run of the
-- application, to populate new pipeline cache objects. The results of
-- pipeline compiles, however, may depend on the vendor ID, device
-- ID, driver version, and other details of the device. To enable
-- applications to detect when previously retrieved data is incompatible
-- with the device, the initial bytes written to pData
-- must be a header consisting of the following members:
--
--
-- +----+--------------+--------------------------------------------------+
-- | Of | Size | Meaning |
-- | fs | | |
-- | et | | |
-- +====+==============+==================================================+
-- | 0 | 4 | length in bytes of the entire pipeline cache |
-- | | | header written as a stream of bytes, with the |
-- | | | least significant byte first |
-- +----+--------------+--------------------------------------------------+
-- | 4 | 4 | a |
-- | | | 'Graphics.Vulkan.Core10.Constants.VkPipelineCach |
-- | | | eHeaderVersion' |
-- | | | value written as a stream of bytes, with the |
-- | | | least significant byte first |
-- +----+--------------+--------------------------------------------------+
-- | 8 | 4 | a vendor ID equal to |
-- | | | @VkPhysicalDeviceProperties@::@vendorID@ written |
-- | | | as a stream of bytes, with the least significant |
-- | | | byte first |
-- +----+--------------+--------------------------------------------------+
-- | 12 | 4 | a device ID equal to |
-- | | | @VkPhysicalDeviceProperties@::@deviceID@ written |
-- | | | as a stream of bytes, with the least significant |
-- | | | byte first |
-- +----+--------------+--------------------------------------------------+
-- | 16 | @VK_UUID_SIZ | a pipeline cache ID equal to |
-- | | E@ | @VkPhysicalDeviceProperties@::@pipelineCacheUUID |
-- | | | @ |
-- +----+--------------+--------------------------------------------------+
--
-- Layout for pipeline cache header version
-- @VK_PIPELINE_CACHE_HEADER_VERSION_ONE@
--
--
-- The first four bytes encode the length of the entire pipeline cache
-- header, in bytes. This value includes all fields in the header
-- including the pipeline cache version field and the size of the length
-- field.
--
-- The next four bytes encode the pipeline cache version, as described
-- for VkPipelineCacheHeaderVersion. A consumer of the pipeline
-- cache should use the cache version to interpret the remainder
-- of the cache header.
--
-- If pDataSize is less than what is necessary to store this
-- header, nothing will be written to pData and zero will be
-- written to pDataSize.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pipelineCache must be a valid
-- VkPipelineCache handle
-- - pDataSize must be a valid pointer to a
-- size_t value
-- - If the value referenced by pDataSize is not 0,
-- and pData is not NULL, pData must be
-- a valid pointer to an array of pDataSize bytes
-- - pipelineCache must have been created, allocated,
-- or retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkPipelineCache
vkGetPipelineCacheData :: ("device" ::: VkDevice) -> ("pipelineCache" ::: VkPipelineCache) -> ("pDataSize" ::: Ptr CSize) -> ("pData" ::: Ptr ()) -> IO VkResult
-- | vkMergePipelineCaches - Combine the data stores of pipeline caches
--
-- Parameters
--
--
-- - device is the logical device that owns the pipeline cache
-- objects.
--
--
--
-- - dstCache is the handle of the pipeline cache to merge
-- results into.
-- - srcCacheCount is the length of the pSrcCaches
-- array.
-- - pSrcCaches is an array of pipeline cache handles, which
-- will be merged into dstCache. The previous contents of
-- dstCache are included after the merge.
--
--
-- Description
--
-- Note
--
-- The details of the merge operation are implementation dependent, but
-- implementations should merge the contents of the specified
-- pipelines and prune duplicate entries.
--
-- Valid Usage
--
--
-- - dstCache must not appear in the list of source
-- caches
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - dstCache must be a valid VkPipelineCache
-- handle
-- - pSrcCaches must be a valid pointer to an array of
-- srcCacheCount valid VkPipelineCache handles
-- - srcCacheCount must be greater than 0
-- - dstCache must have been created, allocated, or
-- retrieved from device
-- - Each element of pSrcCaches must have been created,
-- allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to dstCache must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkPipelineCache
vkMergePipelineCaches :: ("device" ::: VkDevice) -> ("dstCache" ::: VkPipelineCache) -> ("srcCacheCount" ::: Word32) -> ("pSrcCaches" ::: Ptr VkPipelineCache) -> IO VkResult
-- | VkPipelineCacheCreateInfo - Structure specifying parameters of a newly
-- created pipeline cache
--
-- Description
--
-- Valid Usage
--
--
-- - If initialDataSize is not 0, it must be
-- equal to the size of pInitialData, as returned by
-- vkGetPipelineCacheData when pInitialData was
-- originally retrieved
--
--
--
-- - If initialDataSize is not 0,
-- pInitialData must have been retrieved from a previous
-- call to vkGetPipelineCacheData
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - If initialDataSize is not 0,
-- pInitialData must be a valid pointer to an array of
-- initialDataSize bytes
--
--
-- See Also
--
-- VkPipelineCacheCreateFlags, VkStructureType,
-- vkCreatePipelineCache
data VkPipelineCacheCreateInfo
VkPipelineCacheCreateInfo :: VkStructureType -> Ptr () -> VkPipelineCacheCreateFlags -> CSize -> Ptr () -> VkPipelineCacheCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineCacheCreateInfo] :: VkPipelineCacheCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineCacheCreateInfo] :: VkPipelineCacheCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineCacheCreateInfo] :: VkPipelineCacheCreateInfo -> VkPipelineCacheCreateFlags
-- | initialDataSize is the number of bytes in
-- pInitialData. If initialDataSize is zero, the
-- pipeline cache will initially be empty.
[$sel:vkInitialDataSize:VkPipelineCacheCreateInfo] :: VkPipelineCacheCreateInfo -> CSize
-- | pInitialData is a pointer to previously retrieved pipeline
-- cache data. If the pipeline cache data is incompatible (as defined
-- below) with the device, the pipeline cache will be initially empty. If
-- initialDataSize is zero, pInitialData is ignored.
[$sel:vkPInitialData:VkPipelineCacheCreateInfo] :: VkPipelineCacheCreateInfo -> Ptr ()
instance GHC.Show.Show Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.PipelineCache.VkPipelineCacheCreateFlags
module Graphics.Vulkan.Core10.Pipeline
-- | VkBlendFactor - Framebuffer blending factors
--
-- Description
--
-- The semantics of each enum value is described in the table below:
--
--
-- +-----------------------------------------+-------------------+--------+
-- | VkBlendFactor | RGB Blend Factors | Alpha |
-- | | (Sr,Sg,Sb) or | Blend |
-- | | (Dr,Dg,Db) | Factor |
-- | | | (Sa or |
-- | | | Da) |
-- +=========================================+===================+========+
-- | @VK_BLEND_FACTOR_ZERO@ | (0,0,0) | 0 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE@ | (1,1,1) | 1 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_SRC_COLOR@ | (Rs0,Gs0,Bs0) | As0 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR@ | (1-Rs0,1-Gs0,1-Bs | 1-As0 |
-- | | 0) | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_DST_COLOR@ | (Rd,Gd,Bd) | Ad |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR@ | (1-Rd,1-Gd,1-Bd) | 1-Ad |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_SRC_ALPHA@ | (As0,As0,As0) | As0 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA@ | (1-As0,1-As0,1-As | 1-As0 |
-- | | 0) | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_DST_ALPHA@ | (Ad,Ad,Ad) | Ad |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA@ | (1-Ad,1-Ad,1-Ad) | 1-Ad |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_CONSTANT_COLOR@ | (Rc,Gc,Bc) | Ac |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COL | (1-Rc,1-Gc,1-Bc) | 1-Ac |
-- | OR@ | | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_CONSTANT_ALPHA@ | (Ac,Ac,Ac) | Ac |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_ALP | (1-Ac,1-Ac,1-Ac) | 1-Ac |
-- | HA@ | | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_SRC_ALPHA_SATURATE@ | (f,f,f); f = | 1 |
-- | | min(As0,1-Ad) | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_SRC1_COLOR@ | (Rs1,Gs1,Bs1) | As1 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR@ | (1-Rs1,1-Gs1,1-Bs | 1-As1 |
-- | | 1) | |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_SRC1_ALPHA@ | (As1,As1,As1) | As1 |
-- +-----------------------------------------+-------------------+--------+
-- | @VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA@ | (1-As1,1-As1,1-As | 1-As1 |
-- | | 1) | |
-- +-----------------------------------------+-------------------+--------+
--
-- Blend Factors
--
--
-- In this table, the following conventions are used:
--
--
-- - Rs0,Gs0,Bs0 and As0 represent the first source color R, G, B, and
-- A components, respectively, for the fragment output location
-- corresponding to the color attachment being blended.
-- - Rs1,Gs1,Bs1 and As1 represent the second source color R, G, B, and
-- A components, respectively, used in dual source blending modes, for
-- the fragment output location corresponding to the color attachment
-- being blended.
-- - Rd,Gd,Bd and Ad represent the R, G, B, and A components of the
-- destination color. That is, the color currently in the corresponding
-- color attachment for this fragment/sample.
-- - Rc,Gc,Bc and Ac represent the blend constant R, G, B, and A
-- components, respectively.
--
--
-- See Also
--
-- VkPipelineColorBlendAttachmentState
newtype VkBlendFactor
VkBlendFactor :: Int32 -> VkBlendFactor
-- | VkBlendOp - Framebuffer blending operations
--
-- Description
--
-- The semantics of each basic blend operations is described in the table
-- below:
--
--
-- +-------------------------------+--------------------+----------------+
-- | VkBlendOp | RGB Components | Alpha |
-- | | | Component |
-- +===============================+====================+================+
-- | @VK_BLEND_OP_ADD@ | R = Rs0 × Sr + Rd | A = As0 × Sa + |
-- | | × Dr | Ad × Da |
-- | | G = Gs0 × Sg + Gd | |
-- | | × Dg | |
-- | | B = Bs0 × Sb + Bd | |
-- | | × Db | |
-- +-------------------------------+--------------------+----------------+
-- | @VK_BLEND_OP_SUBTRACT@ | R = Rs0 × Sr - Rd | A = As0 × Sa - |
-- | | × Dr | Ad × Da |
-- | | G = Gs0 × Sg - Gd | |
-- | | × Dg | |
-- | | B = Bs0 × Sb - Bd | |
-- | | × Db | |
-- +-------------------------------+--------------------+----------------+
-- | @VK_BLEND_OP_REVERSE_SUBTRACT | R = Rd × Dr - Rs0 | A = Ad × Da - |
-- | @ | × Sr | As0 × Sa |
-- | | G = Gd × Dg - Gs0 | |
-- | | × Sg | |
-- | | B = Bd × Db - Bs0 | |
-- | | × Sb | |
-- +-------------------------------+--------------------+----------------+
-- | @VK_BLEND_OP_MIN@ | R = min(Rs0,Rd) | A = |
-- | | G = min(Gs0,Gd) | min(As0,Ad) |
-- | | B = min(Bs0,Bd) | |
-- +-------------------------------+--------------------+----------------+
-- | @VK_BLEND_OP_MAX@ | R = max(Rs0,Rd) | A = |
-- | | G = max(Gs0,Gd) | max(As0,Ad) |
-- | | B = max(Bs0,Bd) | |
-- +-------------------------------+--------------------+----------------+
--
-- Basic Blend Operations
--
--
-- In this table, the following conventions are used:
--
--
-- - Rs0, Gs0, Bs0 and As0 represent the first source color R, G, B,
-- and A components, respectively.
-- - Rd, Gd, Bd and Ad represent the R, G, B, and A components of the
-- destination color. That is, the color currently in the corresponding
-- color attachment for this fragment/sample.
-- - Sr, Sg, Sb and Sa represent the source blend factor R, G, B, and A
-- components, respectively.
-- - Dr, Dg, Db and Da represent the destination blend factor R, G, B,
-- and A components, respectively.
--
--
-- The blending operation produces a new set of values R, G, B and A,
-- which are written to the framebuffer attachment. If blending is not
-- enabled for this attachment, then R, G, B and A are assigned Rs0, Gs0,
-- Bs0 and As0, respectively.
--
-- If the color attachment is fixed-point, the components of the source
-- and destination values and blend factors are each clamped to [0,1] or
-- [-1,1] respectively for an unsigned normalized or signed normalized
-- color attachment prior to evaluating the blend operations. If the
-- color attachment is floating-point, no clamping occurs.
--
-- See Also
--
-- VkPipelineColorBlendAttachmentState
newtype VkBlendOp
VkBlendOp :: Int32 -> VkBlendOp
-- | VkCompareOp - Stencil comparison function
--
-- See Also
--
-- VkPipelineDepthStencilStateCreateInfo,
-- VkSamplerCreateInfo, VkStencilOpState
newtype VkCompareOp
VkCompareOp :: Int32 -> VkCompareOp
-- | VK_COMPARE_OP_NEVER specifies that the test never passes.
-- | VK_COMPARE_OP_LESS specifies that the test passes when R <
-- S.
-- | VK_COMPARE_OP_EQUAL specifies that the test passes when R =
-- S.
-- | VK_COMPARE_OP_LESS_OR_EQUAL specifies that the test passes
-- when R ≤ S.
-- | VK_COMPARE_OP_GREATER specifies that the test passes when R
-- > S.
-- | VK_COMPARE_OP_NOT_EQUAL specifies that the test passes when R
-- ≠ S.
-- | VK_COMPARE_OP_GREATER_OR_EQUAL specifies that the test passes
-- when R ≥ S.
-- | VK_COMPARE_OP_ALWAYS specifies that the test always passes.
-- | VkDynamicState - Indicate which dynamic state is taken from dynamic
-- state commands
--
-- See Also
--
-- VkPipelineDynamicStateCreateInfo
newtype VkDynamicState
VkDynamicState :: Int32 -> VkDynamicState
-- | VK_DYNAMIC_STATE_VIEWPORT specifies that the
-- pViewports state in
-- VkPipelineViewportStateCreateInfo will be ignored and
-- must be set dynamically with vkCmdSetViewport before any
-- draw commands. The number of viewports used by a pipeline is still
-- specified by the viewportCount member of
-- VkPipelineViewportStateCreateInfo.
-- | VK_DYNAMIC_STATE_SCISSOR specifies that the
-- pScissors state in VkPipelineViewportStateCreateInfo
-- will be ignored and must be set dynamically with
-- vkCmdSetScissor before any draw commands. The number of scissor
-- rectangles used by a pipeline is still specified by the
-- scissorCount member of
-- VkPipelineViewportStateCreateInfo.
-- | VK_DYNAMIC_STATE_LINE_WIDTH specifies that the
-- lineWidth state in
-- VkPipelineRasterizationStateCreateInfo will be ignored and
-- must be set dynamically with vkCmdSetLineWidth before
-- any draw commands that generate line primitives for the rasterizer.
-- | VK_DYNAMIC_STATE_DEPTH_BIAS specifies that the
-- depthBiasConstantFactor, depthBiasClamp and
-- depthBiasSlopeFactor states in
-- VkPipelineRasterizationStateCreateInfo will be ignored and
-- must be set dynamically with vkCmdSetDepthBias before
-- any draws are performed with depthBiasEnable in
-- VkPipelineRasterizationStateCreateInfo set to
-- VK_TRUE.
-- | VK_DYNAMIC_STATE_BLEND_CONSTANTS specifies that the
-- blendConstants state in
-- VkPipelineColorBlendStateCreateInfo will be ignored and
-- must be set dynamically with vkCmdSetBlendConstants
-- before any draws are performed with a pipeline state with
-- VkPipelineColorBlendAttachmentState member
-- blendEnable set to VK_TRUE and any of the blend
-- functions using a constant blend color.
-- | VK_DYNAMIC_STATE_DEPTH_BOUNDS specifies that the
-- minDepthBounds and maxDepthBounds states of
-- VkPipelineDepthStencilStateCreateInfo will be ignored and
-- must be set dynamically with vkCmdSetDepthBounds before
-- any draws are performed with a pipeline state with
-- VkPipelineDepthStencilStateCreateInfo member
-- depthBoundsTestEnable set to VK_TRUE.
-- | VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK specifies that the
-- compareMask state in
-- VkPipelineDepthStencilStateCreateInfo for both front
-- and back will be ignored and must be set dynamically
-- with vkCmdSetStencilCompareMask before any draws are performed
-- with a pipeline state with
-- VkPipelineDepthStencilStateCreateInfo member
-- stencilTestEnable set to VK_TRUE
-- | VK_DYNAMIC_STATE_STENCIL_WRITE_MASK specifies that the
-- writeMask state in
-- VkPipelineDepthStencilStateCreateInfo for both front
-- and back will be ignored and must be set dynamically
-- with vkCmdSetStencilWriteMask before any draws are performed
-- with a pipeline state with
-- VkPipelineDepthStencilStateCreateInfo member
-- stencilTestEnable set to VK_TRUE
-- | VK_DYNAMIC_STATE_STENCIL_REFERENCE specifies that the
-- reference state in
-- VkPipelineDepthStencilStateCreateInfo for both front
-- and back will be ignored and must be set dynamically
-- with vkCmdSetStencilReference before any draws are performed
-- with a pipeline state with
-- VkPipelineDepthStencilStateCreateInfo member
-- stencilTestEnable set to VK_TRUE
-- | VkPolygonMode - Control polygon rasterization mode
--
-- Description
--
--
-- - VK_POLYGON_MODE_POINT specifies that polygon vertices are
-- drawn as points.
--
--
--
-- - VK_POLYGON_MODE_LINE specifies that polygon edges are
-- drawn as line segments.
-- - VK_POLYGON_MODE_FILL specifies that polygons are rendered
-- using the polygon rasterization rules in this section.
-- - VK_POLYGON_MODE_FILL_RECTANGLE_NV specifies that polygons
-- are rendered using polygon rasterization rules, modified to consider a
-- sample within the primitive if the sample location is inside the
-- axis-aligned bounding box of the triangle after projection. Note that
-- the barycentric weights used in attribute interpolation can
-- extend outside the range [0,1] when these primitives are shaded.
-- Special treatment is given to a sample position on the boundary edge
-- of the bounding box. In such a case, if two rectangles lie on either
-- side of a common edge (with identical endpoints) on which a sample
-- position lies, then exactly one of the triangles must produce a
-- fragment that covers that sample during rasterization.Polygons
-- rendered in VK_POLYGON_MODE_FILL_RECTANGLE_NV mode may
-- be clipped by the frustum or by user clip planes. If clipping is
-- applied, the triangle is culled rather than clipped.Area calculation
-- and facingness are determined for
-- VK_POLYGON_MODE_FILL_RECTANGLE_NV mode using the triangle’s
-- vertices.
--
--
-- These modes affect only the final rasterization of polygons: in
-- particular, a polygon’s vertices are shaded and the polygon is clipped
-- and possibly culled before these modes are applied.
--
-- See Also
--
-- VkPipelineRasterizationStateCreateInfo
newtype VkPolygonMode
VkPolygonMode :: Int32 -> VkPolygonMode
-- | VkFrontFace - Interpret polygon front-facing orientation
--
-- Description
--
--
-- - VK_FRONT_FACE_COUNTER_CLOCKWISE specifies that a triangle
-- with positive area is considered front-facing.
--
--
--
-- - VK_FRONT_FACE_CLOCKWISE specifies that a triangle with
-- negative area is considered front-facing.
--
--
-- Any triangle which is not front-facing is back-facing, including
-- zero-area triangles.
--
-- See Also
--
-- VkPipelineRasterizationStateCreateInfo
newtype VkFrontFace
VkFrontFace :: Int32 -> VkFrontFace
-- | VkLogicOp - Framebuffer logical operations
--
-- Description
--
-- The logical operations supported by Vulkan are summarized in the
-- following table in which
--
--
-- - ¬ is bitwise invert,
-- - ∧ is bitwise and,
-- - ∨ is bitwise or,
-- - ⊕ is bitwise exclusive or,
-- - s is the fragment’s Rs0, Gs0, Bs0 or As0 component value for the
-- fragment output corresponding to the color attachment being updated,
-- and
-- - d is the color attachment’s R, G, B or A component value:
--
--
--
-- +-----------------------------------+-----------------------------------+
-- | Mode | Operation |
-- +===================================+===================================+
-- | @VK_LOGIC_OP_CLEAR@ | 0 |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_AND@ | s ∧ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_AND_REVERSE@ | s ∧ ¬ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_COPY@ | s |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_AND_INVERTED@ | ¬ s ∧ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_NO_OP@ | d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_XOR@ | s ⊕ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_OR@ | s ∨ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_NOR@ | ¬ (s ∨ d) |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_EQUIVALENT@ | ¬ (s ⊕ d) |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_INVERT@ | ¬ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_OR_REVERSE@ | s ∨ ¬ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_COPY_INVERTED@ | ¬ s |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_OR_INVERTED@ | ¬ s ∨ d |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_NAND@ | ¬ (s ∧ d) |
-- +-----------------------------------+-----------------------------------+
-- | @VK_LOGIC_OP_SET@ | all 1s |
-- +-----------------------------------+-----------------------------------+
--
-- Logical Operations
--
--
-- The result of the logical operation is then written to the color
-- attachment as controlled by the component write mask, described in
-- Blend Operations.
--
-- See Also
--
-- VkPipelineColorBlendStateCreateInfo
newtype VkLogicOp
VkLogicOp :: Int32 -> VkLogicOp
-- | VkPrimitiveTopology - Supported primitive topologies
--
-- Description
--
-- See Also
--
-- VkPipelineInputAssemblyStateCreateInfo
newtype VkPrimitiveTopology
VkPrimitiveTopology :: Int32 -> VkPrimitiveTopology
-- | VkStencilOp - Stencil comparison function
--
-- Description
--
--
-- - VK_STENCIL_OP_KEEP keeps the current value.
--
--
--
-- - VK_STENCIL_OP_ZERO sets the value to 0.
-- - VK_STENCIL_OP_REPLACE sets the value to
-- reference.
-- - VK_STENCIL_OP_INCREMENT_AND_CLAMP increments the current
-- value and clamps to the maximum representable unsigned value.
-- - VK_STENCIL_OP_DECREMENT_AND_CLAMP decrements the current
-- value and clamps to 0.
-- - VK_STENCIL_OP_INVERT bitwise-inverts the current
-- value.
-- - VK_STENCIL_OP_INCREMENT_AND_WRAP increments the current
-- value and wraps to 0 when the maximum value would have been
-- exceeded.
-- - VK_STENCIL_OP_DECREMENT_AND_WRAP decrements the current
-- value and wraps to the maximum possible value when the value would go
-- below 0.
--
--
-- For purposes of increment and decrement, the stencil bits are
-- considered as an unsigned integer.
--
-- If the stencil test fails, the sample’s coverage bit is cleared in the
-- fragment. If there is no stencil framebuffer attachment, stencil
-- modification cannot occur, and it is as if the stencil tests
-- always pass.
--
-- If the stencil test passes, the writeMask member of the
-- VkStencilOpState structures controls how the updated stencil
-- value is written to the stencil framebuffer attachment.
--
-- The least significant s bits of writeMask, where s is the
-- number of bits in the stencil framebuffer attachment, specify an
-- integer mask. Where a 1 appears in this mask, the corresponding bit in
-- the stencil value in the depth/stencil attachment is written; where a
-- 0 appears, the bit is not written. The writeMask value uses
-- either the front-facing or back-facing state based on the facingness
-- of the fragment. Fragments generated by front-facing primitives use
-- the front mask and fragments generated by back-facing primitives use
-- the back mask.
--
-- See Also
--
-- VkStencilOpState
newtype VkStencilOp
VkStencilOp :: Int32 -> VkStencilOp
-- | VkVertexInputRate - Specify rate at which vertex attributes are pulled
-- from buffers
--
-- See Also
--
-- VkVertexInputBindingDescription
newtype VkVertexInputRate
VkVertexInputRate :: Int32 -> VkVertexInputRate
-- | VK_VERTEX_INPUT_RATE_VERTEX specifies that vertex attribute
-- addressing is a function of the vertex index.
-- | VK_VERTEX_INPUT_RATE_INSTANCE specifies that vertex attribute
-- addressing is a function of the instance index.
-- | VkPipelineDepthStencilStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineDepthStencilStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineDepthStencilStateCreateInfo
newtype VkPipelineDepthStencilStateCreateFlags
VkPipelineDepthStencilStateCreateFlags :: VkFlags -> VkPipelineDepthStencilStateCreateFlags
-- | VkPipelineDynamicStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineDynamicStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineDynamicStateCreateInfo
newtype VkPipelineDynamicStateCreateFlags
VkPipelineDynamicStateCreateFlags :: VkFlags -> VkPipelineDynamicStateCreateFlags
-- | VkPipelineColorBlendStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineColorBlendStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineColorBlendStateCreateInfo
newtype VkPipelineColorBlendStateCreateFlags
VkPipelineColorBlendStateCreateFlags :: VkFlags -> VkPipelineColorBlendStateCreateFlags
-- | VkPipelineMultisampleStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineMultisampleStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineMultisampleStateCreateInfo
newtype VkPipelineMultisampleStateCreateFlags
VkPipelineMultisampleStateCreateFlags :: VkFlags -> VkPipelineMultisampleStateCreateFlags
-- | VkPipelineRasterizationStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineRasterizationStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineRasterizationStateCreateInfo
newtype VkPipelineRasterizationStateCreateFlags
VkPipelineRasterizationStateCreateFlags :: VkFlags -> VkPipelineRasterizationStateCreateFlags
-- | VkPipelineViewportStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineViewportStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineViewportStateCreateInfo
newtype VkPipelineViewportStateCreateFlags
VkPipelineViewportStateCreateFlags :: VkFlags -> VkPipelineViewportStateCreateFlags
-- | VkPipelineTessellationStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineTessellationStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineTessellationStateCreateInfo
newtype VkPipelineTessellationStateCreateFlags
VkPipelineTessellationStateCreateFlags :: VkFlags -> VkPipelineTessellationStateCreateFlags
-- | VkPipelineInputAssemblyStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineInputAssemblyStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineInputAssemblyStateCreateInfo
newtype VkPipelineInputAssemblyStateCreateFlags
VkPipelineInputAssemblyStateCreateFlags :: VkFlags -> VkPipelineInputAssemblyStateCreateFlags
-- | VkPipelineVertexInputStateCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineVertexInputStateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineVertexInputStateCreateInfo
newtype VkPipelineVertexInputStateCreateFlags
VkPipelineVertexInputStateCreateFlags :: VkFlags -> VkPipelineVertexInputStateCreateFlags
-- | VkPipelineShaderStageCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineShaderStageCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineShaderStageCreateInfo
newtype VkPipelineShaderStageCreateFlags
VkPipelineShaderStageCreateFlags :: VkFlags -> VkPipelineShaderStageCreateFlags
-- | VkShaderStageFlagBits - Bitmask specifying a pipeline stage
--
-- See Also
--
-- VkPipelineShaderStageCreateInfo, VkShaderStageFlags,
-- vkGetShaderInfoAMD
newtype VkShaderStageFlagBits
VkShaderStageFlagBits :: VkFlags -> VkShaderStageFlagBits
-- | VK_SHADER_STAGE_VERTEX_BIT specifies the vertex stage.
-- | VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT specifies the
-- tessellation control stage.
-- | VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT specifies the
-- tessellation evaluation stage.
-- | VK_SHADER_STAGE_GEOMETRY_BIT specifies the geometry stage.
-- | VK_SHADER_STAGE_FRAGMENT_BIT specifies the fragment stage.
-- | VK_SHADER_STAGE_COMPUTE_BIT specifies the compute stage.
-- | VK_SHADER_STAGE_ALL_GRAPHICS is a combination of bits used as
-- shorthand to specify all graphics stages defined above (excluding the
-- compute stage).
-- | VK_SHADER_STAGE_ALL is a combination of bits used as
-- shorthand to specify all shader stages supported by the device,
-- including all additional stages which are introduced by extensions.
-- | VkPipelineCreateFlagBits - Bitmask controlling how a pipeline is
-- created
--
-- Description
--
--
-- - VK_PIPELINE_CREATE_DISABLE_OPTIMIZATION_BIT specifies
-- that the created pipeline will not be optimized. Using this flag
-- may reduce the time taken to create the pipeline.
--
--
--
-- - VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT specifies that
-- the pipeline to be created is allowed to be the parent of a pipeline
-- that will be created in a subsequent call to
-- vkCreateGraphicsPipelines or
-- vkCreateComputePipelines.
-- - VK_PIPELINE_CREATE_DERIVATIVE_BIT specifies that the
-- pipeline to be created will be a child of a previously created parent
-- pipeline.
-- - VK_PIPELINE_CREATE_VIEW_INDEX_FROM_DEVICE_INDEX_BIT
-- specifies that any shader input variables decorated as
-- DeviceIndex will be assigned values as if they were decorated
-- as ViewIndex.
-- - VK_PIPELINE_CREATE_DISPATCH_BASE specifies that a compute
-- pipeline can be used with vkCmdDispatchBase with a
-- non-zero base workgroup.
--
--
-- It is valid to set both
-- VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT and
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT. This allows a pipeline to
-- be both a parent and possibly a child in a pipeline hierarchy. See
-- Pipeline Derivatives for more information.
--
-- See Also
--
-- VkPipelineCreateFlags
newtype VkPipelineCreateFlagBits
VkPipelineCreateFlagBits :: VkFlags -> VkPipelineCreateFlagBits
-- | VkColorComponentFlagBits - Bitmask controlling which components are
-- written to the framebuffer
--
-- Description
--
--
-- - VK_COLOR_COMPONENT_R_BIT specifies that the R value is
-- written to the color attachment for the appropriate sample. Otherwise,
-- the value in memory is unmodified.
--
--
--
-- - VK_COLOR_COMPONENT_G_BIT specifies that the G value is
-- written to the color attachment for the appropriate sample. Otherwise,
-- the value in memory is unmodified.
-- - VK_COLOR_COMPONENT_B_BIT specifies that the B value is
-- written to the color attachment for the appropriate sample. Otherwise,
-- the value in memory is unmodified.
-- - VK_COLOR_COMPONENT_A_BIT specifies that the A value is
-- written to the color attachment for the appropriate sample. Otherwise,
-- the value in memory is unmodified.
--
--
-- The color write mask operation is applied regardless of whether
-- blending is enabled.
--
-- See Also
--
-- VkColorComponentFlags
newtype VkColorComponentFlagBits
VkColorComponentFlagBits :: VkFlags -> VkColorComponentFlagBits
-- | VkCullModeFlagBits - Bitmask controlling triangle culling
--
-- Description
--
--
-- - VK_CULL_MODE_NONE specifies that no triangles are
-- discarded
--
--
--
-- - VK_CULL_MODE_FRONT_BIT specifies that front-facing
-- triangles are discarded
-- - VK_CULL_MODE_BACK_BIT specifies that back-facing
-- triangles are discarded
-- - VK_CULL_MODE_FRONT_AND_BACK specifies that all triangles
-- are discarded.
--
--
-- Following culling, fragments are produced for any triangles which have
-- not been discarded.
--
-- See Also
--
-- VkCullModeFlags
newtype VkCullModeFlagBits
VkCullModeFlagBits :: VkFlags -> VkCullModeFlagBits
-- | VkPipeline - Opaque handle to a pipeline object
--
-- Description
--
-- See Also
--
-- VkComputePipelineCreateInfo,
-- VkGraphicsPipelineCreateInfo,
-- VkObjectTablePipelineEntryNVX, vkCmdBindPipeline,
-- vkCreateComputePipelines, vkCreateGraphicsPipelines,
-- vkDestroyPipeline, vkGetShaderInfoAMD
type VkPipeline = Ptr VkPipeline_T
-- | VkPipelineLayout - Opaque handle to a pipeline layout object
--
-- Description
--
-- See Also
--
-- VkComputePipelineCreateInfo,
-- VkDescriptorUpdateTemplateCreateInfo,
-- VkGraphicsPipelineCreateInfo,
-- VkObjectTableDescriptorSetEntryNVX,
-- VkObjectTablePushConstantEntryNVX,
-- vkCmdBindDescriptorSets, vkCmdPushConstants,
-- vkCmdPushDescriptorSetKHR,
-- vkCmdPushDescriptorSetWithTemplateKHR,
-- vkCreatePipelineLayout, vkDestroyPipelineLayout
type VkPipelineLayout = Ptr VkPipelineLayout_T
-- | VkRenderPass - Opaque handle to a render pass object
--
-- Description
--
-- See Also
--
-- VkCommandBufferInheritanceInfo, VkFramebufferCreateInfo,
-- VkGraphicsPipelineCreateInfo, VkRenderPassBeginInfo,
-- vkCreateRenderPass, vkDestroyRenderPass,
-- vkGetRenderAreaGranularity
type VkRenderPass = Ptr VkRenderPass_T
-- | vkCreateGraphicsPipelines - Create graphics pipelines
--
-- Parameters
--
--
-- - device is the logical device that creates the graphics
-- pipelines.
--
--
--
-- - pipelineCache is either VK_NULL_HANDLE, indicating
-- that pipeline caching is disabled; or the handle of a valid
-- pipeline cache object, in which case use of that cache is
-- enabled for the duration of the command.
-- - createInfoCount is the length of the
-- pCreateInfos and pPipelines arrays.
-- - pCreateInfos is an array of
-- VkGraphicsPipelineCreateInfo structures.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pPipelines is a pointer to an array in which the
-- resulting graphics pipeline objects are returned.
--
--
-- Description
--
-- The VkGraphicsPipelineCreateInfo structure includes an array of
-- shader create info structures containing all the desired active shader
-- stages, as well as creation info to define all relevant fixed-function
-- stages, and a pipeline layout.
--
-- Valid Usage
--
--
-- - If the flags member of any element of
-- pCreateInfos contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and the
-- basePipelineIndex member of that same element is not
-- -1, basePipelineIndex must be less than the
-- index into pCreateInfos that corresponds to that element
--
--
--
-- - If the flags member of any element of
-- pCreateInfos contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, the base pipeline
-- must have been created with the
-- VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT flag set
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If pipelineCache is not VK_NULL_HANDLE,
-- pipelineCache must be a valid VkPipelineCache
-- handle
-- - pCreateInfos must be a valid pointer to an array
-- of createInfoCount valid
-- VkGraphicsPipelineCreateInfo structures
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pPipelines must be a valid pointer to an array of
-- createInfoCount VkPipeline handles
-- - createInfoCount must be greater than
-- 0
-- - If pipelineCache is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkGraphicsPipelineCreateInfo, VkPipeline,
-- VkPipelineCache
vkCreateGraphicsPipelines :: ("device" ::: VkDevice) -> ("pipelineCache" ::: VkPipelineCache) -> ("createInfoCount" ::: Word32) -> ("pCreateInfos" ::: Ptr VkGraphicsPipelineCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pPipelines" ::: Ptr VkPipeline) -> IO VkResult
-- | vkCreateComputePipelines - Creates a new compute pipeline object
--
-- Parameters
--
--
-- - device is the logical device that creates the compute
-- pipelines.
--
--
--
-- - pipelineCache is either VK_NULL_HANDLE, indicating
-- that pipeline caching is disabled; or the handle of a valid
-- pipeline cache object, in which case use of that cache is
-- enabled for the duration of the command.
-- - createInfoCount is the length of the
-- pCreateInfos and pPipelines arrays.
-- - pCreateInfos is an array of
-- VkComputePipelineCreateInfo structures.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pPipelines is a pointer to an array in which the
-- resulting compute pipeline objects are returned.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If the flags member of any element of
-- pCreateInfos contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and the
-- basePipelineIndex member of that same element is not
-- -1, basePipelineIndex must be less than the
-- index into pCreateInfos that corresponds to that element
--
--
--
-- - If the flags member of any element of
-- pCreateInfos contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, the base pipeline
-- must have been created with the
-- VK_PIPELINE_CREATE_ALLOW_DERIVATIVES_BIT flag set
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If pipelineCache is not VK_NULL_HANDLE,
-- pipelineCache must be a valid VkPipelineCache
-- handle
-- - pCreateInfos must be a valid pointer to an array
-- of createInfoCount valid VkComputePipelineCreateInfo
-- structures
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pPipelines must be a valid pointer to an array of
-- createInfoCount VkPipeline handles
-- - createInfoCount must be greater than
-- 0
-- - If pipelineCache is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkComputePipelineCreateInfo,
-- VkDevice, VkPipeline, VkPipelineCache
vkCreateComputePipelines :: ("device" ::: VkDevice) -> ("pipelineCache" ::: VkPipelineCache) -> ("createInfoCount" ::: Word32) -> ("pCreateInfos" ::: Ptr VkComputePipelineCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pPipelines" ::: Ptr VkPipeline) -> IO VkResult
-- | vkDestroyPipeline - Destroy a pipeline object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- pipeline.
--
--
--
-- - pipeline is the handle of the pipeline to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to pipeline must
-- have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- pipeline was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- pipeline was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If pipeline is not VK_NULL_HANDLE,
-- pipeline must be a valid VkPipeline
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If pipeline is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to pipeline must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkPipeline
vkDestroyPipeline :: ("device" ::: VkDevice) -> ("pipeline" ::: VkPipeline) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkOffset2D - Structure specifying a two-dimensional offset
--
-- Description
--
-- See Also
--
-- VkDisplayPlaneCapabilitiesKHR, VkRect2D,
-- VkRectLayerKHR
data VkOffset2D
VkOffset2D :: Int32 -> Int32 -> VkOffset2D
-- | x is the x offset.
[$sel:vkX:VkOffset2D] :: VkOffset2D -> Int32
-- | y is the y offset.
[$sel:vkY:VkOffset2D] :: VkOffset2D -> Int32
-- | VkExtent2D - Structure specifying a two-dimensional extent
--
-- Description
--
-- See Also
--
-- VkDisplayModeParametersKHR,
-- VkDisplayPlaneCapabilitiesKHR, VkDisplayPropertiesKHR,
-- VkDisplaySurfaceCreateInfoKHR,
-- VkMultisamplePropertiesEXT,
-- VkPhysicalDeviceSampleLocationsPropertiesEXT, VkRect2D,
-- VkRectLayerKHR, VkSampleLocationsInfoEXT,
-- VkSurfaceCapabilities2EXT, VkSurfaceCapabilitiesKHR,
-- VkSwapchainCreateInfoKHR, vkGetRenderAreaGranularity
data VkExtent2D
VkExtent2D :: Word32 -> Word32 -> VkExtent2D
-- | width is the width of the extent.
[$sel:vkWidth:VkExtent2D] :: VkExtent2D -> Word32
-- | height is the height of the extent.
[$sel:vkHeight:VkExtent2D] :: VkExtent2D -> Word32
-- | VkViewport - Structure specifying a viewport
--
-- Description
--
-- The framebuffer depth coordinate zf may be represented
-- using either a fixed-point or floating-point representation. However,
-- a floating-point representation must be used if the
-- depth/stencil attachment has a floating-point depth component. If an
-- m-bit fixed-point representation is used, we assume that it represents
-- each value <math>, where k ∈ { 0, 1, …, 2m-1 }, as k (e.g. 1.0
-- is represented in binary as a string of all ones).
--
-- The viewport parameters shown in the above equations are found from
-- these values as
--
--
-- - ox = x + width / 2
-- - oy = y + height / 2
-- - oz = minDepth
-- - px = width
-- - py = height
-- - pz = maxDepth - minDepth.
--
--
-- The application can specify a negative term for
-- height, which has the effect of negating the y coordinate in
-- clip space before performing the transform. When using a negative
-- height, the application should also adjust the
-- y value to point to the lower left corner of the viewport
-- instead of the upper left corner. Using the negative height
-- allows the application to avoid having to negate the y component of
-- the Position output from the last vertex processing stage in
-- shaders that also target other graphics APIs.
--
-- The width and height of the implementation-dependent maximum
-- viewport dimensions must be greater than or equal to the
-- width and height of the largest image which can be created and
-- attached to a framebuffer.
--
-- The floating-point viewport bounds are represented with an
-- implementation-dependent precision.
--
-- Valid Usage
--
--
-- - width must be greater than 0.0
--
--
--
-- - width must be less than or equal to
-- VkPhysicalDeviceLimits::maxViewportDimensions[0]
-- - The absolute value of height must be less than or
-- equal to
-- VkPhysicalDeviceLimits::maxViewportDimensions[1]
-- - x must be greater than or equal to
-- viewportBoundsRange[0]
-- - (x + width) must be less than or equal to
-- viewportBoundsRange[1]
-- - y must be greater than or equal to
-- viewportBoundsRange[0]
-- - y must be less than or equal to
-- viewportBoundsRange[1]
-- - (y + height) must be greater than or
-- equal to viewportBoundsRange[0]
-- - (y + height) must be less than or equal
-- to viewportBoundsRange[1]
-- - Unless
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled minDepth must be between
-- 0.0 and 1.0, inclusive
-- - Unless
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled maxDepth must be between
-- 0.0 and 1.0, inclusive
--
--
-- See Also
--
-- VkPipelineViewportStateCreateInfo, vkCmdSetViewport
data VkViewport
VkViewport :: CFloat -> CFloat -> CFloat -> CFloat -> CFloat -> CFloat -> VkViewport
-- | x and y are the viewport’s upper left corner (x,y).
[$sel:vkX:VkViewport] :: VkViewport -> CFloat
[$sel:vkY:VkViewport] :: VkViewport -> CFloat
-- | width and height are the viewport’s width and
-- height, respectively.
[$sel:vkWidth:VkViewport] :: VkViewport -> CFloat
[$sel:vkHeight:VkViewport] :: VkViewport -> CFloat
-- | minDepth and maxDepth are the depth range for the
-- viewport. It is valid for minDepth to be greater than or
-- equal to maxDepth.
[$sel:vkMinDepth:VkViewport] :: VkViewport -> CFloat
[$sel:vkMaxDepth:VkViewport] :: VkViewport -> CFloat
-- | VkRect2D - Structure specifying a two-dimensional subregion
--
-- Description
--
-- See Also
--
-- VkBindImageMemoryDeviceGroupInfo, VkClearRect,
-- VkDeviceGroupRenderPassBeginInfo,
-- VkDisplayPresentInfoKHR, VkExtent2D, VkOffset2D,
-- VkPipelineDiscardRectangleStateCreateInfoEXT,
-- VkPipelineViewportStateCreateInfo,
-- VkRenderPassBeginInfo, vkCmdSetDiscardRectangleEXT,
-- vkCmdSetScissor, vkGetPhysicalDevicePresentRectanglesKHR
data VkRect2D
VkRect2D :: VkOffset2D -> VkExtent2D -> VkRect2D
-- | offset is a VkOffset2D specifying the rectangle
-- offset.
[$sel:vkOffset:VkRect2D] :: VkRect2D -> VkOffset2D
-- | extent is a VkExtent2D specifying the rectangle
-- extent.
[$sel:vkExtent:VkRect2D] :: VkRect2D -> VkExtent2D
-- | VkSpecializationMapEntry - Structure specifying a specialization map
-- entry
--
-- Description
--
-- If a constantID value is not a specialization constant ID
-- used in the shader, that map entry does not affect the behavior of the
-- pipeline.
--
-- Valid Usage
--
--
-- - For a constantID specialization constant declared in a
-- shader, size must match the byte size of the
-- constantID. If the specialization constant is of type
-- boolean, size must be the byte size of
-- VkBool32
--
--
-- See Also
--
-- VkSpecializationInfo
data VkSpecializationMapEntry
VkSpecializationMapEntry :: Word32 -> Word32 -> CSize -> VkSpecializationMapEntry
-- | constantID is the ID of the specialization constant in
-- SPIR-V.
[$sel:vkConstantID:VkSpecializationMapEntry] :: VkSpecializationMapEntry -> Word32
-- | offset is the byte offset of the specialization constant
-- value within the supplied data buffer.
[$sel:vkOffset:VkSpecializationMapEntry] :: VkSpecializationMapEntry -> Word32
-- | size is the byte size of the specialization constant value
-- within the supplied data buffer.
[$sel:vkSize:VkSpecializationMapEntry] :: VkSpecializationMapEntry -> CSize
-- | VkSpecializationInfo - Structure specifying specialization info
--
-- Description
--
-- pMapEntries points to a structure of type
-- VkSpecializationMapEntry.
--
-- Valid Usage
--
--
-- - The offset member of each element of pMapEntries
-- must be less than dataSize
--
--
--
-- - The size member of each element of pMapEntries
-- must be less than or equal to dataSize minus
-- offset
-- - If mapEntryCount is not 0, pMapEntries
-- must be a valid pointer to an array of mapEntryCount
-- valid VkSpecializationMapEntry structures
--
--
-- Valid Usage (Implicit)
--
--
-- - If dataSize is not 0, pData must
-- be a valid pointer to an array of dataSize bytes
--
--
-- See Also
--
-- VkPipelineShaderStageCreateInfo,
-- VkSpecializationMapEntry
data VkSpecializationInfo
VkSpecializationInfo :: Word32 -> Ptr VkSpecializationMapEntry -> CSize -> Ptr () -> VkSpecializationInfo
-- | mapEntryCount is the number of entries in the
-- pMapEntries array.
[$sel:vkMapEntryCount:VkSpecializationInfo] :: VkSpecializationInfo -> Word32
-- | pMapEntries is a pointer to an array of
-- VkSpecializationMapEntry which maps constant IDs to offsets
-- in pData.
[$sel:vkPMapEntries:VkSpecializationInfo] :: VkSpecializationInfo -> Ptr VkSpecializationMapEntry
-- | dataSize is the byte size of the pData buffer.
[$sel:vkDataSize:VkSpecializationInfo] :: VkSpecializationInfo -> CSize
-- | pData contains the actual constant values to specialize with.
[$sel:vkPData:VkSpecializationInfo] :: VkSpecializationInfo -> Ptr ()
-- | VkPipelineShaderStageCreateInfo - Structure specifying parameters of a
-- newly created pipeline shader stage
--
-- Description
--
-- Valid Usage
--
--
-- - If the geometry shaders feature is not enabled,
-- stage must not be
-- VK_SHADER_STAGE_GEOMETRY_BIT
--
--
--
-- - If the tessellation shaders feature is not enabled,
-- stage must not be
-- VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT or
-- VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT
-- - stage must not be
-- VK_SHADER_STAGE_ALL_GRAPHICS, or
-- VK_SHADER_STAGE_ALL
-- - pName must be the name of an OpEntryPoint
-- in module with an execution model that matches
-- stage
-- - If the identified entry point includes any variable in its
-- interface that is declared with the ClipDistance
-- BuiltIn decoration, that variable must not have an
-- array size greater than
-- VkPhysicalDeviceLimits::maxClipDistances
-- - If the identified entry point includes any variable in its
-- interface that is declared with the CullDistance
-- BuiltIn decoration, that variable must not have an
-- array size greater than
-- VkPhysicalDeviceLimits::maxCullDistances
-- - If the identified entry point includes any variables in its
-- interface that are declared with the ClipDistance or
-- CullDistance BuiltIn decoration, those variables
-- must not have array sizes which sum to more than
-- VkPhysicalDeviceLimits::maxCombinedClipAndCullDistances
-- - If the identified entry point includes any variable in its
-- interface that is declared with the SampleMask
-- BuiltIn decoration, that variable must not have an
-- array size greater than
-- VkPhysicalDeviceLimits::maxSampleMaskWords
-- - If stage is VK_SHADER_STAGE_VERTEX_BIT, the
-- identified entry point must not include any input variable in
-- its interface that is decorated with CullDistance
-- - If stage is
-- VK_SHADER_STAGE_TESSELLATION_CONTROL_BIT or
-- VK_SHADER_STAGE_TESSELLATION_EVALUATION_BIT, and the
-- identified entry point has an OpExecutionMode instruction
-- that specifies a patch size with OutputVertices, the patch
-- size must be greater than 0 and less than or equal to
-- VkPhysicalDeviceLimits::maxTessellationPatchSize
-- - If stage is VK_SHADER_STAGE_GEOMETRY_BIT, the
-- identified entry point must have an OpExecutionMode
-- instruction that specifies a maximum output vertex count that is
-- greater than 0 and less than or equal to
-- VkPhysicalDeviceLimits::maxGeometryOutputVertices
-- - If stage is VK_SHADER_STAGE_GEOMETRY_BIT, the
-- identified entry point must have an OpExecutionMode
-- instruction that specifies an invocation count that is greater than
-- 0 and less than or equal to
-- VkPhysicalDeviceLimits::maxGeometryShaderInvocations
-- - If stage is VK_SHADER_STAGE_GEOMETRY_BIT, and
-- the identified entry point writes to Layer for any primitive,
-- it must write the same value to Layer for all vertices
-- of a given primitive
-- - If stage is VK_SHADER_STAGE_GEOMETRY_BIT, and
-- the identified entry point writes to ViewportIndex for any
-- primitive, it must write the same value to
-- ViewportIndex for all vertices of a given primitive
-- - If stage is VK_SHADER_STAGE_FRAGMENT_BIT, the
-- identified entry point must not include any output variables in
-- its interface decorated with CullDistance
-- - If stage is VK_SHADER_STAGE_FRAGMENT_BIT, and
-- the identified entry point writes to FragDepth in any
-- execution path, it must write to FragDepth in all
-- execution paths
-- - If stage is VK_SHADER_STAGE_FRAGMENT_BIT, and
-- the identified entry point writes to FragStencilRefEXT in any
-- execution path, it must write to FragStencilRefEXT in
-- all execution paths
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - stage must be a valid VkShaderStageFlagBits
-- value
-- - module must be a valid VkShaderModule
-- handle
-- - pName must be a null-terminated UTF-8 string
-- - If pSpecializationInfo is not NULL,
-- pSpecializationInfo must be a valid pointer to a valid
-- VkSpecializationInfo structure
--
--
-- See Also
--
-- VkComputePipelineCreateInfo,
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineShaderStageCreateFlags, VkShaderModule,
-- VkShaderStageFlagBits, VkSpecializationInfo,
-- VkStructureType
data VkPipelineShaderStageCreateInfo
VkPipelineShaderStageCreateInfo :: VkStructureType -> Ptr () -> VkPipelineShaderStageCreateFlags -> VkShaderStageFlagBits -> VkShaderModule -> Ptr CChar -> Ptr VkSpecializationInfo -> VkPipelineShaderStageCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> VkPipelineShaderStageCreateFlags
-- | stage is a VkShaderStageFlagBits value specifying a
-- single pipeline stage.
[$sel:vkStage:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> VkShaderStageFlagBits
-- | module is a VkShaderModule object that contains the
-- shader for this stage.
[$sel:vkModule:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> VkShaderModule
-- | pName is a pointer to a null-terminated UTF-8 string
-- specifying the entry point name of the shader for this stage.
[$sel:vkPName:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> Ptr CChar
-- | pSpecializationInfo is a pointer to
-- VkSpecializationInfo, as described in Specialization
-- Constants, and can be NULL.
[$sel:vkPSpecializationInfo:VkPipelineShaderStageCreateInfo] :: VkPipelineShaderStageCreateInfo -> Ptr VkSpecializationInfo
-- | VkComputePipelineCreateInfo - Structure specifying parameters of a
-- newly created compute pipeline
--
-- Description
--
-- The parameters basePipelineHandle and
-- basePipelineIndex are described in more detail in Pipeline
-- Derivatives.
--
-- stage points to a structure of type
-- VkPipelineShaderStageCreateInfo.
--
-- Valid Usage
--
--
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineIndex is -1, basePipelineHandle
-- must be a valid handle to a compute VkPipeline
--
--
--
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineHandle is VK_NULL_HANDLE,
-- basePipelineIndex must be a valid index into the
-- calling command’s pCreateInfos parameter
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineIndex is not -1, basePipelineHandle
-- must be VK_NULL_HANDLE
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineHandle is not VK_NULL_HANDLE,
-- basePipelineIndex must be -1
-- - The stage member of stage must be
-- VK_SHADER_STAGE_COMPUTE_BIT
-- - The shader code for the entry point identified by stage
-- and the rest of the state identified by this structure must
-- adhere to the pipeline linking rules described in the Shader
-- Interfaces chapter
-- - layout must be consistent with the layout
-- of the compute shader specified in stage
-- - The number of resources in layout accessible to the
-- compute shader stage must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageResources
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COMPUTE_PIPELINE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be a valid combination of
-- VkPipelineCreateFlagBits values
-- - stage must be a valid
-- VkPipelineShaderStageCreateInfo structure
-- - layout must be a valid VkPipelineLayout
-- handle
-- - Both of basePipelineHandle, and layout that are
-- valid handles must have been created, allocated, or retrieved
-- from the same VkDevice
--
--
-- See Also
--
-- VkPipeline, VkPipelineCreateFlags,
-- VkPipelineLayout, VkPipelineShaderStageCreateInfo,
-- VkStructureType, vkCreateComputePipelines
data VkComputePipelineCreateInfo
VkComputePipelineCreateInfo :: VkStructureType -> Ptr () -> VkPipelineCreateFlags -> VkPipelineShaderStageCreateInfo -> VkPipelineLayout -> VkPipeline -> Int32 -> VkComputePipelineCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> Ptr ()
-- | flags is a bitmask of VkPipelineCreateFlagBits
-- specifying how the pipeline will be generated.
[$sel:vkFlags:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> VkPipelineCreateFlags
-- | stage is a VkPipelineShaderStageCreateInfo describing
-- the compute shader.
[$sel:vkStage:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> VkPipelineShaderStageCreateInfo
-- | layout is the description of binding locations used by both
-- the pipeline and descriptor sets used with the pipeline.
[$sel:vkLayout:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> VkPipelineLayout
-- | basePipelineHandle is a pipeline to derive from
[$sel:vkBasePipelineHandle:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> VkPipeline
-- | basePipelineIndex is an index into the pCreateInfos
-- parameter to use as a pipeline to derive from
[$sel:vkBasePipelineIndex:VkComputePipelineCreateInfo] :: VkComputePipelineCreateInfo -> Int32
-- | VkVertexInputBindingDescription - Structure specifying vertex input
-- binding description
--
-- Description
--
-- Valid Usage
--
--
-- - binding must be less than
-- VkPhysicalDeviceLimits::maxVertexInputBindings
--
--
--
-- - stride must be less than or equal to
-- VkPhysicalDeviceLimits::maxVertexInputBindingStride
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkPipelineVertexInputStateCreateInfo, VkVertexInputRate
data VkVertexInputBindingDescription
VkVertexInputBindingDescription :: Word32 -> Word32 -> VkVertexInputRate -> VkVertexInputBindingDescription
-- | binding is the binding number that this structure describes.
[$sel:vkBinding:VkVertexInputBindingDescription] :: VkVertexInputBindingDescription -> Word32
-- | stride is the distance in bytes between two consecutive
-- elements within the buffer.
[$sel:vkStride:VkVertexInputBindingDescription] :: VkVertexInputBindingDescription -> Word32
-- | inputRate is a VkVertexInputRate value specifying
-- whether vertex attribute addressing is a function of the vertex index
-- or of the instance index.
[$sel:vkInputRate:VkVertexInputBindingDescription] :: VkVertexInputBindingDescription -> VkVertexInputRate
-- | VkVertexInputAttributeDescription - Structure specifying vertex input
-- attribute description
--
-- Description
--
-- Valid Usage
--
--
-- - location must be less than
-- VkPhysicalDeviceLimits::maxVertexInputAttributes
--
--
--
-- - binding must be less than
-- VkPhysicalDeviceLimits::maxVertexInputBindings
-- - offset must be less than or equal to
-- VkPhysicalDeviceLimits::maxVertexInputAttributeOffset
-- - format must be allowed as a vertex buffer format,
-- as specified by the VK_FORMAT_FEATURE_VERTEX_BUFFER_BIT flag
-- in VkFormatProperties::bufferFeatures returned by
-- vkGetPhysicalDeviceFormatProperties
--
--
-- Valid Usage (Implicit)
--
--
-- - format must be a valid VkFormat value
--
--
-- See Also
--
-- VkFormat, VkPipelineVertexInputStateCreateInfo
data VkVertexInputAttributeDescription
VkVertexInputAttributeDescription :: Word32 -> Word32 -> VkFormat -> Word32 -> VkVertexInputAttributeDescription
-- | location is the shader binding location number for this
-- attribute.
[$sel:vkLocation:VkVertexInputAttributeDescription] :: VkVertexInputAttributeDescription -> Word32
-- | binding is the binding number which this attribute takes its
-- data from.
[$sel:vkBinding:VkVertexInputAttributeDescription] :: VkVertexInputAttributeDescription -> Word32
-- | format is the size and type of the vertex attribute data.
[$sel:vkFormat:VkVertexInputAttributeDescription] :: VkVertexInputAttributeDescription -> VkFormat
-- | offset is a byte offset of this attribute relative to the
-- start of an element in the vertex input binding.
[$sel:vkOffset:VkVertexInputAttributeDescription] :: VkVertexInputAttributeDescription -> Word32
-- | VkPipelineVertexInputStateCreateInfo - Structure specifying parameters
-- of a newly created pipeline vertex input state
--
-- Description
--
-- Valid Usage
--
--
-- - vertexBindingDescriptionCount must be less than or
-- equal to
-- VkPhysicalDeviceLimits::maxVertexInputBindings
--
--
--
-- - vertexAttributeDescriptionCount must be less than
-- or equal to
-- VkPhysicalDeviceLimits::maxVertexInputAttributes
-- - For every binding specified by each element of
-- pVertexAttributeDescriptions, a
-- VkVertexInputBindingDescription must exist in
-- pVertexBindingDescriptions with the same value of
-- binding
-- - All elements of pVertexBindingDescriptions must
-- describe distinct binding numbers
-- - All elements of pVertexAttributeDescriptions must
-- describe distinct attribute locations
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of
-- VkPipelineVertexInputDivisorStateCreateInfoEXT
-- - flags must be 0
-- - If vertexBindingDescriptionCount is not 0,
-- pVertexBindingDescriptions must be a valid pointer to
-- an array of vertexBindingDescriptionCount valid
-- VkVertexInputBindingDescription structures
-- - If vertexAttributeDescriptionCount is not 0,
-- pVertexAttributeDescriptions must be a valid pointer
-- to an array of vertexAttributeDescriptionCount valid
-- VkVertexInputAttributeDescription structures
--
--
-- See Also
--
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineVertexInputStateCreateFlags, VkStructureType,
-- VkVertexInputAttributeDescription,
-- VkVertexInputBindingDescription
data VkPipelineVertexInputStateCreateInfo
VkPipelineVertexInputStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineVertexInputStateCreateFlags -> Word32 -> Ptr VkVertexInputBindingDescription -> Word32 -> Ptr VkVertexInputAttributeDescription -> VkPipelineVertexInputStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> VkPipelineVertexInputStateCreateFlags
-- | vertexBindingDescriptionCount is the number of vertex binding
-- descriptions provided in pVertexBindingDescriptions.
[$sel:vkVertexBindingDescriptionCount:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> Word32
-- | pVertexBindingDescriptions is a pointer to an array of
-- VkVertexInputBindingDescription structures.
[$sel:vkPVertexBindingDescriptions:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> Ptr VkVertexInputBindingDescription
-- | vertexAttributeDescriptionCount is the number of vertex
-- attribute descriptions provided in
-- pVertexAttributeDescriptions.
[$sel:vkVertexAttributeDescriptionCount:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> Word32
-- | pVertexAttributeDescriptions is a pointer to an array of
-- VkVertexInputAttributeDescription structures.
[$sel:vkPVertexAttributeDescriptions:VkPipelineVertexInputStateCreateInfo] :: VkPipelineVertexInputStateCreateInfo -> Ptr VkVertexInputAttributeDescription
-- | VkPipelineInputAssemblyStateCreateInfo - Structure specifying
-- parameters of a newly created pipeline input assembly state
--
-- Description
--
-- Restarting the assembly of primitives discards the most recent index
-- values if those elements formed an incomplete primitive, and restarts
-- the primitive assembly using the subsequent indices, but only
-- assembling the immediately following element through the end of the
-- originally specified elements. The primitive restart index value
-- comparison is performed before adding the vertexOffset value
-- to the index value.
--
-- Valid Usage
--
--
-- - If topology is VK_PRIMITIVE_TOPOLOGY_POINT_LIST,
-- VK_PRIMITIVE_TOPOLOGY_LINE_LIST,
-- VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST,
-- VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY,
-- VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY or
-- VK_PRIMITIVE_TOPOLOGY_PATCH_LIST,
-- primitiveRestartEnable must be VK_FALSE
--
--
--
-- - If the geometry shaders feature is not enabled,
-- topology must not be any of
-- VK_PRIMITIVE_TOPOLOGY_LINE_LIST_WITH_ADJACENCY,
-- VK_PRIMITIVE_TOPOLOGY_LINE_STRIP_WITH_ADJACENCY,
-- VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST_WITH_ADJACENCY or
-- VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP_WITH_ADJACENCY
-- - If the tessellation shaders feature is not enabled,
-- topology must not be
-- VK_PRIMITIVE_TOPOLOGY_PATCH_LIST
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - topology must be a valid
-- VkPrimitiveTopology value
--
--
-- See Also
--
-- VkBool32, VkGraphicsPipelineCreateInfo,
-- VkPipelineInputAssemblyStateCreateFlags,
-- VkPrimitiveTopology, VkStructureType
data VkPipelineInputAssemblyStateCreateInfo
VkPipelineInputAssemblyStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineInputAssemblyStateCreateFlags -> VkPrimitiveTopology -> VkBool32 -> VkPipelineInputAssemblyStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineInputAssemblyStateCreateInfo] :: VkPipelineInputAssemblyStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineInputAssemblyStateCreateInfo] :: VkPipelineInputAssemblyStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineInputAssemblyStateCreateInfo] :: VkPipelineInputAssemblyStateCreateInfo -> VkPipelineInputAssemblyStateCreateFlags
-- | topology is a VkPrimitiveTopology defining the
-- primitive topology, as described below.
[$sel:vkTopology:VkPipelineInputAssemblyStateCreateInfo] :: VkPipelineInputAssemblyStateCreateInfo -> VkPrimitiveTopology
-- | primitiveRestartEnable controls whether a special vertex
-- index value is treated as restarting the assembly of primitives. This
-- enable only applies to indexed draws (vkCmdDrawIndexed and
-- vkCmdDrawIndexedIndirect), and the special index value is
-- either 0xFFFFFFFF when the indexType parameter of
-- vkCmdBindIndexBuffer is equal to
-- VK_INDEX_TYPE_UINT32, or 0xFFFF when indexType is
-- equal to VK_INDEX_TYPE_UINT16. Primitive restart is not
-- allowed for “list” topologies.
[$sel:vkPrimitiveRestartEnable:VkPipelineInputAssemblyStateCreateInfo] :: VkPipelineInputAssemblyStateCreateInfo -> VkBool32
-- | VkPipelineTessellationStateCreateInfo - Structure specifying
-- parameters of a newly created pipeline tessellation state
--
-- Description
--
-- Valid Usage
--
--
-- - patchControlPoints must be greater than zero and
-- less than or equal to
-- VkPhysicalDeviceLimits::maxTessellationPatchSize
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineTessellationStateCreateFlags, VkStructureType
data VkPipelineTessellationStateCreateInfo
VkPipelineTessellationStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineTessellationStateCreateFlags -> Word32 -> VkPipelineTessellationStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineTessellationStateCreateInfo] :: VkPipelineTessellationStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineTessellationStateCreateInfo] :: VkPipelineTessellationStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineTessellationStateCreateInfo] :: VkPipelineTessellationStateCreateInfo -> VkPipelineTessellationStateCreateFlags
-- | patchControlPoints number of control points per patch.
[$sel:vkPatchControlPoints:VkPipelineTessellationStateCreateInfo] :: VkPipelineTessellationStateCreateInfo -> Word32
-- | VkPipelineViewportStateCreateInfo - Structure specifying parameters of
-- a newly created pipeline viewport state
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - If the multiple viewports feature is not enabled,
-- scissorCount must be 1
-- - viewportCount must be between 1 and
-- VkPhysicalDeviceLimits::maxViewports, inclusive
-- - scissorCount must be between 1 and
-- VkPhysicalDeviceLimits::maxViewports, inclusive
-- - scissorCount and viewportCount must be
-- identical
-- - If the viewportWScalingEnable member of a
-- VkPipelineViewportWScalingStateCreateInfoNV structure chained
-- to the pNext chain is VK_TRUE, the
-- viewportCount member of the
-- VkPipelineViewportWScalingStateCreateInfoNV structure
-- must be equal to viewportCount
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineViewportStateCreateFlags, VkRect2D,
-- VkStructureType, VkViewport
data VkPipelineViewportStateCreateInfo
VkPipelineViewportStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineViewportStateCreateFlags -> Word32 -> Ptr VkViewport -> Word32 -> Ptr VkRect2D -> VkPipelineViewportStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> VkPipelineViewportStateCreateFlags
-- | viewportCount is the number of viewports used by the
-- pipeline.
[$sel:vkViewportCount:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> Word32
-- | pViewports is a pointer to an array of VkViewport
-- structures, defining the viewport transforms. If the viewport state is
-- dynamic, this member is ignored.
[$sel:vkPViewports:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> Ptr VkViewport
-- | scissorCount is the number of scissors and must
-- match the number of viewports.
[$sel:vkScissorCount:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> Word32
-- | pScissors is a pointer to an array of VkRect2D
-- structures which define the rectangular bounds of the scissor for the
-- corresponding viewport. If the scissor state is dynamic, this member
-- is ignored.
[$sel:vkPScissors:VkPipelineViewportStateCreateInfo] :: VkPipelineViewportStateCreateInfo -> Ptr VkRect2D
-- | VkPipelineRasterizationStateCreateInfo - Structure specifying
-- parameters of a newly created pipeline rasterization state
--
-- Description
--
-- The application can also add a
-- VkPipelineRasterizationStateRasterizationOrderAMD structure
-- to the pNext chain of a
-- VkPipelineRasterizationStateCreateInfo structure. This
-- structure enables selecting the rasterization order to use when
-- rendering with the corresponding graphics pipeline as described in
-- Rasterization Order.
--
-- Valid Usage
--
--
-- - If the depth clamping feature is not enabled,
-- depthClampEnable must be VK_FALSE
--
--
--
-- - If the non-solid fill modes feature is not enabled,
-- polygonMode must be VK_POLYGON_MODE_FILL or
-- VK_POLYGON_MODE_FILL_RECTANGLE_NV
-- - If the {html_spec_relative}#VK_NV_fill_rectangle
-- extension is not enabled, polygonMode must not be
-- VK_POLYGON_MODE_FILL_RECTANGLE_NV
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkBool32, VkCullModeFlags, VkFrontFace,
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineRasterizationStateCreateFlags, VkPolygonMode,
-- VkStructureType
data VkPipelineRasterizationStateCreateInfo
VkPipelineRasterizationStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineRasterizationStateCreateFlags -> VkBool32 -> VkBool32 -> VkPolygonMode -> VkCullModeFlags -> VkFrontFace -> VkBool32 -> CFloat -> CFloat -> CFloat -> CFloat -> VkPipelineRasterizationStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkPipelineRasterizationStateCreateFlags
-- | depthClampEnable controls whether to clamp the fragment’s
-- depth values instead of clipping primitives to the z planes of the
-- frustum, as described in Primitive Clipping.
[$sel:vkDepthClampEnable:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkBool32
-- | rasterizerDiscardEnable controls whether primitives are
-- discarded immediately before the rasterization stage.
[$sel:vkRasterizerDiscardEnable:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkBool32
-- | polygonMode is the triangle rendering mode. See
-- VkPolygonMode.
[$sel:vkPolygonMode:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkPolygonMode
-- | cullMode is the triangle facing direction used for primitive
-- culling. See VkCullModeFlagBits.
[$sel:vkCullMode:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkCullModeFlags
-- | frontFace is a VkFrontFace value specifying the
-- front-facing triangle orientation to be used for culling.
[$sel:vkFrontFace:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkFrontFace
-- | depthBiasEnable controls whether to bias fragment depth
-- values.
[$sel:vkDepthBiasEnable:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> VkBool32
-- | depthBiasConstantFactor is a scalar factor controlling the
-- constant depth value added to each fragment.
[$sel:vkDepthBiasConstantFactor:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> CFloat
-- | depthBiasClamp is the maximum (or minimum) depth bias of a
-- fragment.
[$sel:vkDepthBiasClamp:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> CFloat
-- | depthBiasSlopeFactor is a scalar factor applied to a
-- fragment’s slope in depth bias calculations.
[$sel:vkDepthBiasSlopeFactor:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> CFloat
-- | lineWidth is the width of rasterized line segments.
[$sel:vkLineWidth:VkPipelineRasterizationStateCreateInfo] :: VkPipelineRasterizationStateCreateInfo -> CFloat
-- | VkPipelineMultisampleStateCreateInfo - Structure specifying parameters
-- of a newly created pipeline multisample state
--
-- Description
--
-- Valid Usage
--
--
-- - If the sample rate shading feature is not enabled,
-- sampleShadingEnable must be VK_FALSE
--
--
--
-- - If the alpha to one feature is not enabled,
-- alphaToOneEnable must be VK_FALSE
-- - minSampleShading must be in the range [0,1]
-- - If the subpass has any color attachments and
-- rasterizationSamples is greater than the number of color
-- samples, then sampleShadingEnable must be
-- VK_FALSE
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkBool32, VkGraphicsPipelineCreateInfo,
-- VkPipelineMultisampleStateCreateFlags,
-- VkSampleCountFlagBits, VkSampleMask,
-- VkStructureType
data VkPipelineMultisampleStateCreateInfo
VkPipelineMultisampleStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineMultisampleStateCreateFlags -> VkSampleCountFlagBits -> VkBool32 -> CFloat -> Ptr VkSampleMask -> VkBool32 -> VkBool32 -> VkPipelineMultisampleStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkPipelineMultisampleStateCreateFlags
-- | rasterizationSamples is a VkSampleCountFlagBits
-- specifying the number of samples per pixel used in rasterization.
[$sel:vkRasterizationSamples:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkSampleCountFlagBits
-- | sampleShadingEnable can be used to enable Sample
-- Shading.
[$sel:vkSampleShadingEnable:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkBool32
-- | minSampleShading specifies a minimum fraction of sample
-- shading if sampleShadingEnable is set to VK_TRUE.
[$sel:vkMinSampleShading:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> CFloat
-- | pSampleMask is a bitmask of static coverage information that
-- is ANDed with the coverage information generated during rasterization,
-- as described in Sample Mask.
[$sel:vkPSampleMask:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> Ptr VkSampleMask
-- | alphaToCoverageEnable controls whether a temporary coverage
-- value is generated based on the alpha component of the fragment’s
-- first color output as specified in the Multisample Coverage
-- section.
[$sel:vkAlphaToCoverageEnable:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkBool32
-- | alphaToOneEnable controls whether the alpha component of the
-- fragment’s first color output is replaced with one as described in
-- Multisample Coverage.
[$sel:vkAlphaToOneEnable:VkPipelineMultisampleStateCreateInfo] :: VkPipelineMultisampleStateCreateInfo -> VkBool32
-- | VkPipelineColorBlendAttachmentState - Structure specifying a pipeline
-- color blend attachment state
--
-- Description
--
-- Valid Usage
--
--
-- - If the dual source blending feature is not enabled,
-- srcColorBlendFactor must not be
-- VK_BLEND_FACTOR_SRC1_COLOR,
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,
-- VK_BLEND_FACTOR_SRC1_ALPHA, or
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
--
--
--
-- - If the dual source blending feature is not enabled,
-- dstColorBlendFactor must not be
-- VK_BLEND_FACTOR_SRC1_COLOR,
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,
-- VK_BLEND_FACTOR_SRC1_ALPHA, or
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
-- - If the dual source blending feature is not enabled,
-- srcAlphaBlendFactor must not be
-- VK_BLEND_FACTOR_SRC1_COLOR,
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,
-- VK_BLEND_FACTOR_SRC1_ALPHA, or
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
-- - If the dual source blending feature is not enabled,
-- dstAlphaBlendFactor must not be
-- VK_BLEND_FACTOR_SRC1_COLOR,
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR,
-- VK_BLEND_FACTOR_SRC1_ALPHA, or
-- VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
-- - If either of colorBlendOp or alphaBlendOp is an
-- advanced blend operation, then colorBlendOp
-- must equal alphaBlendOp
-- - If
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT::advancedBlendIndependentBlend
-- is VK_FALSE and colorBlendOp is an advanced blend
-- operation, then colorBlendOp must be the same for
-- all attachments.
-- - If
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT::advancedBlendIndependentBlend
-- is VK_FALSE and alphaBlendOp is an advanced blend
-- operation, then alphaBlendOp must be the same for
-- all attachments.
-- - If
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT::advancedBlendAllOperations
-- is VK_FALSE, then colorBlendOp must not be
-- VK_BLEND_OP_ZERO_EXT, VK_BLEND_OP_SRC_EXT,
-- VK_BLEND_OP_DST_EXT, VK_BLEND_OP_SRC_OVER_EXT,
-- VK_BLEND_OP_DST_OVER_EXT, VK_BLEND_OP_SRC_IN_EXT,
-- VK_BLEND_OP_DST_IN_EXT, VK_BLEND_OP_SRC_OUT_EXT,
-- VK_BLEND_OP_DST_OUT_EXT, VK_BLEND_OP_SRC_ATOP_EXT,
-- VK_BLEND_OP_DST_ATOP_EXT, VK_BLEND_OP_XOR_EXT,
-- VK_BLEND_OP_INVERT_EXT, VK_BLEND_OP_INVERT_RGB_EXT,
-- VK_BLEND_OP_LINEARDODGE_EXT,
-- VK_BLEND_OP_LINEARBURN_EXT,
-- VK_BLEND_OP_VIVIDLIGHT_EXT,
-- VK_BLEND_OP_LINEARLIGHT_EXT,
-- VK_BLEND_OP_PINLIGHT_EXT, VK_BLEND_OP_HARDMIX_EXT,
-- VK_BLEND_OP_PLUS_EXT, VK_BLEND_OP_PLUS_CLAMPED_EXT,
-- VK_BLEND_OP_PLUS_CLAMPED_ALPHA_EXT,
-- VK_BLEND_OP_PLUS_DARKER_EXT, VK_BLEND_OP_MINUS_EXT,
-- VK_BLEND_OP_MINUS_CLAMPED_EXT,
-- VK_BLEND_OP_CONTRAST_EXT,
-- VK_BLEND_OP_INVERT_OVG_EXT, VK_BLEND_OP_RED_EXT,
-- VK_BLEND_OP_GREEN_EXT, or VK_BLEND_OP_BLUE_EXT
-- - If colorBlendOp or alphaBlendOp is an
-- advanced blend operation, then
-- VkSubpassDescription::colorAttachmentCount of the
-- subpass this pipeline is compiled against must be less than or
-- equal to
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT::advancedBlendMaxColorAttachments
--
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkBlendFactor, VkBlendOp, VkBool32,
-- VkColorComponentFlags,
-- VkPipelineColorBlendStateCreateInfo
data VkPipelineColorBlendAttachmentState
VkPipelineColorBlendAttachmentState :: VkBool32 -> VkBlendFactor -> VkBlendFactor -> VkBlendOp -> VkBlendFactor -> VkBlendFactor -> VkBlendOp -> VkColorComponentFlags -> VkPipelineColorBlendAttachmentState
-- | blendEnable controls whether blending is enabled for the
-- corresponding color attachment. If blending is not enabled, the source
-- fragment’s color for that attachment is passed through unmodified.
[$sel:vkBlendEnable:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBool32
-- | srcColorBlendFactor selects which blend factor is used to
-- determine the source factors (Sr,Sg,Sb).
[$sel:vkSrcColorBlendFactor:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendFactor
-- | dstColorBlendFactor selects which blend factor is used to
-- determine the destination factors (Dr,Dg,Db).
[$sel:vkDstColorBlendFactor:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendFactor
-- | colorBlendOp selects which blend operation is used to
-- calculate the RGB values to write to the color attachment.
[$sel:vkColorBlendOp:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendOp
-- | srcAlphaBlendFactor selects which blend factor is used to
-- determine the source factor Sa.
[$sel:vkSrcAlphaBlendFactor:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendFactor
-- | dstAlphaBlendFactor selects which blend factor is used to
-- determine the destination factor Da.
[$sel:vkDstAlphaBlendFactor:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendFactor
-- | alphaBlendOp selects which blend operation is use to
-- calculate the alpha values to write to the color attachment.
[$sel:vkAlphaBlendOp:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkBlendOp
-- | colorWriteMask is a bitmask of
-- VkColorComponentFlagBits specifying which of the R, G, B,
-- and/or A components are enabled for writing, as described for the
-- Color Write Mask.
[$sel:vkColorWriteMask:VkPipelineColorBlendAttachmentState] :: VkPipelineColorBlendAttachmentState -> VkColorComponentFlags
-- | VkPipelineColorBlendStateCreateInfo - Structure specifying parameters
-- of a newly created pipeline color blend state
--
-- Description
--
-- Each element of the pAttachments array is a
-- VkPipelineColorBlendAttachmentState structure specifying
-- per-target blending state for each individual color attachment. If the
-- independent blending feature is not enabled on the device, all
-- VkPipelineColorBlendAttachmentState elements in the
-- pAttachments array must be identical.
--
-- Valid Usage
--
--
-- - If the independent blending feature is not enabled, all
-- elements of pAttachments must be identical
--
--
--
-- - If the logic operations feature is not enabled,
-- logicOpEnable must be VK_FALSE
-- - If logicOpEnable is VK_TRUE, logicOp
-- must be a valid VkLogicOp value
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT
-- - flags must be 0
-- - If attachmentCount is not 0,
-- pAttachments must be a valid pointer to an array of
-- attachmentCount valid
-- VkPipelineColorBlendAttachmentState structures
--
--
-- See Also
--
-- VkBool32, VkGraphicsPipelineCreateInfo,
-- VkLogicOp, VkPipelineColorBlendAttachmentState,
-- VkPipelineColorBlendStateCreateFlags, VkStructureType
data VkPipelineColorBlendStateCreateInfo
VkPipelineColorBlendStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineColorBlendStateCreateFlags -> VkBool32 -> VkLogicOp -> Word32 -> Ptr VkPipelineColorBlendAttachmentState -> Vector 4 CFloat -> VkPipelineColorBlendStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> VkPipelineColorBlendStateCreateFlags
-- | logicOpEnable controls whether to apply Logical
-- Operations.
[$sel:vkLogicOpEnable:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> VkBool32
-- | logicOp selects which logical operation to apply.
[$sel:vkLogicOp:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> VkLogicOp
-- | attachmentCount is the number of
-- VkPipelineColorBlendAttachmentState elements in
-- pAttachments. This value must equal the
-- colorAttachmentCount for the subpass in which this pipeline
-- is used.
[$sel:vkAttachmentCount:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> Word32
-- | pAttachments: is a pointer to array of per target attachment
-- states.
[$sel:vkPAttachments:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> Ptr VkPipelineColorBlendAttachmentState
-- | blendConstants is an array of four values used as the R, G,
-- B, and A components of the blend constant that are used in blending,
-- depending on the blend factor.
[$sel:vkBlendConstants:VkPipelineColorBlendStateCreateInfo] :: VkPipelineColorBlendStateCreateInfo -> Vector 4 CFloat
-- | VkPipelineDynamicStateCreateInfo - Structure specifying parameters of
-- a newly created pipeline dynamic state
--
-- Description
--
-- Valid Usage
--
--
-- - Each element of pDynamicStates must be unique
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - pDynamicStates must be a valid pointer to an array
-- of dynamicStateCount valid VkDynamicState values
-- - dynamicStateCount must be greater than
-- 0
--
--
-- See Also
--
-- VkDynamicState, VkGraphicsPipelineCreateInfo,
-- VkPipelineDynamicStateCreateFlags, VkStructureType
data VkPipelineDynamicStateCreateInfo
VkPipelineDynamicStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineDynamicStateCreateFlags -> Word32 -> Ptr VkDynamicState -> VkPipelineDynamicStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineDynamicStateCreateInfo] :: VkPipelineDynamicStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineDynamicStateCreateInfo] :: VkPipelineDynamicStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineDynamicStateCreateInfo] :: VkPipelineDynamicStateCreateInfo -> VkPipelineDynamicStateCreateFlags
-- | dynamicStateCount is the number of elements in the
-- pDynamicStates array.
[$sel:vkDynamicStateCount:VkPipelineDynamicStateCreateInfo] :: VkPipelineDynamicStateCreateInfo -> Word32
-- | pDynamicStates is an array of VkDynamicState values
-- specifying which pieces of pipeline state will use the values from
-- dynamic state commands rather than from pipeline state creation info.
[$sel:vkPDynamicStates:VkPipelineDynamicStateCreateInfo] :: VkPipelineDynamicStateCreateInfo -> Ptr VkDynamicState
-- | VkStencilOpState - Structure specifying stencil operation state
--
-- Description
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkCompareOp, VkPipelineDepthStencilStateCreateInfo,
-- VkStencilOp
data VkStencilOpState
VkStencilOpState :: VkStencilOp -> VkStencilOp -> VkStencilOp -> VkCompareOp -> Word32 -> Word32 -> Word32 -> VkStencilOpState
-- | failOp is a VkStencilOp value specifying the action
-- performed on samples that fail the stencil test.
[$sel:vkFailOp:VkStencilOpState] :: VkStencilOpState -> VkStencilOp
-- | passOp is a VkStencilOp value specifying the action
-- performed on samples that pass both the depth and stencil tests.
[$sel:vkPassOp:VkStencilOpState] :: VkStencilOpState -> VkStencilOp
-- | depthFailOp is a VkStencilOp value specifying the
-- action performed on samples that pass the stencil test and fail the
-- depth test.
[$sel:vkDepthFailOp:VkStencilOpState] :: VkStencilOpState -> VkStencilOp
-- | compareOp is a VkCompareOp value specifying the
-- comparison operator used in the stencil test.
[$sel:vkCompareOp:VkStencilOpState] :: VkStencilOpState -> VkCompareOp
-- | compareMask selects the bits of the unsigned integer stencil
-- values participating in the stencil test.
[$sel:vkCompareMask:VkStencilOpState] :: VkStencilOpState -> Word32
-- | writeMask selects the bits of the unsigned integer stencil
-- values updated by the stencil test in the stencil framebuffer
-- attachment.
[$sel:vkWriteMask:VkStencilOpState] :: VkStencilOpState -> Word32
-- | reference is an integer reference value that is used in the
-- unsigned stencil comparison.
[$sel:vkReference:VkStencilOpState] :: VkStencilOpState -> Word32
-- | VkPipelineDepthStencilStateCreateInfo - Structure specifying
-- parameters of a newly created pipeline depth stencil state
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - depthCompareOp must be a valid VkCompareOp
-- value
-- - front must be a valid VkStencilOpState
-- structure
-- - back must be a valid VkStencilOpState
-- structure
--
--
-- See Also
--
-- VkBool32, VkCompareOp,
-- VkGraphicsPipelineCreateInfo,
-- VkPipelineDepthStencilStateCreateFlags,
-- VkStencilOpState, VkStructureType
data VkPipelineDepthStencilStateCreateInfo
VkPipelineDepthStencilStateCreateInfo :: VkStructureType -> Ptr () -> VkPipelineDepthStencilStateCreateFlags -> VkBool32 -> VkBool32 -> VkCompareOp -> VkBool32 -> VkBool32 -> VkStencilOpState -> VkStencilOpState -> CFloat -> CFloat -> VkPipelineDepthStencilStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkPipelineDepthStencilStateCreateFlags
-- | depthTestEnable controls whether depth testing is
-- enabled.
[$sel:vkDepthTestEnable:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkBool32
-- | depthWriteEnable controls whether depth writes are
-- enabled when depthTestEnable is VK_TRUE. Depth
-- writes are always disabled when depthTestEnable is
-- VK_FALSE.
[$sel:vkDepthWriteEnable:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkBool32
-- | depthCompareOp is the comparison operator used in the
-- depth test.
[$sel:vkDepthCompareOp:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkCompareOp
-- | depthBoundsTestEnable controls whether depth bounds
-- testing is enabled.
[$sel:vkDepthBoundsTestEnable:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkBool32
-- | stencilTestEnable controls whether stencil testing is
-- enabled.
[$sel:vkStencilTestEnable:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkBool32
-- | front and back control the parameters of the
-- stencil test.
[$sel:vkFront:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkStencilOpState
[$sel:vkBack:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> VkStencilOpState
-- | minDepthBounds and maxDepthBounds define the range
-- of values used in the depth bounds test.
[$sel:vkMinDepthBounds:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> CFloat
[$sel:vkMaxDepthBounds:VkPipelineDepthStencilStateCreateInfo] :: VkPipelineDepthStencilStateCreateInfo -> CFloat
-- | VkGraphicsPipelineCreateInfo - Structure specifying parameters of a
-- newly created graphics pipeline
--
-- Description
--
-- The parameters basePipelineHandle and
-- basePipelineIndex are described in more detail in Pipeline
-- Derivatives.
--
-- pStages points to an array of
-- VkPipelineShaderStageCreateInfo structures, which were
-- previously described in Compute Pipelines.
--
-- pDynamicState points to a structure of type
-- VkPipelineDynamicStateCreateInfo.
--
-- If any shader stage fails to compile, the compile log will be reported
-- back to the application, and VK_ERROR_INVALID_SHADER_NV will
-- be generated.
--
-- Valid Usage
--
--
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineIndex is -1, basePipelineHandle
-- must be a valid handle to a graphics VkPipeline
--
--
--
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineHandle is VK_NULL_HANDLE,
-- basePipelineIndex must be a valid index into the
-- calling command’s pCreateInfos parameter
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineIndex is not -1, basePipelineHandle
-- must be VK_NULL_HANDLE
-- - If flags contains the
-- VK_PIPELINE_CREATE_DERIVATIVE_BIT flag, and
-- basePipelineHandle is not VK_NULL_HANDLE,
-- basePipelineIndex must be -1
-- - The stage member of each element of pStages
-- must be unique
-- - The stage member of one element of pStages
-- must be VK_SHADER_STAGE_VERTEX_BIT
-- - The stage member of each element of pStages
-- must not be VK_SHADER_STAGE_COMPUTE_BIT
-- - If pStages includes a tessellation control shader stage,
-- it must include a tessellation evaluation shader stage
-- - If pStages includes a tessellation evaluation shader
-- stage, it must include a tessellation control shader stage
-- - If pStages includes a tessellation control shader stage
-- and a tessellation evaluation shader stage,
-- pTessellationState must be a valid pointer to a valid
-- VkPipelineTessellationStateCreateInfo structure
-- - If pStages includes tessellation shader stages, the
-- shader code of at least one stage must contain an
-- OpExecutionMode instruction that specifies the type of
-- subdivision in the pipeline
-- - If pStages includes tessellation shader stages, and the
-- shader code of both stages contain an OpExecutionMode
-- instruction that specifies the type of subdivision in the pipeline,
-- they must both specify the same subdivision mode
-- - If pStages includes tessellation shader stages, the
-- shader code of at least one stage must contain an
-- OpExecutionMode instruction that specifies the output patch
-- size in the pipeline
-- - If pStages includes tessellation shader stages, and the
-- shader code of both contain an OpExecutionMode instruction
-- that specifies the out patch size in the pipeline, they must
-- both specify the same patch size
-- - If pStages includes tessellation shader stages, the
-- topology member of pInputAssembly must be
-- VK_PRIMITIVE_TOPOLOGY_PATCH_LIST
-- - If the topology member of pInputAssembly is
-- VK_PRIMITIVE_TOPOLOGY_PATCH_LIST, pStages
-- must include tessellation shader stages
-- - If pStages includes a geometry shader stage, and does not
-- include any tessellation shader stages, its shader code must
-- contain an OpExecutionMode instruction that specifies an
-- input primitive type that is compatible with the primitive
-- topology specified in pInputAssembly
-- - If pStages includes a geometry shader stage, and also
-- includes tessellation shader stages, its shader code must
-- contain an OpExecutionMode instruction that specifies an
-- input primitive type that is compatible with the primitive
-- topology that is output by the tessellation stages
-- - If pStages includes a fragment shader stage and a
-- geometry shader stage, and the fragment shader code reads from an
-- input variable that is decorated with PrimitiveID, then the
-- geometry shader code must write to a matching output variable,
-- decorated with PrimitiveID, in all execution paths
-- - If pStages includes a fragment shader stage, its shader
-- code must not read from any input attachment that is defined as
-- VK_ATTACHMENT_UNUSED in subpass
-- - The shader code for the entry points identified by
-- pStages, and the rest of the state identified by this
-- structure must adhere to the pipeline linking rules described
-- in the Shader Interfaces chapter
-- - If rasterization is not disabled and subpass uses a
-- depth/stencil attachment in renderPass that has a layout of
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL or
-- VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL in
-- the VkAttachmentReference defined by subpass, the
-- depthWriteEnable member of pDepthStencilState
-- must be VK_FALSE
-- - If rasterization is not disabled and subpass uses a
-- depth/stencil attachment in renderPass that has a layout of
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL or
-- VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL in
-- the VkAttachmentReference defined by subpass, the
-- failOp, passOp and depthFailOp members of
-- each of the front and back members of
-- pDepthStencilState must be
-- VK_STENCIL_OP_KEEP
-- - If rasterization is not disabled and the subpass uses color
-- attachments, then for each color attachment in the subpass the
-- blendEnable member of the corresponding element of the
-- pAttachment member of pColorBlendState must
-- be VK_FALSE if the format of the attachment does not
-- support color blend operations, as specified by the
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BLEND_BIT flag in
-- VkFormatProperties::linearTilingFeatures or
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties
-- - If rasterization is not disabled and the subpass uses color
-- attachments, the attachmentCount member of
-- pColorBlendState must be equal to the
-- colorAttachmentCount used to create subpass
-- - If no element of the pDynamicStates member of
-- pDynamicState is VK_DYNAMIC_STATE_VIEWPORT, the
-- pViewports member of pViewportState must be a
-- valid pointer to an array of
-- pViewportState::viewportCount VkViewport
-- structures
-- - If no element of the pDynamicStates member of
-- pDynamicState is VK_DYNAMIC_STATE_SCISSOR, the
-- pScissors member of pViewportState must be a
-- valid pointer to an array of
-- pViewportState::scissorCount VkRect2D
-- structures
-- - If the wide lines feature is not enabled, and no element of the
-- pDynamicStates member of pDynamicState is
-- VK_DYNAMIC_STATE_LINE_WIDTH, the lineWidth member of
-- pRasterizationState must be 1.0
-- - If the rasterizerDiscardEnable member of
-- pRasterizationState is VK_FALSE,
-- pViewportState must be a valid pointer to a valid
-- VkPipelineViewportStateCreateInfo structure
-- - If the rasterizerDiscardEnable member of
-- pRasterizationState is VK_FALSE,
-- pMultisampleState must be a valid pointer to a valid
-- VkPipelineMultisampleStateCreateInfo structure
-- - If the rasterizerDiscardEnable member of
-- pRasterizationState is VK_FALSE, and
-- subpass uses a depth/stencil attachment,
-- pDepthStencilState must be a valid pointer to a valid
-- VkPipelineDepthStencilStateCreateInfo structure
-- - If the rasterizerDiscardEnable member of
-- pRasterizationState is VK_FALSE, and
-- subpass uses color attachments, pColorBlendState
-- must be a valid pointer to a valid
-- VkPipelineColorBlendStateCreateInfo structure
-- - If the depth bias clamping feature is not enabled, no element of
-- the pDynamicStates member of pDynamicState is
-- VK_DYNAMIC_STATE_DEPTH_BIAS, and the depthBiasEnable
-- member of pRasterizationState is VK_TRUE, the
-- depthBiasClamp member of pRasterizationState
-- must be 0.0
-- - If the
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is not enabled and no element of the pDynamicStates
-- member of pDynamicState is
-- VK_DYNAMIC_STATE_DEPTH_BOUNDS, and the
-- depthBoundsTestEnable member of pDepthStencilState
-- is VK_TRUE, the minDepthBounds and
-- maxDepthBounds members of pDepthStencilState
-- must be between 0.0 and 1.0, inclusive
-- - If no element of the pDynamicStates member of
-- pDynamicState is
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT, and the
-- sampleLocationsEnable member of a
-- VkPipelineSampleLocationsStateCreateInfoEXT structure chained
-- to the pNext chain of pMultisampleState is
-- VK_TRUE,
-- sampleLocationsInfo.sampleLocationGridSize.width must
-- evenly divide
-- VkMultisamplePropertiesEXT::sampleLocationGridSize.width
-- as returned by vkGetPhysicalDeviceMultisamplePropertiesEXT with
-- a samples parameter equaling
-- rasterizationSamples
-- - If no element of the pDynamicStates member of
-- pDynamicState is
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT, and the
-- sampleLocationsEnable member of a
-- VkPipelineSampleLocationsStateCreateInfoEXT structure chained
-- to the pNext chain of pMultisampleState is
-- VK_TRUE,
-- sampleLocationsInfo.sampleLocationGridSize.height must
-- evenly divide
-- VkMultisamplePropertiesEXT::sampleLocationGridSize.height
-- as returned by vkGetPhysicalDeviceMultisamplePropertiesEXT with
-- a samples parameter equaling
-- rasterizationSamples
-- - If no element of the pDynamicStates member of
-- pDynamicState is
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT, and the
-- sampleLocationsEnable member of a
-- VkPipelineSampleLocationsStateCreateInfoEXT structure chained
-- to the pNext chain of pMultisampleState is
-- VK_TRUE, sampleLocationsInfo.sampleLocationsPerPixel
-- must equal rasterizationSamples
-- - If the sampleLocationsEnable member of a
-- VkPipelineSampleLocationsStateCreateInfoEXT structure chained
-- to the pNext chain of pMultisampleState is
-- VK_TRUE, the fragment shader code must not statically
-- use the extended instruction InterpolateAtSample
-- - layout must be consistent with all shaders
-- specified in pStages
-- - If subpass uses color and/or depth/stencil attachments,
-- then the rasterizationSamples member of
-- pMultisampleState must equal the maximum of the sample
-- counts of those subpass attachments
-- - If subpass has a depth/stencil attachment and depth test,
-- stencil test, or depth bounds test are enabled, then the
-- rasterizationSamples member of pMultisampleState
-- must be the same as the sample count of the depth/stencil
-- attachment
-- - If subpass has any color attachments, then the
-- rasterizationSamples member of pMultisampleState
-- must be greater than or equal to the sample count for those
-- subpass attachments
-- - If subpass does not use any color and/or depth/stencil
-- attachments, then the rasterizationSamples member of
-- pMultisampleState must follow the rules for a
-- zero-attachment subpass
-- - subpass must be a valid subpass within
-- renderPass
-- - If the renderPass has multiview enabled and
-- subpass has more than one bit set in the view mask and
-- multiviewTessellationShader is not enabled, then
-- pStages must not include tessellation shaders.
-- - If the renderPass has multiview enabled and
-- subpass has more than one bit set in the view mask and
-- multiviewGeometryShader is not enabled, then pStages
-- must not include a geometry shader.
-- - If the renderPass has multiview enabled and
-- subpass has more than one bit set in the view mask, shaders
-- in the pipeline must not write to the Layer built-in
-- output
-- - If the renderPass has multiview enabled, then all shaders
-- must not include variables decorated with the Layer
-- built-in decoration in their interfaces.
-- - flags must not contain the
-- VK_PIPELINE_CREATE_DISPATCH_BASE flag.
-- - If pStages includes a fragment shader stage and an input
-- attachment was referenced by the
-- VkRenderPassInputAttachmentAspectCreateInfo at
-- renderPass create time, its shader code must not read
-- from any aspect that was not specified in the aspectMask of
-- the corresponding VkInputAttachmentAspectReference
-- structure.
-- - The number of resources in layout accessible to each
-- shader stage that is used by the pipeline must be less than or
-- equal to
-- VkPhysicalDeviceLimits::maxPerStageResources
-- - If no element of the pDynamicStates member of
-- pDynamicState is
-- VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV, and the
-- viewportWScalingEnable member of a
-- VkPipelineViewportWScalingStateCreateInfoNV structure, chained
-- to the pNext chain of pViewportState, is
-- VK_TRUE, the pViewportWScalings member of the
-- VkPipelineViewportWScalingStateCreateInfoNV must be a
-- pointer to an array of
-- VkPipelineViewportWScalingStateCreateInfoNV::viewportCount
-- valid VkViewportWScalingNV structures
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of
-- VkPipelineDiscardRectangleStateCreateInfoEXT
-- - flags must be a valid combination of
-- VkPipelineCreateFlagBits values
-- - pStages must be a valid pointer to an array of
-- stageCount valid VkPipelineShaderStageCreateInfo
-- structures
-- - pVertexInputState must be a valid pointer to a
-- valid VkPipelineVertexInputStateCreateInfo structure
-- - pInputAssemblyState must be a valid pointer to a
-- valid VkPipelineInputAssemblyStateCreateInfo structure
-- - pRasterizationState must be a valid pointer to a
-- valid VkPipelineRasterizationStateCreateInfo structure
-- - If pDynamicState is not NULL,
-- pDynamicState must be a valid pointer to a valid
-- VkPipelineDynamicStateCreateInfo structure
-- - layout must be a valid VkPipelineLayout
-- handle
-- - renderPass must be a valid VkRenderPass
-- handle
-- - stageCount must be greater than 0
-- - Each of basePipelineHandle, layout, and
-- renderPass that are valid handles must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkPipeline, VkPipelineColorBlendStateCreateInfo,
-- VkPipelineCreateFlags,
-- VkPipelineDepthStencilStateCreateInfo,
-- VkPipelineDynamicStateCreateInfo,
-- VkPipelineInputAssemblyStateCreateInfo,
-- VkPipelineLayout, VkPipelineMultisampleStateCreateInfo,
-- VkPipelineRasterizationStateCreateInfo,
-- VkPipelineShaderStageCreateInfo,
-- VkPipelineTessellationStateCreateInfo,
-- VkPipelineVertexInputStateCreateInfo,
-- VkPipelineViewportStateCreateInfo, VkRenderPass,
-- VkStructureType, vkCreateGraphicsPipelines
data VkGraphicsPipelineCreateInfo
VkGraphicsPipelineCreateInfo :: VkStructureType -> Ptr () -> VkPipelineCreateFlags -> Word32 -> Ptr VkPipelineShaderStageCreateInfo -> Ptr VkPipelineVertexInputStateCreateInfo -> Ptr VkPipelineInputAssemblyStateCreateInfo -> Ptr VkPipelineTessellationStateCreateInfo -> Ptr VkPipelineViewportStateCreateInfo -> Ptr VkPipelineRasterizationStateCreateInfo -> Ptr VkPipelineMultisampleStateCreateInfo -> Ptr VkPipelineDepthStencilStateCreateInfo -> Ptr VkPipelineColorBlendStateCreateInfo -> Ptr VkPipelineDynamicStateCreateInfo -> VkPipelineLayout -> VkRenderPass -> Word32 -> VkPipeline -> Int32 -> VkGraphicsPipelineCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr ()
-- | flags is a bitmask of VkPipelineCreateFlagBits
-- specifying how the pipeline will be generated.
[$sel:vkFlags:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> VkPipelineCreateFlags
-- | stageCount is the number of entries in the pStages
-- array.
[$sel:vkStageCount:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Word32
-- | pStages is an array of size stageCount structures of
-- type VkPipelineShaderStageCreateInfo describing the set of the
-- shader stages to be included in the graphics pipeline.
[$sel:vkPStages:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineShaderStageCreateInfo
-- | pVertexInputState is a pointer to an instance of the
-- VkPipelineVertexInputStateCreateInfo structure.
[$sel:vkPVertexInputState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineVertexInputStateCreateInfo
-- | pInputAssemblyState is a pointer to an instance of the
-- VkPipelineInputAssemblyStateCreateInfo structure which
-- determines input assembly behavior, as described in Drawing
-- Commands.
[$sel:vkPInputAssemblyState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineInputAssemblyStateCreateInfo
-- | pTessellationState is a pointer to an instance of the
-- VkPipelineTessellationStateCreateInfo structure, and is ignored
-- if the pipeline does not include a tessellation control shader stage
-- and tessellation evaluation shader stage.
[$sel:vkPTessellationState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineTessellationStateCreateInfo
-- | pViewportState is a pointer to an instance of the
-- VkPipelineViewportStateCreateInfo structure, and is ignored if
-- the pipeline has rasterization disabled.
[$sel:vkPViewportState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineViewportStateCreateInfo
-- | pRasterizationState is a pointer to an instance of the
-- VkPipelineRasterizationStateCreateInfo structure.
[$sel:vkPRasterizationState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineRasterizationStateCreateInfo
-- | pMultisampleState is a pointer to an instance of the
-- VkPipelineMultisampleStateCreateInfo, and is ignored if the
-- pipeline has rasterization disabled.
[$sel:vkPMultisampleState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineMultisampleStateCreateInfo
-- | pDepthStencilState is a pointer to an instance of the
-- VkPipelineDepthStencilStateCreateInfo structure, and is ignored
-- if the pipeline has rasterization disabled or if the subpass of the
-- render pass the pipeline is created against does not use a
-- depth/stencil attachment.
[$sel:vkPDepthStencilState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineDepthStencilStateCreateInfo
-- | pColorBlendState is a pointer to an instance of the
-- VkPipelineColorBlendStateCreateInfo structure, and is ignored
-- if the pipeline has rasterization disabled or if the subpass of the
-- render pass the pipeline is created against does not use any color
-- attachments.
[$sel:vkPColorBlendState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineColorBlendStateCreateInfo
-- | pDynamicState is a pointer to
-- VkPipelineDynamicStateCreateInfo and is used to indicate which
-- properties of the pipeline state object are dynamic and can be
-- changed independently of the pipeline state. This can be
-- NULL, which means no state in the pipeline is considered
-- dynamic.
[$sel:vkPDynamicState:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Ptr VkPipelineDynamicStateCreateInfo
-- | layout is the description of binding locations used by both
-- the pipeline and descriptor sets used with the pipeline.
[$sel:vkLayout:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> VkPipelineLayout
-- | renderPass is a handle to a render pass object describing the
-- environment in which the pipeline will be used; the pipeline
-- must only be used with an instance of any render pass
-- compatible with the one provided. See Render Pass Compatibility
-- for more information.
[$sel:vkRenderPass:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> VkRenderPass
-- | subpass is the index of the subpass in the render pass where
-- this pipeline will be used.
[$sel:vkSubpass:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Word32
-- | basePipelineHandle is a pipeline to derive from.
[$sel:vkBasePipelineHandle:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> VkPipeline
-- | basePipelineIndex is an index into the pCreateInfos
-- parameter to use as a pipeline to derive from.
[$sel:vkBasePipelineIndex:VkGraphicsPipelineCreateInfo] :: VkGraphicsPipelineCreateInfo -> Int32
-- | VkPipelineCreateFlags - Bitmask of VkPipelineCreateFlagBits
--
-- Description
--
-- VkPipelineCreateFlags is a bitmask type for setting a mask of
-- zero or more VkPipelineCreateFlagBits.
--
-- See Also
--
-- VkComputePipelineCreateInfo,
-- VkGraphicsPipelineCreateInfo, VkPipelineCreateFlagBits
type VkPipelineCreateFlags = VkPipelineCreateFlagBits
-- | VkColorComponentFlags - Bitmask of VkColorComponentFlagBits
--
-- Description
--
-- VkColorComponentFlags is a bitmask type for setting a mask of
-- zero or more VkColorComponentFlagBits.
--
-- See Also
--
-- VkColorComponentFlagBits,
-- VkPipelineColorBlendAttachmentState
type VkColorComponentFlags = VkColorComponentFlagBits
-- | VkCullModeFlags - Bitmask of VkCullModeFlagBits
--
-- Description
--
-- VkCullModeFlags is a bitmask type for setting a mask of zero
-- or more VkCullModeFlagBits.
--
-- See Also
--
-- VkCullModeFlagBits,
-- VkPipelineRasterizationStateCreateInfo
type VkCullModeFlags = VkCullModeFlagBits
-- | VkSampleMask - Mask of sample coverage information
--
-- Description
--
-- See Also
--
-- VkPipelineMultisampleStateCreateInfo
type VkSampleMask = Word32
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkGraphicsPipelineCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkGraphicsPipelineCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendAttachmentState
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendAttachmentState
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkComputePipelineCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkComputePipelineCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkStencilOpState
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkStencilOpState
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkVertexInputAttributeDescription
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkVertexInputAttributeDescription
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkVertexInputBindingDescription
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkVertexInputBindingDescription
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkSpecializationInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkSpecializationInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkSpecializationMapEntry
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkSpecializationMapEntry
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkRect2D
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkRect2D
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkViewport
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkViewport
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkExtent2D
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkExtent2D
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkOffset2D
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkOffset2D
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkVertexInputRate
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkVertexInputRate
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkVertexInputRate
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkStencilOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkStencilOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkStencilOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPrimitiveTopology
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPrimitiveTopology
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPrimitiveTopology
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkLogicOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkLogicOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkLogicOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkFrontFace
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkFrontFace
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkFrontFace
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPolygonMode
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkPolygonMode
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkPolygonMode
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkDynamicState
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkDynamicState
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkDynamicState
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkCompareOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkCompareOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkCompareOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkBlendOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkBlendOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkBlendOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkBlendFactor
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pipeline.VkBlendFactor
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pipeline.VkBlendFactor
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkGraphicsPipelineCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendAttachmentState
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkComputePipelineCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkStencilOpState
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkVertexInputAttributeDescription
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkVertexInputBindingDescription
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkSpecializationInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkSpecializationMapEntry
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkRect2D
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkViewport
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkExtent2D
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pipeline.VkOffset2D
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkCullModeFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkColorComponentFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkShaderStageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineShaderStageCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineVertexInputStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineInputAssemblyStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineTessellationStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineViewportStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineRasterizationStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineMultisampleStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineColorBlendStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineDynamicStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPipelineDepthStencilStateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkVertexInputRate
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkVertexInputRate
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkStencilOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkStencilOp
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPrimitiveTopology
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPrimitiveTopology
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkLogicOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkLogicOp
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkFrontFace
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkFrontFace
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkPolygonMode
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkPolygonMode
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkDynamicState
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkDynamicState
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkCompareOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkCompareOp
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkBlendOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkBlendOp
instance GHC.Show.Show Graphics.Vulkan.Core10.Pipeline.VkBlendFactor
instance GHC.Read.Read Graphics.Vulkan.Core10.Pipeline.VkBlendFactor
module Graphics.Vulkan.Extensions.VK_NV_fill_rectangle
module Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling
-- | VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV specifies that the
-- pViewportScalings state in
-- VkPipelineViewportWScalingStateCreateInfoNV will be ignored
-- and must be set dynamically with
-- vkCmdSetViewportWScalingNV before any draws are performed with
-- a pipeline state with
-- VkPipelineViewportWScalingStateCreateInfo member
-- viewportScalingEnable set to VK_TRUE
-- | vkCmdSetViewportWScalingNV - Set the viewport W scaling on a command
-- buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - firstViewport is the index of the first viewport whose
-- parameters are updated by the command.
-- - viewportCount is the number of viewports whose parameters
-- are updated by the command.
-- - pViewportWScalings is a pointer to an array of
-- VkViewportWScalingNV structures specifying viewport
-- parameters.
--
--
-- Description
--
-- The viewport parameters taken from element i of
-- pViewportWScalings replace the current state for the viewport
-- index firstViewport + i, for i in [0,
-- viewportCount).
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_VIEWPORT_W_SCALING_NV dynamic state
-- enabled
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pViewportWScalings must be a valid pointer to an
-- array of viewportCount VkViewportWScalingNV
-- structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - viewportCount must be greater than 0
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkViewportWScalingNV
vkCmdSetViewportWScalingNV :: ("commandBuffer" ::: VkCommandBuffer) -> ("firstViewport" ::: Word32) -> ("viewportCount" ::: Word32) -> ("pViewportWScalings" ::: Ptr VkViewportWScalingNV) -> IO ()
-- | VkViewportWScalingNV - Structure specifying a viewport
--
-- Description
--
-- See Also
--
-- VkPipelineViewportWScalingStateCreateInfoNV,
-- vkCmdSetViewportWScalingNV
data VkViewportWScalingNV
VkViewportWScalingNV :: CFloat -> CFloat -> VkViewportWScalingNV
-- | xcoeff and ycoeff are the viewport’s W scaling
-- factor for x and y respectively.
[$sel:vkXcoeff:VkViewportWScalingNV] :: VkViewportWScalingNV -> CFloat
[$sel:vkYcoeff:VkViewportWScalingNV] :: VkViewportWScalingNV -> CFloat
-- | VkPipelineViewportWScalingStateCreateInfoNV - Structure specifying
-- parameters of a newly created pipeline viewport W scaling state
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_W_SCALING_STATE_CREATE_INFO_NV
--
--
--
-- - viewportCount must be greater than 0
--
--
-- See Also
--
-- VkBool32, VkStructureType, VkViewportWScalingNV
data VkPipelineViewportWScalingStateCreateInfoNV
VkPipelineViewportWScalingStateCreateInfoNV :: VkStructureType -> Ptr () -> VkBool32 -> Word32 -> Ptr VkViewportWScalingNV -> VkPipelineViewportWScalingStateCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineViewportWScalingStateCreateInfoNV] :: VkPipelineViewportWScalingStateCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineViewportWScalingStateCreateInfoNV] :: VkPipelineViewportWScalingStateCreateInfoNV -> Ptr ()
-- | viewportWScalingEnable controls whether viewport W
-- scaling is enabled.
[$sel:vkViewportWScalingEnable:VkPipelineViewportWScalingStateCreateInfoNV] :: VkPipelineViewportWScalingStateCreateInfoNV -> VkBool32
-- | viewportCount is the number of viewports used by W
-- scaling, and must match the number of viewports in the pipeline
-- if viewport W scaling is enabled.
[$sel:vkViewportCount:VkPipelineViewportWScalingStateCreateInfoNV] :: VkPipelineViewportWScalingStateCreateInfoNV -> Word32
-- | pViewportWScalings is a pointer to an array of
-- VkViewportWScalingNV structures, which define the W
-- scaling parameters for the corresponding viewport. If the viewport
-- W scaling state is dynamic, this member is ignored.
[$sel:vkPViewportWScalings:VkPipelineViewportWScalingStateCreateInfoNV] :: VkPipelineViewportWScalingStateCreateInfoNV -> Ptr VkViewportWScalingNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkPipelineViewportWScalingStateCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkPipelineViewportWScalingStateCreateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkViewportWScalingNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkViewportWScalingNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkPipelineViewportWScalingStateCreateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_clip_space_w_scaling.VkViewportWScalingNV
module Graphics.Vulkan.Extensions.VK_KHR_surface
-- | VkColorSpaceKHR - supported color space of the presentation engine
--
-- Description
--
--
-- - VK_COLOR_SPACE_SRGB_NONLINEAR_KHR specifies support for
-- the sRGB color space.
--
--
--
-- - VK_COLOR_SPACE_DISPLAY_P3_NONLINEAR_EXT specifies support
-- for the Display-P3 color space and applies an sRGB-like transfer
-- function (defined below).
-- - VK_COLOR_SPACE_EXTENDED_SRGB_LINEAR_EXT specifies support
-- for the extended sRGB color space and applies a linear transfer
-- function.
-- - VK_COLOR_SPACE_EXTENDED_SRGB_NONLINEAR_EXT specifies
-- support for the extended sRGB color space and applies an sRGB transfer
-- function.
-- - VK_COLOR_SPACE_DCI_P3_LINEAR_EXT specifies support for
-- the DCI-P3 color space and applies a linear OETF.
-- - VK_COLOR_SPACE_DCI_P3_NONLINEAR_EXT specifies support for
-- the DCI-P3 color space and applies the Gamma 2.6 OETF.
-- - VK_COLOR_SPACE_BT709_LINEAR_EXT specifies support for the
-- BT709 color space and applies a linear OETF.
-- - VK_COLOR_SPACE_BT709_NONLINEAR_EXT specifies support for
-- the BT709 color space and applies the SMPTE 170M OETF.
-- - VK_COLOR_SPACE_BT2020_LINEAR_EXT specifies support for
-- the BT2020 color space and applies a linear OETF.
-- - VK_COLOR_SPACE_HDR10_ST2084_EXT specifies support for the
-- HDR10 (BT2020 color) space and applies the SMPTE ST2084 Perceptual
-- Quantizer (PQ) OETF.
-- - VK_COLOR_SPACE_DOLBYVISION_EXT specifies support for the
-- Dolby Vision (BT2020 color space), proprietary encoding, and applies
-- the SMPTE ST2084 OETF.
-- - VK_COLOR_SPACE_HDR10_HLG_EXT specifies support for the
-- HDR10 (BT2020 color space) and applies the Hybrid Log Gamma (HLG)
-- OETF.
-- - VK_COLOR_SPACE_ADOBERGB_LINEAR_EXT specifies support for
-- the AdobeRGB color space and applies a linear OETF.
-- - VK_COLOR_SPACE_ADOBERGB_NONLINEAR_EXT specifies support
-- for the AdobeRGB color space and applies the Gamma 2.2 OETF.
-- - VK_COLOR_SPACE_PASS_THROUGH_EXT specifies that color
-- components are used “as is”. This is intended to allow applications to
-- supply data for color spaces not described here.
--
--
-- The color components of Non-linear color space swap chain images have
-- had the appropriate transfer function applied. Vulkan requires that
-- all implementations support the sRGB transfer function when using an
-- SRGB pixel format. Other transfer functions, such as SMPTE 170M or
-- SMPTE2084, must not be performed by the implementation, but
-- can be performed by the application shader. This extension
-- defines enums for VkColorSpaceKHR that correspond to the
-- following color spaces:
--
--
-- +----------+----------+----------+----------+----------+-----------+
-- | Name | Red | Green | Blue | White-po | Transfer |
-- | | Primary | Primary | Primary | int | function |
-- +==========+==========+==========+==========+==========+===========+
-- | DCI-P3 | 0.680, | 0.265, | 0.150, | 0.3127, | Gamma 2.6 |
-- | | 0.320 | 0.690 | 0.060 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | Display- | 0.680, | 0.265, | 0.150, | 0.3127, | Display-P |
-- | P3 | 0.320 | 0.690 | 0.060 | 0.3290 | 3 |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | BT709 | 0.640, | 0.300, | 0.150, | 0.3127, | SMPTE |
-- | | 0.330 | 0.600 | 0.060 | 0.3290 | 170M |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | sRGB | 0.640, | 0.300, | 0.150, | 0.3127, | sRGB |
-- | | 0.330 | 0.600 | 0.060 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | extended | 0.640, | 0.300, | 0.150, | 0.3127, | extended |
-- | sRGB | 0.330 | 0.600 | 0.060 | 0.3290 | sRGB |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | HDR10_ST | 0.708, | 0.170, | 0.131, | 0.3127, | ST2084 |
-- | 2084 | 0.292 | 0.797 | 0.046 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | DOLBYVIS | 0.708, | 0.170, | 0.131, | 0.3127, | ST2084 |
-- | ION | 0.292 | 0.797 | 0.046 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | HDR10_HL | 0.708, | 0.170, | 0.131, | 0.3127, | HLG |
-- | G | 0.292 | 0.797 | 0.046 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
-- | AdobeRGB | 0.640, | 0.210, | 0.150, | 0.3127, | AdobeRGB |
-- | | 0.330 | 0.710 | 0.060 | 0.3290 | |
-- | | | | | (D65) | |
-- +----------+----------+----------+----------+----------+-----------+
--
-- Color Spaces and Attributes
--
--
-- For Opto-Electrical Transfer Function (OETF), unless otherwise
-- specified, the values of L and E are defined as:
--
-- L - linear luminance of image <math> for conventional
-- colorimetry
--
-- E - corresponding electrical signal (value stored in memory)
--
-- See Also
--
-- VkSurfaceFormatKHR, VkSwapchainCreateInfoKHR
newtype VkColorSpaceKHR
VkColorSpaceKHR :: Int32 -> VkColorSpaceKHR
-- | VkPresentModeKHR - presentation mode supported for a surface
--
-- Description
--
--
-- - VK_PRESENT_MODE_IMMEDIATE_KHR specifies that the
-- presentation engine does not wait for a vertical blanking period to
-- update the current image, meaning this mode may result in
-- visible tearing. No internal queuing of presentation requests is
-- needed, as the requests are applied immediately.
--
--
--
-- - VK_PRESENT_MODE_MAILBOX_KHR specifies that the
-- presentation engine waits for the next vertical blanking period to
-- update the current image. Tearing cannot be observed. An
-- internal single-entry queue is used to hold pending presentation
-- requests. If the queue is full when a new presentation request is
-- received, the new request replaces the existing entry, and any images
-- associated with the prior entry become available for re-use by the
-- application. One request is removed from the queue and processed
-- during each vertical blanking period in which the queue is
-- non-empty.
-- - VK_PRESENT_MODE_FIFO_KHR specifies that the presentation
-- engine waits for the next vertical blanking period to update the
-- current image. Tearing cannot be observed. An internal queue is
-- used to hold pending presentation requests. New requests are appended
-- to the end of the queue, and one request is removed from the beginning
-- of the queue and processed during each vertical blanking period in
-- which the queue is non-empty. This is the only value of
-- presentMode that is required to be supported.
-- - VK_PRESENT_MODE_FIFO_RELAXED_KHR specifies that the
-- presentation engine generally waits for the next vertical blanking
-- period to update the current image. If a vertical blanking period has
-- already passed since the last update of the current image then the
-- presentation engine does not wait for another vertical blanking period
-- for the update, meaning this mode may result in visible tearing
-- in this case. This mode is useful for reducing visual stutter with an
-- application that will mostly present a new image before the next
-- vertical blanking period, but may occasionally be late, and present a
-- new image just after the next vertical blanking period. An internal
-- queue is used to hold pending presentation requests. New requests are
-- appended to the end of the queue, and one request is removed from the
-- beginning of the queue and processed during or after each vertical
-- blanking period in which the queue is non-empty.
-- - VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR specifies that
-- the presentation engine and application have concurrent access to a
-- single image, which is referred to as a shared presentable
-- image. The presentation engine is only required to update the
-- current image after a new presentation request is received. Therefore
-- the application must make a presentation request whenever an
-- update is required. However, the presentation engine may update
-- the current image at any point, meaning this mode may result in
-- visible tearing.
-- - VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR specifies
-- that the presentation engine and application have concurrent access to
-- a single image, which is referred to as a shared presentable
-- image. The presentation engine periodically updates the current
-- image on its regular refresh cycle. The application is only required
-- to make one initial presentation request, after which the presentation
-- engine must update the current image without any need for
-- further presentation requests. The application can indicate the
-- image contents have been updated by making a presentation request, but
-- this does not guarantee the timing of when it will be updated. This
-- mode may result in visible tearing if rendering to the image is
-- not timed correctly.
--
--
-- The supported VkImageUsageFlagBits of the presentable images of
-- a swapchain created for a surface may differ depending on the
-- presentation mode, and can be determined as per the table below:
--
--
-- +-----------------------------------+-----------------------------------+
-- | Presentation mode | Image usage flags |
-- +===================================+===================================+
-- | @VK_PRESENT_MODE_IMMEDIATE_KHR@ | 'VkSurfaceCapabilitiesKHR'::@supp |
-- | | ortedUsageFlags@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_PRESENT_MODE_MAILBOX_KHR@ | 'VkSurfaceCapabilitiesKHR'::@supp |
-- | | ortedUsageFlags@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_PRESENT_MODE_FIFO_KHR@ | 'VkSurfaceCapabilitiesKHR'::@supp |
-- | | ortedUsageFlags@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_PRESENT_MODE_FIFO_RELAXED_KHR | 'VkSurfaceCapabilitiesKHR'::@supp |
-- | @ | ortedUsageFlags@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_PRESENT_MODE_SHARED_DEMAND_RE | 'Graphics.Vulkan.Extensions.VK_KH |
-- | FRESH_KHR@ | R_shared_presentable_image.VkShar |
-- | | edPresentSurfaceCapabilitiesKHR': |
-- | | :@sharedPresentSupportedUsageFlag |
-- | | s@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_PRESENT_MODE_SHARED_CONTINUOU | 'Graphics.Vulkan.Extensions.VK_KH |
-- | S_REFRESH_KHR@ | R_shared_presentable_image.VkShar |
-- | | edPresentSurfaceCapabilitiesKHR': |
-- | | :@sharedPresentSupportedUsageFlag |
-- | | s@ |
-- +-----------------------------------+-----------------------------------+
--
-- Presentable image usage queries
--
--
-- Note
--
-- For reference, the mode indicated by VK_PRESENT_MODE_FIFO_KHR
-- is equivalent to the behavior of {wgl|glX|egl}SwapBuffers with a swap
-- interval of 1, while the mode indicated by
-- VK_PRESENT_MODE_FIFO_RELAXED_KHR is equivalent to the
-- behavior of {wgl|glX}SwapBuffers with a swap interval of -1 (from the
-- {WGL|GLX}_EXT_swap_control_tear extensions).
--
-- See Also
--
-- VkSwapchainCreateInfoKHR,
-- vkGetPhysicalDeviceSurfacePresentModesKHR
newtype VkPresentModeKHR
VkPresentModeKHR :: Int32 -> VkPresentModeKHR
-- | VkCompositeAlphaFlagBitsKHR - alpha compositing modes supported on a
-- device
--
-- Description
--
-- These values are described as follows:
--
--
-- - VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR: The alpha channel, if
-- it exists, of the images is ignored in the compositing process.
-- Instead, the image is treated as if it has a constant alpha of
-- 1.0.
-- - VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR: The alpha
-- channel, if it exists, of the images is respected in the compositing
-- process. The non-alpha channels of the image are expected to already
-- be multiplied by the alpha channel by the application.
-- - VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR: The alpha
-- channel, if it exists, of the images is respected in the compositing
-- process. The non-alpha channels of the image are not expected to
-- already be multiplied by the alpha channel by the application;
-- instead, the compositor will multiply the non-alpha channels of the
-- image by the alpha channel during compositing.
-- - VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR: The way in which the
-- presentation engine treats the alpha channel in the images is unknown
-- to the Vulkan API. Instead, the application is responsible for setting
-- the composite alpha blending mode using native window system commands.
-- If the application does not set the blending mode using native window
-- system commands, then a platform-specific default will be used.
--
--
-- See Also
--
-- VkCompositeAlphaFlagsKHR, VkSwapchainCreateInfoKHR
newtype VkCompositeAlphaFlagBitsKHR
VkCompositeAlphaFlagBitsKHR :: VkFlags -> VkCompositeAlphaFlagBitsKHR
-- | VkSurfaceTransformFlagBitsKHR - presentation transforms supported on a
-- device
--
-- See Also
--
-- VkDisplaySurfaceCreateInfoKHR,
-- VkSurfaceCapabilities2EXT, VkSurfaceCapabilitiesKHR,
-- VkSurfaceTransformFlagsKHR, VkSwapchainCreateInfoKHR
newtype VkSurfaceTransformFlagBitsKHR
VkSurfaceTransformFlagBitsKHR :: VkFlags -> VkSurfaceTransformFlagBitsKHR
-- | VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR specifies that image
-- content is presented without being transformed.
-- | VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR specifies that image
-- content is rotated 90 degrees clockwise.
-- | VK_SURFACE_TRANSFORM_ROTATE_180_BIT_KHR specifies that image
-- content is rotated 180 degrees clockwise.
-- | VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR specifies that image
-- content is rotated 270 degrees clockwise.
-- | VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_BIT_KHR specifies that
-- image content is mirrored horizontally.
-- | VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_90_BIT_KHR
-- specifies that image content is mirrored horizontally, then rotated 90
-- degrees clockwise.
-- | VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_180_BIT_KHR
-- specifies that image content is mirrored horizontally, then rotated
-- 180 degrees clockwise.
-- | VK_SURFACE_TRANSFORM_HORIZONTAL_MIRROR_ROTATE_270_BIT_KHR
-- specifies that image content is mirrored horizontally, then rotated
-- 270 degrees clockwise.
-- | VK_SURFACE_TRANSFORM_INHERIT_BIT_KHR specifies that the
-- presentation transform is not specified, and is instead determined by
-- platform-specific considerations and mechanisms outside Vulkan.
-- | VkSurfaceKHR - Opaque handle to a surface object
--
-- Description
--
-- The VK_KHR_surface extension declares the
-- VkSurfaceKHR object, and provides a function for destroying
-- VkSurfaceKHR objects. Separate platform-specific extensions
-- each provide a function for creating a VkSurfaceKHR object
-- for the respective platform. From the application’s perspective this
-- is an opaque handle, just like the handles of other Vulkan objects.
--
-- See Also
--
-- VkPhysicalDeviceSurfaceInfo2KHR,
-- VkSwapchainCreateInfoKHR, vkCreateAndroidSurfaceKHR,
-- vkCreateDisplayPlaneSurfaceKHR, vkCreateIOSSurfaceMVK,
-- vkCreateMacOSSurfaceMVK, vkCreateMirSurfaceKHR,
-- vkCreateViSurfaceNN, vkCreateWaylandSurfaceKHR,
-- vkCreateWin32SurfaceKHR, vkCreateXcbSurfaceKHR,
-- vkCreateXlibSurfaceKHR, vkDestroySurfaceKHR,
-- vkGetDeviceGroupSurfacePresentModesKHR,
-- vkGetPhysicalDevicePresentRectanglesKHR,
-- vkGetPhysicalDeviceSurfaceCapabilities2EXT,
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR,
-- vkGetPhysicalDeviceSurfaceFormatsKHR,
-- vkGetPhysicalDeviceSurfacePresentModesKHR,
-- vkGetPhysicalDeviceSurfaceSupportKHR
type VkSurfaceKHR = Ptr VkSurfaceKHR_T
-- | vkDestroySurfaceKHR - Destroy a VkSurfaceKHR object
--
-- Parameters
--
--
-- - instance is the instance used to create the surface.
--
--
--
-- - surface is the surface to destroy.
-- - pAllocator is the allocator used for host memory
-- allocated for the surface object when there is no more specific
-- allocator available (see Memory Allocation).
--
--
-- Description
--
-- Destroying a VkSurfaceKHR merely severs the connection
-- between Vulkan and the native surface, and does not imply destroying
-- the native surface, closing a window, or similar behavior.
--
-- Valid Usage
--
--
-- - All VkSwapchainKHR objects created for surface
-- must have been destroyed prior to destroying
-- surface
--
--
--
-- - If VkAllocationCallbacks were provided when
-- surface was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- surface was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - If surface is not VK_NULL_HANDLE, surface
-- must be a valid VkSurfaceKHR handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If surface is a valid handle, it must have been
-- created, allocated, or retrieved from instance
--
--
-- Host Synchronization
--
--
-- - Host access to surface must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkInstance, VkSurfaceKHR
vkDestroySurfaceKHR :: ("instance" ::: VkInstance) -> ("surface" ::: VkSurfaceKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetPhysicalDeviceSurfaceSupportKHR - Query if presentation is
-- supported
--
-- Parameters
--
--
-- - physicalDevice is the physical device.
--
--
--
-- - queueFamilyIndex is the queue family.
-- - surface is the surface.
-- - pSupported is a pointer to a VkBool32, which is
-- set to VK_TRUE to indicate support, and VK_FALSE
-- otherwise.
--
--
-- Description
--
-- Valid Usage
--
--
-- - queueFamilyIndex must be less than
-- pQueueFamilyPropertyCount returned by
-- vkGetPhysicalDeviceQueueFamilyProperties for the given
-- physicalDevice
--
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pSupported must be a valid pointer to a
-- VkBool32 value
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBool32, VkPhysicalDevice, VkSurfaceKHR
vkGetPhysicalDeviceSurfaceSupportKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("queueFamilyIndex" ::: Word32) -> ("surface" ::: VkSurfaceKHR) -> ("pSupported" ::: Ptr VkBool32) -> IO VkResult
-- | vkGetPhysicalDeviceSurfaceCapabilitiesKHR - Query surface capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
-- - surface is the surface that will be associated with the
-- swapchain.
-- - pSurfaceCapabilities is a pointer to an instance of the
-- VkSurfaceCapabilitiesKHR structure in which the capabilities
-- are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pSurfaceCapabilities must be a valid pointer to a
-- VkSurfaceCapabilitiesKHR structure
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkSurfaceCapabilitiesKHR,
-- VkSurfaceKHR
vkGetPhysicalDeviceSurfaceCapabilitiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pSurfaceCapabilities" ::: Ptr VkSurfaceCapabilitiesKHR) -> IO VkResult
-- | vkGetPhysicalDeviceSurfaceFormatsKHR - Query color formats supported
-- by surface
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
-- - surface is the surface that will be associated with the
-- swapchain.
-- - pSurfaceFormatCount is a pointer to an integer related to
-- the number of format pairs available or queried, as described
-- below.
-- - pSurfaceFormats is either NULL or a pointer to
-- an array of VkSurfaceFormatKHR structures.
--
--
-- Description
--
-- If pSurfaceFormats is NULL, then the number of
-- format pairs supported for the given surface is returned in
-- pSurfaceFormatCount. The number of format pairs supported
-- will be greater than or equal to 1. Otherwise,
-- pSurfaceFormatCount must point to a variable set by
-- the user to the number of elements in the pSurfaceFormats
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pSurfaceFormats. If the value
-- of pSurfaceFormatCount is less than the number of format
-- pairs supported, at most pSurfaceFormatCount structures will
-- be written. If pSurfaceFormatCount is smaller than the number
-- of format pairs supported for the given surface,
-- VK_INCOMPLETE will be returned instead of VK_SUCCESS
-- to indicate that not all the available values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pSurfaceFormatCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pSurfaceFormatCount is not
-- 0, and pSurfaceFormats is not NULL,
-- pSurfaceFormats must be a valid pointer to an array of
-- pSurfaceFormatCount VkSurfaceFormatKHR
-- structures
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkSurfaceFormatKHR,
-- VkSurfaceKHR
vkGetPhysicalDeviceSurfaceFormatsKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pSurfaceFormatCount" ::: Ptr Word32) -> ("pSurfaceFormats" ::: Ptr VkSurfaceFormatKHR) -> IO VkResult
-- | vkGetPhysicalDeviceSurfacePresentModesKHR - Query supported
-- presentation modes
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
-- - surface is the surface that will be associated with the
-- swapchain.
-- - pPresentModeCount is a pointer to an integer related to
-- the number of presentation modes available or queried, as described
-- below.
-- - pPresentModes is either NULL or a pointer to an
-- array of VkPresentModeKHR values, indicating the supported
-- presentation modes.
--
--
-- Description
--
-- If pPresentModes is NULL, then the number of
-- presentation modes supported for the given surface is
-- returned in pPresentModeCount. Otherwise,
-- pPresentModeCount must point to a variable set by the
-- user to the number of elements in the pPresentModes array,
-- and on return the variable is overwritten with the number of values
-- actually written to pPresentModes. If the value of
-- pPresentModeCount is less than the number of presentation
-- modes supported, at most pPresentModeCount values will be
-- written. If pPresentModeCount is smaller than the number of
-- presentation modes supported for the given surface,
-- VK_INCOMPLETE will be returned instead of VK_SUCCESS
-- to indicate that not all the available values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pPresentModeCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPresentModeCount is not
-- 0, and pPresentModes is not NULL,
-- pPresentModes must be a valid pointer to an array of
-- pPresentModeCount VkPresentModeKHR values
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkPresentModeKHR, VkSurfaceKHR
vkGetPhysicalDeviceSurfacePresentModesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pPresentModeCount" ::: Ptr Word32) -> ("pPresentModes" ::: Ptr VkPresentModeKHR) -> IO VkResult
-- | VkSurfaceCapabilitiesKHR - Structure describing capabilities of a
-- surface
--
-- Description
--
-- Note
--
-- Supported usage flags of a presentable image when using
-- VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR or
-- VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR presentation
-- mode are provided by
-- VkSharedPresentSurfaceCapabilitiesKHR::sharedPresentSupportedUsageFlags.
--
-- Note
--
-- Formulas such as min(N, maxImageCount) are not correct, since
-- maxImageCount may be zero.
--
-- See Also
--
-- VkCompositeAlphaFlagsKHR, VkExtent2D,
-- VkImageUsageFlags, VkSurfaceCapabilities2KHR,
-- VkSurfaceTransformFlagBitsKHR,
-- VkSurfaceTransformFlagsKHR,
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR
data VkSurfaceCapabilitiesKHR
VkSurfaceCapabilitiesKHR :: Word32 -> Word32 -> VkExtent2D -> VkExtent2D -> VkExtent2D -> Word32 -> VkSurfaceTransformFlagsKHR -> VkSurfaceTransformFlagBitsKHR -> VkCompositeAlphaFlagsKHR -> VkImageUsageFlags -> VkSurfaceCapabilitiesKHR
-- | minImageCount is the minimum number of images the specified
-- device supports for a swapchain created for the surface, and will be
-- at least one.
[$sel:vkMinImageCount:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> Word32
-- | maxImageCount is the maximum number of images the specified
-- device supports for a swapchain created for the surface, and will be
-- either 0, or greater than or equal to minImageCount. A value
-- of 0 means that there is no limit on the number of images, though
-- there may be limits related to the total amount of memory used
-- by presentable images.
[$sel:vkMaxImageCount:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> Word32
-- | currentExtent is the current width and height of the surface,
-- or the special value (0xFFFFFFFF, 0xFFFFFFFF) indicating that the
-- surface size will be determined by the extent of a swapchain targeting
-- the surface.
[$sel:vkCurrentExtent:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkExtent2D
-- | minImageExtent contains the smallest valid swapchain extent
-- for the surface on the specified device. The width and
-- height of the extent will each be less than or equal to the
-- corresponding width and height of
-- currentExtent, unless currentExtent has the special
-- value described above.
[$sel:vkMinImageExtent:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkExtent2D
-- | maxImageExtent contains the largest valid swapchain extent
-- for the surface on the specified device. The width and
-- height of the extent will each be greater than or equal to
-- the corresponding width and height of
-- minImageExtent. The width and height of the
-- extent will each be greater than or equal to the corresponding
-- width and height of currentExtent, unless
-- currentExtent has the special value described above.
[$sel:vkMaxImageExtent:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkExtent2D
-- | maxImageArrayLayers is the maximum number of layers
-- presentable images can have for a swapchain created for this
-- device and surface, and will be at least one.
[$sel:vkMaxImageArrayLayers:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> Word32
-- | supportedTransforms is a bitmask of
-- VkSurfaceTransformFlagBitsKHR indicating the presentation
-- transforms supported for the surface on the specified device. At least
-- one bit will be set.
[$sel:vkSupportedTransforms:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkSurfaceTransformFlagsKHR
-- | currentTransform is VkSurfaceTransformFlagBitsKHR
-- value indicating the surface’s current transform relative to the
-- presentation engine’s natural orientation.
[$sel:vkCurrentTransform:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkSurfaceTransformFlagBitsKHR
-- | supportedCompositeAlpha is a bitmask of
-- VkCompositeAlphaFlagBitsKHR, representing the alpha compositing
-- modes supported by the presentation engine for the surface on the
-- specified device, and at least one bit will be set. Opaque composition
-- can be achieved in any alpha compositing mode by either using
-- an image format that has no alpha component, or by ensuring that all
-- pixels in the presentable images have an alpha value of 1.0.
[$sel:vkSupportedCompositeAlpha:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkCompositeAlphaFlagsKHR
-- | supportedUsageFlags is a bitmask of
-- VkImageUsageFlagBits representing the ways the application
-- can use the presentable images of a swapchain created with
-- VkPresentModeKHR set to VK_PRESENT_MODE_IMMEDIATE_KHR,
-- VK_PRESENT_MODE_MAILBOX_KHR,
-- VK_PRESENT_MODE_FIFO_KHR or
-- VK_PRESENT_MODE_FIFO_RELAXED_KHR for the surface on the
-- specified device. VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT
-- must be included in the set but implementations may
-- support additional usages.
[$sel:vkSupportedUsageFlags:VkSurfaceCapabilitiesKHR] :: VkSurfaceCapabilitiesKHR -> VkImageUsageFlags
-- | VkSurfaceFormatKHR - Structure describing a supported swapchain
-- format-color space pair
--
-- Description
--
-- See Also
--
-- VkColorSpaceKHR, VkFormat, VkSurfaceFormat2KHR,
-- vkGetPhysicalDeviceSurfaceFormatsKHR
data VkSurfaceFormatKHR
VkSurfaceFormatKHR :: VkFormat -> VkColorSpaceKHR -> VkSurfaceFormatKHR
-- | format is a VkFormat that is compatible with the
-- specified surface.
[$sel:vkFormat:VkSurfaceFormatKHR] :: VkSurfaceFormatKHR -> VkFormat
-- | colorSpace is a presentation VkColorSpaceKHR that is
-- compatible with the surface.
[$sel:vkColorSpace:VkSurfaceFormatKHR] :: VkSurfaceFormatKHR -> VkColorSpaceKHR
-- | VkCompositeAlphaFlagsKHR - Bitmask of VkCompositeAlphaFlagBitsKHR
--
-- Description
--
-- VkCompositeAlphaFlagsKHR is a bitmask type for setting a mask
-- of zero or more VkCompositeAlphaFlagBitsKHR.
--
-- See Also
--
-- VkCompositeAlphaFlagBitsKHR, VkSurfaceCapabilities2EXT,
-- VkSurfaceCapabilitiesKHR
type VkCompositeAlphaFlagsKHR = VkCompositeAlphaFlagBitsKHR
-- | VkSurfaceTransformFlagsKHR - Bitmask of VkSurfaceTransformFlagBitsKHR
--
-- Description
--
-- VkSurfaceTransformFlagsKHR is a bitmask type for setting a
-- mask of zero or more VkSurfaceTransformFlagBitsKHR.
--
-- See Also
--
-- VkDisplayPropertiesKHR, VkSurfaceCapabilities2EXT,
-- VkSurfaceCapabilitiesKHR, VkSurfaceTransformFlagBitsKHR
type VkSurfaceTransformFlagsKHR = VkSurfaceTransformFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceCapabilitiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceCapabilitiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceFormatKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceFormatKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkPresentModeKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_surface.VkPresentModeKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkPresentModeKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkColorSpaceKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_surface.VkColorSpaceKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_surface.VkColorSpaceKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceCapabilitiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceFormatKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_surface.VkSurfaceTransformFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_surface.VkCompositeAlphaFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkPresentModeKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_surface.VkPresentModeKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_surface.VkColorSpaceKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_surface.VkColorSpaceKHR
module Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2
-- | vkGetPhysicalDeviceSurfaceCapabilities2KHR - Reports capabilities of a
-- surface on a physical device
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
--
-- Description
--
-- vkGetPhysicalDeviceSurfaceCapabilities2KHR behaves similarly
-- to vkGetPhysicalDeviceSurfaceCapabilitiesKHR, with the ability
-- to specify extended inputs via chained input structures, and to return
-- extended information via chained output structures.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pSurfaceInfo must be a valid pointer to a valid
-- VkPhysicalDeviceSurfaceInfo2KHR structure
-- - pSurfaceCapabilities must be a valid pointer to a
-- VkSurfaceCapabilities2KHR structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceSurfaceInfo2KHR,
-- VkSurfaceCapabilities2KHR
vkGetPhysicalDeviceSurfaceCapabilities2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pSurfaceInfo" ::: Ptr VkPhysicalDeviceSurfaceInfo2KHR) -> ("pSurfaceCapabilities" ::: Ptr VkSurfaceCapabilities2KHR) -> IO VkResult
-- | vkGetPhysicalDeviceSurfaceFormats2KHR - Query color formats supported
-- by surface
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
-- - pSurfaceInfo points to an instance of the
-- VkPhysicalDeviceSurfaceInfo2KHR structure, describing the
-- surface and other fixed parameters that would be consumed by
-- vkCreateSwapchainKHR.
-- - pSurfaceFormatCount is a pointer to an integer related to
-- the number of format tuples available or queried, as described
-- below.
-- - pSurfaceFormats is either NULL or a pointer to
-- an array of VkSurfaceFormat2KHR structures.
--
--
-- Description
--
-- If pSurfaceFormats is NULL, then the number of
-- format tuples supported for the given surface is returned in
-- pSurfaceFormatCount. The number of format tuples supported
-- will be greater than or equal to 1. Otherwise,
-- pSurfaceFormatCount must point to a variable set by
-- the user to the number of elements in the pSurfaceFormats
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pSurfaceFormats. If the value
-- of pSurfaceFormatCount is less than the number of format
-- tuples supported, at most pSurfaceFormatCount structures will
-- be written. If pSurfaceFormatCount is smaller than the number
-- of format tuples supported for the surface parameters described in
-- pSurfaceInfo, VK_INCOMPLETE will be returned instead
-- of VK_SUCCESS to indicate that not all the available values
-- were returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pSurfaceInfo must be a valid pointer to a valid
-- VkPhysicalDeviceSurfaceInfo2KHR structure
-- - pSurfaceFormatCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pSurfaceFormatCount is not
-- 0, and pSurfaceFormats is not NULL,
-- pSurfaceFormats must be a valid pointer to an array of
-- pSurfaceFormatCount VkSurfaceFormat2KHR
-- structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceSurfaceInfo2KHR,
-- VkSurfaceFormat2KHR
vkGetPhysicalDeviceSurfaceFormats2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pSurfaceInfo" ::: Ptr VkPhysicalDeviceSurfaceInfo2KHR) -> ("pSurfaceFormatCount" ::: Ptr Word32) -> ("pSurfaceFormats" ::: Ptr VkSurfaceFormat2KHR) -> IO VkResult
-- | VkPhysicalDeviceSurfaceInfo2KHR - Structure specifying a surface and
-- related swapchain creation parameters
--
-- Description
--
-- The members of VkPhysicalDeviceSurfaceInfo2KHR correspond to
-- the arguments to vkGetPhysicalDeviceSurfaceCapabilitiesKHR,
-- with sType and pNext added for extensibility.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SURFACE_INFO_2_KHR
--
--
--
-- - pNext must be NULL
-- - surface must be a valid VkSurfaceKHR
-- handle
--
--
-- See Also
--
-- VkStructureType, VkSurfaceKHR,
-- vkGetPhysicalDeviceSurfaceCapabilities2KHR,
-- vkGetPhysicalDeviceSurfaceFormats2KHR
data VkPhysicalDeviceSurfaceInfo2KHR
VkPhysicalDeviceSurfaceInfo2KHR :: VkStructureType -> Ptr () -> VkSurfaceKHR -> VkPhysicalDeviceSurfaceInfo2KHR
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceSurfaceInfo2KHR] :: VkPhysicalDeviceSurfaceInfo2KHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceSurfaceInfo2KHR] :: VkPhysicalDeviceSurfaceInfo2KHR -> Ptr ()
-- | surface is the surface that will be associated with the
-- swapchain.
[$sel:vkSurface:VkPhysicalDeviceSurfaceInfo2KHR] :: VkPhysicalDeviceSurfaceInfo2KHR -> VkSurfaceKHR
-- | VkSurfaceCapabilities2KHR - Structure describing capabilities of a
-- surface
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_KHR
--
--
--
--
-- See Also
--
-- VkStructureType, VkSurfaceCapabilitiesKHR,
-- vkGetPhysicalDeviceSurfaceCapabilities2KHR
data VkSurfaceCapabilities2KHR
VkSurfaceCapabilities2KHR :: VkStructureType -> Ptr () -> VkSurfaceCapabilitiesKHR -> VkSurfaceCapabilities2KHR
-- | sType is the type of this structure.
[$sel:vkSType:VkSurfaceCapabilities2KHR] :: VkSurfaceCapabilities2KHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSurfaceCapabilities2KHR] :: VkSurfaceCapabilities2KHR -> Ptr ()
-- | surfaceCapabilities is a structure of type
-- VkSurfaceCapabilitiesKHR describing the capabilities of the
-- specified surface.
[$sel:vkSurfaceCapabilities:VkSurfaceCapabilities2KHR] :: VkSurfaceCapabilities2KHR -> VkSurfaceCapabilitiesKHR
-- | VkSurfaceFormat2KHR - Structure describing a supported swapchain
-- format tuple
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SURFACE_FORMAT_2_KHR
--
--
--
--
-- See Also
--
-- VkStructureType, VkSurfaceFormatKHR,
-- vkGetPhysicalDeviceSurfaceFormats2KHR
data VkSurfaceFormat2KHR
VkSurfaceFormat2KHR :: VkStructureType -> Ptr () -> VkSurfaceFormatKHR -> VkSurfaceFormat2KHR
-- | sType is the type of this structure.
[$sel:vkSType:VkSurfaceFormat2KHR] :: VkSurfaceFormat2KHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSurfaceFormat2KHR] :: VkSurfaceFormat2KHR -> Ptr ()
-- | surfaceFormat is an instance of VkSurfaceFormatKHR
-- describing a format-color space pair that is compatible with the
-- specified surface.
[$sel:vkSurfaceFormat:VkSurfaceFormat2KHR] :: VkSurfaceFormat2KHR -> VkSurfaceFormatKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceFormat2KHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceFormat2KHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceCapabilities2KHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceCapabilities2KHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkPhysicalDeviceSurfaceInfo2KHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkPhysicalDeviceSurfaceInfo2KHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceFormat2KHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkSurfaceCapabilities2KHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_get_surface_capabilities2.VkPhysicalDeviceSurfaceInfo2KHR
module Graphics.Vulkan.Extensions.VK_EXT_swapchain_colorspace
module Graphics.Vulkan.Extensions.VK_KHR_incremental_present
-- | VkPresentRegionsKHR - Structure hint of rectangular regions changed by
-- vkQueuePresentKHR
--
-- Description
--
-- Valid Usage
--
--
-- - swapchainCount must be the same value as
-- VkPresentInfoKHR::swapchainCount, where
-- VkPresentInfoKHR is in the pNext-chain of this
-- VkPresentRegionsKHR structure.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PRESENT_REGIONS_KHR
--
--
--
-- - If pRegions is not NULL, pRegions
-- must be a valid pointer to an array of swapchainCount
-- valid VkPresentRegionKHR structures
-- - swapchainCount must be greater than
-- 0
--
--
-- See Also
--
-- VkPresentRegionKHR, VkStructureType
data VkPresentRegionsKHR
VkPresentRegionsKHR :: VkStructureType -> Ptr () -> Word32 -> Ptr VkPresentRegionKHR -> VkPresentRegionsKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkPresentRegionsKHR] :: VkPresentRegionsKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPresentRegionsKHR] :: VkPresentRegionsKHR -> Ptr ()
-- | swapchainCount is the number of swapchains being presented to
-- by this command.
[$sel:vkSwapchainCount:VkPresentRegionsKHR] :: VkPresentRegionsKHR -> Word32
-- | pRegions is NULL or a pointer to an array of
-- VkPresentRegionKHR elements with swapchainCount
-- entries. If not NULL, each element of pRegions
-- contains the region that has changed since the last present to the
-- swapchain in the corresponding entry in the
-- VkPresentInfoKHR::pSwapchains array.
[$sel:vkPRegions:VkPresentRegionsKHR] :: VkPresentRegionsKHR -> Ptr VkPresentRegionKHR
-- | VkPresentRegionKHR - Structure containing rectangular region changed
-- by vkQueuePresentKHR for a given VkImage
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - If rectangleCount is not 0, and
-- pRectangles is not NULL, pRectangles
-- must be a valid pointer to an array of rectangleCount
-- VkRectLayerKHR structures
--
--
-- See Also
--
-- VkPresentRegionsKHR, VkRectLayerKHR
data VkPresentRegionKHR
VkPresentRegionKHR :: Word32 -> Ptr VkRectLayerKHR -> VkPresentRegionKHR
-- | rectangleCount is the number of rectangles in
-- pRectangles, or zero if the entire image has changed and
-- should be presented.
[$sel:vkRectangleCount:VkPresentRegionKHR] :: VkPresentRegionKHR -> Word32
-- | pRectangles is either NULL or a pointer to an array
-- of VkRectLayerKHR structures. The VkRectLayerKHR
-- structure is the framebuffer coordinates, plus layer, of a portion of
-- a presentable image that has changed and must be presented. If
-- non-NULL, each entry in pRectangles is a rectangle
-- of the given image that has changed since the last image was presented
-- to the given swapchain.
[$sel:vkPRectangles:VkPresentRegionKHR] :: VkPresentRegionKHR -> Ptr VkRectLayerKHR
-- | VkRectLayerKHR - Structure containing a rectangle, including layer,
-- changed by vkQueuePresentKHR for a given VkImage
--
-- Description
--
-- Valid Usage
--
--
-- - The sum of offset and extent must be no
-- greater than the imageExtent member of the
-- VkSwapchainCreateInfoKHR structure given to
-- vkCreateSwapchainKHR.
--
--
--
-- - layer must be less than imageArrayLayers
-- member of the VkSwapchainCreateInfoKHR structure given to
-- vkCreateSwapchainKHR.
--
--
-- Some platforms allow the size of a surface to change, and then scale
-- the pixels of the image to fit the surface. VkRectLayerKHR
-- specifies pixels of the swapchain’s image(s), which will be constant
-- for the life of the swapchain.
--
-- See Also
--
-- VkExtent2D, VkOffset2D, VkPresentRegionKHR
data VkRectLayerKHR
VkRectLayerKHR :: VkOffset2D -> VkExtent2D -> Word32 -> VkRectLayerKHR
-- | offset is the origin of the rectangle, in pixels.
[$sel:vkOffset:VkRectLayerKHR] :: VkRectLayerKHR -> VkOffset2D
-- | extent is the size of the rectangle, in pixels.
[$sel:vkExtent:VkRectLayerKHR] :: VkRectLayerKHR -> VkExtent2D
-- | layer is the layer of the image. For images with only one
-- layer, the value of layer must be 0.
[$sel:vkLayer:VkRectLayerKHR] :: VkRectLayerKHR -> Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkRectLayerKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkRectLayerKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkPresentRegionKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_incremental_present.VkRectLayerKHR
module Graphics.Vulkan.Extensions.VK_KHR_display
-- | VkDisplayPlaneAlphaFlagBitsKHR - Alpha blending type
--
-- See Also
--
-- VkDisplayPlaneAlphaFlagsKHR,
-- VkDisplaySurfaceCreateInfoKHR
newtype VkDisplayPlaneAlphaFlagBitsKHR
VkDisplayPlaneAlphaFlagBitsKHR :: VkFlags -> VkDisplayPlaneAlphaFlagBitsKHR
-- | VK_DISPLAY_PLANE_ALPHA_OPAQUE_BIT_KHR specifies that the
-- source image will be treated as opaque.
-- | VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR specifies that a global
-- alpha value must be specified that will be applied to all
-- pixels in the source image.
-- | VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR specifies that the
-- alpha value will be determined by the alpha channel of the source
-- image’s pixels. If the source format contains no alpha values, no
-- blending will be applied. The source alpha values are not
-- premultiplied into the source image’s other color channels.
-- | VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_PREMULTIPLIED_BIT_KHR is
-- equivalent to VK_DISPLAY_PLANE_ALPHA_PER_PIXEL_BIT_KHR,
-- except the source alpha values are assumed to be premultiplied into
-- the source image’s other color channels.
newtype VkDisplayModeCreateFlagsKHR
VkDisplayModeCreateFlagsKHR :: VkFlags -> VkDisplayModeCreateFlagsKHR
newtype VkDisplaySurfaceCreateFlagsKHR
VkDisplaySurfaceCreateFlagsKHR :: VkFlags -> VkDisplaySurfaceCreateFlagsKHR
-- | VkDisplayKHR - Opaque handle to a display object
--
-- Description
--
-- See Also
--
-- VkDisplayPlanePropertiesKHR, VkDisplayPropertiesKHR,
-- vkAcquireXlibDisplayEXT, vkCreateDisplayModeKHR,
-- vkDisplayPowerControlEXT, vkGetDisplayModePropertiesKHR,
-- vkGetDisplayPlaneSupportedDisplaysKHR,
-- vkGetRandROutputDisplayEXT, vkRegisterDisplayEventEXT,
-- vkReleaseDisplayEXT
type VkDisplayKHR = Ptr VkDisplayKHR_T
-- | VkDisplayModeKHR - Opaque handle to a display mode object
--
-- Description
--
-- See Also
--
-- VkDisplayModePropertiesKHR,
-- VkDisplaySurfaceCreateInfoKHR, vkCreateDisplayModeKHR,
-- vkGetDisplayPlaneCapabilitiesKHR
type VkDisplayModeKHR = Ptr VkDisplayModeKHR_T
-- | vkGetPhysicalDeviceDisplayPropertiesKHR - Query information about the
-- available displays
--
-- Parameters
--
--
-- - physicalDevice is a physical device.
--
--
--
-- - pPropertyCount is a pointer to an integer related to the
-- number of display devices available or queried, as described
-- below.
-- - pProperties is either NULL or a pointer to an
-- array of VkDisplayPropertiesKHR structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of display
-- devices available for physicalDevice is returned in
-- pPropertyCount. Otherwise, pPropertyCount
-- must point to a variable set by the user to the number of
-- elements in the pProperties array, and on return the variable
-- is overwritten with the number of structures actually written to
-- pProperties. If the value of pPropertyCount is less
-- than the number of display devices for physicalDevice, at
-- most pPropertyCount structures will be written. If
-- pPropertyCount is smaller than the number of display devices
-- available for physicalDevice, VK_INCOMPLETE will be
-- returned instead of VK_SUCCESS to indicate that not all the
-- available values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkDisplayPropertiesKHR
-- structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDisplayPropertiesKHR, VkPhysicalDevice
vkGetPhysicalDeviceDisplayPropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkDisplayPropertiesKHR) -> IO VkResult
-- | vkGetPhysicalDeviceDisplayPlanePropertiesKHR - Query the plane
-- properties
--
-- Parameters
--
--
-- - physicalDevice is a physical device.
--
--
--
-- - pPropertyCount is a pointer to an integer related to the
-- number of display planes available or queried, as described
-- below.
-- - pProperties is either NULL or a pointer to an
-- array of VkDisplayPlanePropertiesKHR structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of display
-- planes available for physicalDevice is returned in
-- pPropertyCount. Otherwise, pPropertyCount
-- must point to a variable set by the user to the number of
-- elements in the pProperties array, and on return the variable
-- is overwritten with the number of structures actually written to
-- pProperties. If the value of pPropertyCount is less
-- than the number of display planes for physicalDevice, at most
-- pPropertyCount structures will be written.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkDisplayPlanePropertiesKHR
-- structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDisplayPlanePropertiesKHR, VkPhysicalDevice
vkGetPhysicalDeviceDisplayPlanePropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkDisplayPlanePropertiesKHR) -> IO VkResult
-- | vkGetDisplayPlaneSupportedDisplaysKHR - Query the list of displays a
-- plane supports
--
-- Parameters
--
--
-- - physicalDevice is a physical device.
--
--
--
-- - planeIndex is the plane which the application wishes to
-- use, and must be in the range [0, physical device plane count -
-- 1].
-- - pDisplayCount is a pointer to an integer related to the
-- number of displays available or queried, as described below.
-- - pDisplays is either NULL or a pointer to an
-- array of VkDisplayKHR handles.
--
--
-- Description
--
-- If pDisplays is NULL, then the number of displays
-- usable with the specified planeIndex for
-- physicalDevice is returned in pDisplayCount.
-- Otherwise, pDisplayCount must point to a variable set
-- by the user to the number of elements in the pDisplays array,
-- and on return the variable is overwritten with the number of handles
-- actually written to pDisplays. If the value of
-- pDisplayCount is less than the number of display planes for
-- physicalDevice, at most pDisplayCount handles will
-- be written. If pDisplayCount is smaller than the number of
-- displays usable with the specified planeIndex for
-- physicalDevice, VK_INCOMPLETE will be returned
-- instead of VK_SUCCESS to indicate that not all the available
-- values were returned.
--
-- Valid Usage
--
--
-- - planeIndex must be less than the number of display
-- planes supported by the device as determined by calling
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR
--
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pDisplayCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pDisplayCount is not
-- 0, and pDisplays is not NULL,
-- pDisplays must be a valid pointer to an array of
-- pDisplayCount VkDisplayKHR handles
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDisplayKHR, VkPhysicalDevice
vkGetDisplayPlaneSupportedDisplaysKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("planeIndex" ::: Word32) -> ("pDisplayCount" ::: Ptr Word32) -> ("pDisplays" ::: Ptr VkDisplayKHR) -> IO VkResult
-- | vkGetDisplayModePropertiesKHR - Query the set of mode properties
-- supported by the display
--
-- Parameters
--
--
-- - physicalDevice is the physical device associated with
-- display.
--
--
--
-- - display is the display to query.
-- - pPropertyCount is a pointer to an integer related to the
-- number of display modes available or queried, as described below.
-- - pProperties is either NULL or a pointer to an
-- array of VkDisplayModePropertiesKHR structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of display
-- modes available on the specified display for
-- physicalDevice is returned in pPropertyCount.
-- Otherwise, pPropertyCount must point to a variable set
-- by the user to the number of elements in the pProperties
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pProperties. If the value of
-- pPropertyCount is less than the number of display modes for
-- physicalDevice, at most pPropertyCount structures
-- will be written. If pPropertyCount is smaller than the number
-- of display modes available on the specified display for
-- physicalDevice, VK_INCOMPLETE will be returned
-- instead of VK_SUCCESS to indicate that not all the available
-- values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - display must be a valid VkDisplayKHR
-- handle
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkDisplayModePropertiesKHR
-- structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDisplayKHR, VkDisplayModePropertiesKHR,
-- VkPhysicalDevice
vkGetDisplayModePropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("display" ::: VkDisplayKHR) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkDisplayModePropertiesKHR) -> IO VkResult
-- | vkCreateDisplayModeKHR - Create a display mode
--
-- Parameters
--
--
-- - physicalDevice is the physical device associated with
-- display.
--
--
--
-- - display is the display to create an additional mode
-- for.
-- - pCreateInfo is a VkDisplayModeCreateInfoKHR
-- structure describing the new mode to create.
-- - pAllocator is the allocator used for host memory
-- allocated for the display mode object when there is no more specific
-- allocator available (see Memory Allocation).
-- - pMode returns the handle of the mode created.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - display must be a valid VkDisplayKHR
-- handle
-- - pCreateInfo must be a valid pointer to a valid
-- VkDisplayModeCreateInfoKHR structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pMode must be a valid pointer to a
-- VkDisplayModeKHR handle
--
--
-- Host Synchronization
--
--
-- - Host access to display must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDisplayKHR,
-- VkDisplayModeCreateInfoKHR, VkDisplayModeKHR,
-- VkPhysicalDevice
vkCreateDisplayModeKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("display" ::: VkDisplayKHR) -> ("pCreateInfo" ::: Ptr VkDisplayModeCreateInfoKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pMode" ::: Ptr VkDisplayModeKHR) -> IO VkResult
-- | vkGetDisplayPlaneCapabilitiesKHR - Query capabilities of a mode and
-- plane combination
--
-- Parameters
--
--
-- - physicalDevice is the physical device associated with
-- display
--
--
--
-- - mode is the display mode the application intends to
-- program when using the specified plane. Note this parameter also
-- implicitly specifies a display.
-- - planeIndex is the plane which the application intends to
-- use with the display, and is less than the number of display planes
-- supported by the device.
-- - pCapabilities is a pointer to a
-- VkDisplayPlaneCapabilitiesKHR structure in which the
-- capabilities are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - mode must be a valid VkDisplayModeKHR
-- handle
-- - pCapabilities must be a valid pointer to a
-- VkDisplayPlaneCapabilitiesKHR structure
--
--
-- Host Synchronization
--
--
-- - Host access to mode must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDisplayModeKHR, VkDisplayPlaneCapabilitiesKHR,
-- VkPhysicalDevice
vkGetDisplayPlaneCapabilitiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("mode" ::: VkDisplayModeKHR) -> ("planeIndex" ::: Word32) -> ("pCapabilities" ::: Ptr VkDisplayPlaneCapabilitiesKHR) -> IO VkResult
-- | vkCreateDisplayPlaneSurfaceKHR - Create a VkSurfaceKHR
-- structure representing a display plane and mode
--
-- Parameters
--
--
-- - instance is the instance corresponding to the physical
-- device the targeted display is on.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkDisplaySurfaceCreateInfoKHR structure specifying which mode,
-- plane, and other parameters to use, as described below.
-- - pAllocator is the allocator used for host memory
-- allocated for the surface object when there is no more specific
-- allocator available (see Memory Allocation).
-- - pSurface points to a VkSurfaceKHR handle in
-- which the created surface is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - instance must be a valid VkInstance
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDisplaySurfaceCreateInfoKHR structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSurface must be a valid pointer to a
-- VkSurfaceKHR handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDisplaySurfaceCreateInfoKHR,
-- VkInstance, VkSurfaceKHR
vkCreateDisplayPlaneSurfaceKHR :: ("instance" ::: VkInstance) -> ("pCreateInfo" ::: Ptr VkDisplaySurfaceCreateInfoKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSurface" ::: Ptr VkSurfaceKHR) -> IO VkResult
-- | VkDisplayPropertiesKHR - Structure describing an available display
-- device
--
-- Description
--
-- Note
--
-- For devices which have no natural value to return here,
-- implementations should return the maximum resolution supported.
--
--
-- - supportedTransforms tells which transforms are supported
-- by this display. This will contain one or more of the bits from
-- VkSurfaceTransformFlagsKHR.
-- - planeReorderPossible tells whether the planes on this
-- display can have their z order changed. If this is
-- VK_TRUE, the application can re-arrange the planes on
-- this display in any order relative to each other.
-- - persistentContent tells whether the display supports
-- self-refresh/internal buffering. If this is true, the application
-- can submit persistent present operations on swapchains created
-- against this display.
--
--
-- Note
--
-- Persistent presents may have higher latency, and may use
-- less power when the screen content is updated infrequently, or when
-- only a portion of the screen needs to be updated in most frames.
--
-- See Also
--
-- VkBool32, VkDisplayKHR, VkExtent2D,
-- VkSurfaceTransformFlagsKHR,
-- vkGetPhysicalDeviceDisplayPropertiesKHR
data VkDisplayPropertiesKHR
VkDisplayPropertiesKHR :: VkDisplayKHR -> Ptr CChar -> VkExtent2D -> VkExtent2D -> VkSurfaceTransformFlagsKHR -> VkBool32 -> VkBool32 -> VkDisplayPropertiesKHR
-- | display is a handle that is used to refer to the display
-- described here. This handle will be valid for the lifetime of the
-- Vulkan instance.
[$sel:vkDisplay:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkDisplayKHR
-- | displayName is a pointer to a NULL-terminated string
-- containing the name of the display. Generally, this will be the name
-- provided by the display’s EDID. It can be NULL if no
-- suitable name is available. If not NULL, the memory it points
-- to must remain accessible as long as display is valid.
[$sel:vkDisplayName:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> Ptr CChar
-- | physicalDimensions describes the physical width and height of
-- the visible portion of the display, in millimeters.
[$sel:vkPhysicalDimensions:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkExtent2D
-- | physicalResolution describes the physical, native, or
-- preferred resolution of the display.
[$sel:vkPhysicalResolution:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkExtent2D
[$sel:vkSupportedTransforms:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkSurfaceTransformFlagsKHR
[$sel:vkPlaneReorderPossible:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkBool32
[$sel:vkPersistentContent:VkDisplayPropertiesKHR] :: VkDisplayPropertiesKHR -> VkBool32
-- | VkDisplayPlanePropertiesKHR - Structure describing display plane
-- properties
--
-- Description
--
-- See Also
--
-- VkDisplayKHR,
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR
data VkDisplayPlanePropertiesKHR
VkDisplayPlanePropertiesKHR :: VkDisplayKHR -> Word32 -> VkDisplayPlanePropertiesKHR
-- | currentDisplay is the handle of the display the plane is
-- currently associated with. If the plane is not currently attached to
-- any displays, this will be VK_NULL_HANDLE.
[$sel:vkCurrentDisplay:VkDisplayPlanePropertiesKHR] :: VkDisplayPlanePropertiesKHR -> VkDisplayKHR
-- | currentStackIndex is the current z-order of the plane. This
-- will be between 0 and the value returned by
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR in
-- pPropertyCount.
[$sel:vkCurrentStackIndex:VkDisplayPlanePropertiesKHR] :: VkDisplayPlanePropertiesKHR -> Word32
-- | VkDisplayModeParametersKHR - Structure describing display parameters
-- associated with a display mode
--
-- Description
--
-- Note
--
-- For example, a 60Hz display mode would report a refreshRate
-- of 60,000.
--
-- See Also
--
-- VkDisplayModeCreateInfoKHR, VkDisplayModePropertiesKHR,
-- VkExtent2D
data VkDisplayModeParametersKHR
VkDisplayModeParametersKHR :: VkExtent2D -> Word32 -> VkDisplayModeParametersKHR
-- | visibleRegion is the 2D extents of the visible region.
[$sel:vkVisibleRegion:VkDisplayModeParametersKHR] :: VkDisplayModeParametersKHR -> VkExtent2D
-- | refreshRate is a uint32_t that is the number of
-- times the display is refreshed each second multiplied by 1000.
[$sel:vkRefreshRate:VkDisplayModeParametersKHR] :: VkDisplayModeParametersKHR -> Word32
-- | VkDisplayModePropertiesKHR - Structure describing display mode
-- properties
--
-- Description
--
-- See Also
--
-- VkDisplayModeKHR, VkDisplayModeParametersKHR,
-- vkGetDisplayModePropertiesKHR
data VkDisplayModePropertiesKHR
VkDisplayModePropertiesKHR :: VkDisplayModeKHR -> VkDisplayModeParametersKHR -> VkDisplayModePropertiesKHR
-- | displayMode is a handle to the display mode described in this
-- structure. This handle will be valid for the lifetime of the Vulkan
-- instance.
[$sel:vkDisplayMode:VkDisplayModePropertiesKHR] :: VkDisplayModePropertiesKHR -> VkDisplayModeKHR
-- | parameters is a VkDisplayModeParametersKHR structure
-- describing the display parameters associated with
-- displayMode.
[$sel:vkParameters:VkDisplayModePropertiesKHR] :: VkDisplayModePropertiesKHR -> VkDisplayModeParametersKHR
-- | VkDisplayModeCreateInfoKHR - Structure specifying parameters of a
-- newly created display mode object
--
-- Description
--
-- Valid Usage
--
--
-- - The width and height members of the
-- visibleRegion member of parameters must be
-- greater than 0
--
--
--
-- - The refreshRate member of parameters must
-- be greater than 0
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DISPLAY_MODE_CREATE_INFO_KHR
--
--
--
-- - pNext must be NULL
-- - flags must be 0
--
--
-- See Also
--
-- VkDisplayModeCreateFlagsKHR, VkDisplayModeParametersKHR,
-- VkStructureType, vkCreateDisplayModeKHR
data VkDisplayModeCreateInfoKHR
VkDisplayModeCreateInfoKHR :: VkStructureType -> Ptr () -> VkDisplayModeCreateFlagsKHR -> VkDisplayModeParametersKHR -> VkDisplayModeCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDisplayModeCreateInfoKHR] :: VkDisplayModeCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDisplayModeCreateInfoKHR] :: VkDisplayModeCreateInfoKHR -> Ptr ()
-- | flags is reserved for future use, and must be zero.
[$sel:vkFlags:VkDisplayModeCreateInfoKHR] :: VkDisplayModeCreateInfoKHR -> VkDisplayModeCreateFlagsKHR
-- | parameters is a VkDisplayModeParametersKHR structure
-- describing the display parameters to use in creating the new mode. If
-- the parameters are not compatible with the specified display, the
-- implementation must return
-- VK_ERROR_INITIALIZATION_FAILED.
[$sel:vkParameters:VkDisplayModeCreateInfoKHR] :: VkDisplayModeCreateInfoKHR -> VkDisplayModeParametersKHR
-- | VkDisplayPlaneCapabilitiesKHR - Structure describing capabilities of a
-- mode and plane combination
--
-- Description
--
-- The minimum and maximum position and extent fields describe the
-- implementation limits, if any, as they apply to the specified display
-- mode and plane. Vendors may support displaying a subset of a
-- swapchain’s presentable images on the specified display plane. This is
-- expressed by returning minSrcPosition,
-- maxSrcPosition, minSrcExtent, and
-- maxSrcExtent values that indicate a range of possible
-- positions and sizes may be used to specify the region within
-- the presentable images that source pixels will be read from when
-- creating a swapchain on the specified display mode and plane.
--
-- Vendors may also support mapping the presentable images’
-- content to a subset or superset of the visible region in the specified
-- display mode. This is expressed by returning minDstPosition,
-- maxDstPosition, minDstExtent and
-- maxDstExtent values that indicate a range of possible
-- positions and sizes may be used to describe the region within
-- the display mode that the source pixels will be mapped to.
--
-- Other vendors may support only a 1-1 mapping between pixels in
-- the presentable images and the display mode. This may be
-- indicated by returning (0,0) for minSrcPosition,
-- maxSrcPosition, minDstPosition, and
-- maxDstPosition, and (display mode width, display mode height)
-- for minSrcExtent, maxSrcExtent,
-- minDstExtent, and maxDstExtent.
--
-- These values indicate the limits of the implementation’s individual
-- fields. Not all combinations of values within the offset and extent
-- ranges returned in VkDisplayPlaneCapabilitiesKHR are
-- guaranteed to be supported. Vendors may still fail presentation
-- requests that specify unsupported combinations.
--
-- See Also
--
-- VkDisplayPlaneAlphaFlagsKHR, VkExtent2D,
-- VkOffset2D, vkGetDisplayPlaneCapabilitiesKHR
data VkDisplayPlaneCapabilitiesKHR
VkDisplayPlaneCapabilitiesKHR :: VkDisplayPlaneAlphaFlagsKHR -> VkOffset2D -> VkOffset2D -> VkExtent2D -> VkExtent2D -> VkOffset2D -> VkOffset2D -> VkExtent2D -> VkExtent2D -> VkDisplayPlaneCapabilitiesKHR
-- | supportedAlpha is a bitmask of
-- VkDisplayPlaneAlphaFlagBitsKHR describing the supported alpha
-- blending modes.
[$sel:vkSupportedAlpha:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkDisplayPlaneAlphaFlagsKHR
-- | minSrcPosition is the minimum source rectangle offset
-- supported by this plane using the specified mode.
[$sel:vkMinSrcPosition:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkOffset2D
-- | maxSrcPosition is the maximum source rectangle offset
-- supported by this plane using the specified mode. The x and
-- y components of maxSrcPosition must each be
-- greater than or equal to the x and y components of
-- minSrcPosition, respectively.
[$sel:vkMaxSrcPosition:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkOffset2D
-- | minSrcExtent is the minimum source rectangle size supported
-- by this plane using the specified mode.
[$sel:vkMinSrcExtent:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkExtent2D
-- | maxSrcExtent is the maximum source rectangle size supported
-- by this plane using the specified mode.
[$sel:vkMaxSrcExtent:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkExtent2D
-- | minDstPosition, maxDstPosition,
-- minDstExtent, maxDstExtent all have similar
-- semantics to their corresponding *Src* equivalents, but apply
-- to the output region within the mode rather than the input region
-- within the source image. Unlike the *Src* offsets,
-- minDstPosition and maxDstPosition may contain
-- negative values.
[$sel:vkMinDstPosition:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkOffset2D
[$sel:vkMaxDstPosition:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkOffset2D
[$sel:vkMinDstExtent:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkExtent2D
[$sel:vkMaxDstExtent:VkDisplayPlaneCapabilitiesKHR] :: VkDisplayPlaneCapabilitiesKHR -> VkExtent2D
-- | VkDisplaySurfaceCreateInfoKHR - Structure specifying parameters of a
-- newly created display plane surface object
--
-- Description
--
-- Note
--
-- Creating a display surface must not modify the state of the
-- displays, planes, or other resources it names. For example, it
-- must not apply the specified mode to be set on the associated
-- display. Application of display configuration occurs as a side effect
-- of presenting to a display surface.
--
-- Valid Usage
--
--
-- - planeIndex must be less than the number of display
-- planes supported by the device as determined by calling
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR
--
--
--
-- - If the planeReorderPossible member of the
-- VkDisplayPropertiesKHR structure returned by
-- vkGetPhysicalDeviceDisplayPropertiesKHR for the display
-- corresponding to displayMode is VK_TRUE then
-- planeStackIndex must be less than the number of
-- display planes supported by the device as determined by calling
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR; otherwise
-- planeStackIndex must equal the
-- currentStackIndex member of
-- VkDisplayPlanePropertiesKHR returned by
-- vkGetPhysicalDeviceDisplayPlanePropertiesKHR for the display
-- plane corresponding to displayMode
-- - If alphaMode is
-- VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR then
-- globalAlpha must be between 0 and 1,
-- inclusive
-- - alphaMode must be 0 or one of the bits
-- present in the supportedAlpha member of
-- VkDisplayPlaneCapabilitiesKHR returned by
-- vkGetDisplayPlaneCapabilitiesKHR for the display plane
-- corresponding to displayMode
-- - The width and height members of
-- imageExtent must be less than the
-- maxImageDimensions2D member of
-- VkPhysicalDeviceLimits
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DISPLAY_SURFACE_CREATE_INFO_KHR
--
--
--
--
-- See Also
--
-- VkDisplayModeKHR, VkDisplayPlaneAlphaFlagBitsKHR,
-- VkDisplaySurfaceCreateFlagsKHR, VkExtent2D,
-- VkStructureType, VkSurfaceTransformFlagBitsKHR,
-- vkCreateDisplayPlaneSurfaceKHR
data VkDisplaySurfaceCreateInfoKHR
VkDisplaySurfaceCreateInfoKHR :: VkStructureType -> Ptr () -> VkDisplaySurfaceCreateFlagsKHR -> VkDisplayModeKHR -> Word32 -> Word32 -> VkSurfaceTransformFlagBitsKHR -> CFloat -> VkDisplayPlaneAlphaFlagBitsKHR -> VkExtent2D -> VkDisplaySurfaceCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> Ptr ()
-- | flags is reserved for future use, and must be zero.
[$sel:vkFlags:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkDisplaySurfaceCreateFlagsKHR
-- | displayMode is a VkDisplayModeKHR handle specifying
-- the mode to use when displaying this surface.
[$sel:vkDisplayMode:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkDisplayModeKHR
-- | planeIndex is the plane on which this surface appears.
[$sel:vkPlaneIndex:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> Word32
-- | planeStackIndex is the z-order of the plane.
[$sel:vkPlaneStackIndex:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> Word32
-- | transform is a VkSurfaceTransformFlagBitsKHR value
-- specifying the transformation to apply to images as part of the
-- scanout operation.
[$sel:vkTransform:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkSurfaceTransformFlagBitsKHR
-- | globalAlpha is the global alpha value. This value is ignored
-- if alphaMode is not
-- VK_DISPLAY_PLANE_ALPHA_GLOBAL_BIT_KHR.
[$sel:vkGlobalAlpha:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> CFloat
-- | alphaMode is a VkDisplayPlaneAlphaFlagBitsKHR value
-- specifying the type of alpha blending to use.
[$sel:vkAlphaMode:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkDisplayPlaneAlphaFlagBitsKHR
-- | imageExtent The size of the presentable images to use with
-- the surface.
[$sel:vkImageExtent:VkDisplaySurfaceCreateInfoKHR] :: VkDisplaySurfaceCreateInfoKHR -> VkExtent2D
-- | VkDisplayPlaneAlphaFlagsKHR - Bitmask of
-- VkDisplayPlaneAlphaFlagBitsKHR
--
-- Description
--
-- VkDisplayPlaneAlphaFlagsKHR is a bitmask type for setting a
-- mask of zero or more VkDisplayPlaneAlphaFlagBitsKHR.
--
-- See Also
--
-- VkDisplayPlaneAlphaFlagBitsKHR,
-- VkDisplayPlaneCapabilitiesKHR
type VkDisplayPlaneAlphaFlagsKHR = VkDisplayPlaneAlphaFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneCapabilitiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneCapabilitiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModePropertiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModePropertiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeParametersKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeParametersKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlanePropertiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlanePropertiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPropertiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPropertiesKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneCapabilitiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModePropertiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeParametersKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlanePropertiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPropertiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplaySurfaceCreateFlagsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayModeCreateFlagsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_display.VkDisplayPlaneAlphaFlagBitsKHR
module Graphics.Vulkan.Extensions.VK_EXT_direct_mode_display
-- | vkReleaseDisplayEXT - Release access to an acquired VkDisplayKHR
--
-- Parameters
--
--
-- - physicalDevice The physical device the display is
-- on.
--
--
--
-- - display The display to release control of.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - display must be a valid VkDisplayKHR
-- handle
--
--
-- Return Codes
--
--
--
-- See Also
--
-- VkDisplayKHR, VkPhysicalDevice
vkReleaseDisplayEXT :: ("physicalDevice" ::: VkPhysicalDevice) -> ("display" ::: VkDisplayKHR) -> IO VkResult
module Graphics.Vulkan.Extensions.VK_EXT_sample_locations
-- | VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT specifies that the
-- sampleLocationsInfo state in
-- VkPipelineSampleLocationsStateCreateInfoEXT will be ignored and
-- must be set dynamically with vkCmdSetSampleLocationsEXT
-- before any draw or clear commands. Enabling custom sample locations is
-- still indicated by the sampleLocationsEnable member of
-- VkPipelineSampleLocationsStateCreateInfoEXT.
-- | vkCmdSetSampleLocationsEXT - Set the dynamic sample locations state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - pSampleLocationsInfo is the sample locations state to
-- set.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT dynamic state
-- enabled
--
--
--
-- - The sampleLocationsPerPixel member of
-- pSampleLocationsInfo must equal the
-- rasterizationSamples member of the
-- VkPipelineMultisampleStateCreateInfo structure the bound
-- graphics pipeline has been created with
-- - If
-- VkPhysicalDeviceSampleLocationsPropertiesEXT::variableSampleLocations
-- is VK_FALSE then the current render pass must have
-- been begun by specifying a
-- VkRenderPassSampleLocationsBeginInfoEXT structure whose
-- pPostSubpassSampleLocations member contains an element with a
-- subpassIndex matching the current subpass index and the
-- sampleLocationsInfo member of that element must match
-- the sample locations state pointed to by
-- pSampleLocationsInfo
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pSampleLocationsInfo must be a valid pointer to a
-- valid VkSampleLocationsInfoEXT structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkSampleLocationsInfoEXT
vkCmdSetSampleLocationsEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("pSampleLocationsInfo" ::: Ptr VkSampleLocationsInfoEXT) -> IO ()
-- | vkGetPhysicalDeviceMultisamplePropertiesEXT - Report sample count
-- specific multisampling capabilities of a physical device
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the additional multisampling capabilities.
--
--
--
-- - samples is the sample count to query the capabilities
-- for.
-- - pMultisampleProperties is a pointer to a structure of
-- type VkMultisamplePropertiesEXT, in which information about the
-- additional multisampling capabilities specific to the sample count is
-- returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - samples must be a valid
-- VkSampleCountFlagBits value
-- - pMultisampleProperties must be a valid pointer to
-- a VkMultisamplePropertiesEXT structure
--
--
-- See Also
--
-- VkMultisamplePropertiesEXT, VkPhysicalDevice,
-- VkSampleCountFlagBits
vkGetPhysicalDeviceMultisamplePropertiesEXT :: ("physicalDevice" ::: VkPhysicalDevice) -> ("samples" ::: VkSampleCountFlagBits) -> ("pMultisampleProperties" ::: Ptr VkMultisamplePropertiesEXT) -> IO ()
-- | VkSampleLocationEXT - Structure specifying the coordinates of a sample
-- location
--
-- Description
--
-- The domain space of the sample location coordinates has an upper-left
-- origin within the pixel in framebuffer space.
--
-- The values specified in a VkSampleLocationEXT structure are
-- always clamped to the implementation-dependent sample location
-- coordinate range
-- [sampleLocationCoordinateRange[0],sampleLocationCoordinateRange[1]]
-- that can be queried by chaining the
-- VkPhysicalDeviceSampleLocationsPropertiesEXT structure to the
-- pNext chain of VkPhysicalDeviceProperties2.
--
-- See Also
--
-- VkSampleLocationsInfoEXT
data VkSampleLocationEXT
VkSampleLocationEXT :: CFloat -> CFloat -> VkSampleLocationEXT
-- | x is the horizontal coordinate of the sample’s location.
[$sel:vkX:VkSampleLocationEXT] :: VkSampleLocationEXT -> CFloat
-- | y is the vertical coordinate of the sample’s location.
[$sel:vkY:VkSampleLocationEXT] :: VkSampleLocationEXT -> CFloat
-- | VkSampleLocationsInfoEXT - Structure specifying a set of sample
-- locations
--
-- Description
--
-- This structure can be used either to specify the sample
-- locations to be used for rendering or to specify the set of sample
-- locations an image subresource has been last rendered with for the
-- purposes of layout transitions of depth/stencil images created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT.
--
-- The sample locations in pSampleLocations specify
-- sampleLocationsPerPixel number of sample locations for each
-- pixel in the grid of the size specified in
-- sampleLocationGridSize. The sample location for sample i at
-- the pixel grid location (x,y) is taken from
-- pSampleLocations[(x + y *
-- sampleLocationGridSize.width) *
-- sampleLocationsPerPixel + i].
--
-- Valid Usage
--
--
--
--
-- - sampleLocationsCount must equal
-- sampleLocationsPerPixel ×
-- sampleLocationGridSize.width ×
-- sampleLocationGridSize.height
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLE_LOCATIONS_INFO_EXT
--
--
--
-- - sampleLocationsPerPixel must be a valid
-- VkSampleCountFlagBits value
-- - pSampleLocations must be a valid pointer to an
-- array of sampleLocationsCount VkSampleLocationEXT
-- structures
-- - sampleLocationsCount must be greater than
-- 0
--
--
-- See Also
--
-- VkAttachmentSampleLocationsEXT, VkExtent2D,
-- VkPipelineSampleLocationsStateCreateInfoEXT,
-- VkSampleCountFlagBits, VkSampleLocationEXT,
-- VkStructureType, VkSubpassSampleLocationsEXT,
-- vkCmdSetSampleLocationsEXT
data VkSampleLocationsInfoEXT
VkSampleLocationsInfoEXT :: VkStructureType -> Ptr () -> VkSampleCountFlagBits -> VkExtent2D -> Word32 -> Ptr VkSampleLocationEXT -> VkSampleLocationsInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> Ptr ()
-- | sampleLocationsPerPixel is a VkSampleCountFlagBits
-- specifying the number of sample locations per pixel.
[$sel:vkSampleLocationsPerPixel:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> VkSampleCountFlagBits
-- | sampleLocationGridSize is the size of the sample location
-- grid to select custom sample locations for.
[$sel:vkSampleLocationGridSize:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> VkExtent2D
-- | sampleLocationsCount is the number of sample locations in
-- pSampleLocations.
[$sel:vkSampleLocationsCount:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> Word32
-- | pSampleLocations is an array of sampleLocationsCount
-- VkSampleLocationEXT structures.
[$sel:vkPSampleLocations:VkSampleLocationsInfoEXT] :: VkSampleLocationsInfoEXT -> Ptr VkSampleLocationEXT
-- | VkAttachmentSampleLocationsEXT - Structure specifying the sample
-- locations state to use in the initial layout transition of attachments
--
-- Description
--
-- If the image referenced by the framebuffer attachment at index
-- attachmentIndex was not created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- then the values specified in sampleLocationsInfo are ignored.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sampleLocationsInfo must be a valid
-- VkSampleLocationsInfoEXT structure
--
--
-- See Also
--
-- VkRenderPassSampleLocationsBeginInfoEXT,
-- VkSampleLocationsInfoEXT
data VkAttachmentSampleLocationsEXT
VkAttachmentSampleLocationsEXT :: Word32 -> VkSampleLocationsInfoEXT -> VkAttachmentSampleLocationsEXT
-- | attachmentIndex is the index of the attachment for which the
-- sample locations state is provided.
[$sel:vkAttachmentIndex:VkAttachmentSampleLocationsEXT] :: VkAttachmentSampleLocationsEXT -> Word32
-- | sampleLocationsInfo is the sample locations state to use for
-- the layout transition of the given attachment from the initial layout
-- of the attachment to the image layout specified for the attachment in
-- the first subpass using it.
[$sel:vkSampleLocationsInfo:VkAttachmentSampleLocationsEXT] :: VkAttachmentSampleLocationsEXT -> VkSampleLocationsInfoEXT
-- | VkSubpassSampleLocationsEXT - Structure specifying the sample
-- locations state to use for layout transitions of attachments performed
-- after a given subpass
--
-- Description
--
-- If the image referenced by the depth/stencil attachment used in the
-- subpass identified by subpassIndex was not created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT or
-- if the subpass does not use a depth/stencil attachment, and
-- VkPhysicalDeviceSampleLocationsPropertiesEXT::variableSampleLocations
-- is VK_TRUE then the values specified in
-- sampleLocationsInfo are ignored.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sampleLocationsInfo must be a valid
-- VkSampleLocationsInfoEXT structure
--
--
-- See Also
--
-- VkRenderPassSampleLocationsBeginInfoEXT,
-- VkSampleLocationsInfoEXT
data VkSubpassSampleLocationsEXT
VkSubpassSampleLocationsEXT :: Word32 -> VkSampleLocationsInfoEXT -> VkSubpassSampleLocationsEXT
-- | subpassIndex is the index of the subpass for which the sample
-- locations state is provided.
[$sel:vkSubpassIndex:VkSubpassSampleLocationsEXT] :: VkSubpassSampleLocationsEXT -> Word32
-- | sampleLocationsInfo is the sample locations state to use for
-- the layout transition of the depth/stencil attachment away from the
-- image layout the attachment is used with in the subpass specified in
-- subpassIndex.
[$sel:vkSampleLocationsInfo:VkSubpassSampleLocationsEXT] :: VkSubpassSampleLocationsEXT -> VkSampleLocationsInfoEXT
-- | VkRenderPassSampleLocationsBeginInfoEXT - Structure specifying sample
-- locations to use for the layout transition of custom sample locations
-- compatible depth/stencil attachments
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_RENDER_PASS_SAMPLE_LOCATIONS_BEGIN_INFO_EXT
--
--
--
-- - If attachmentInitialSampleLocationsCount is not
-- 0, pAttachmentInitialSampleLocations must be
-- a valid pointer to an array of
-- attachmentInitialSampleLocationsCount valid
-- VkAttachmentSampleLocationsEXT structures
-- - If postSubpassSampleLocationsCount is not 0,
-- pPostSubpassSampleLocations must be a valid pointer to
-- an array of postSubpassSampleLocationsCount valid
-- VkSubpassSampleLocationsEXT structures
--
--
-- See Also
--
-- VkAttachmentSampleLocationsEXT, VkStructureType,
-- VkSubpassSampleLocationsEXT
data VkRenderPassSampleLocationsBeginInfoEXT
VkRenderPassSampleLocationsBeginInfoEXT :: VkStructureType -> Ptr () -> Word32 -> Ptr VkAttachmentSampleLocationsEXT -> Word32 -> Ptr VkSubpassSampleLocationsEXT -> VkRenderPassSampleLocationsBeginInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> Ptr ()
-- | attachmentInitialSampleLocationsCount is the number of
-- elements in the pAttachmentInitialSampleLocations array.
[$sel:vkAttachmentInitialSampleLocationsCount:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> Word32
-- | pAttachmentInitialSampleLocations is an array of
-- attachmentInitialSampleLocationsCount
-- VkAttachmentSampleLocationsEXT structures specifying the
-- attachment indices and their corresponding sample location state. Each
-- element of pAttachmentInitialSampleLocations can
-- specify the sample location state to use in the automatic layout
-- transition performed to transition a depth/stencil attachment from the
-- initial layout of the attachment to the image layout specified for the
-- attachment in the first subpass using it.
[$sel:vkPAttachmentInitialSampleLocations:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> Ptr VkAttachmentSampleLocationsEXT
-- | postSubpassSampleLocationsCount is the number of elements in
-- the pPostSubpassSampleLocations array.
[$sel:vkPostSubpassSampleLocationsCount:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> Word32
-- | pPostSubpassSampleLocations is an array of
-- postSubpassSampleLocationsCount
-- VkSubpassSampleLocationsEXT structures specifying the subpass
-- indices and their corresponding sample location state. Each element of
-- pPostSubpassSampleLocations can specify the sample
-- location state to use in the automatic layout transition performed to
-- transition the depth/stencil attachment used by the specified subpass
-- to the image layout specified in a dependent subpass or to the final
-- layout of the attachment in case the specified subpass is the last
-- subpass using that attachment. In addition, if
-- VkPhysicalDeviceSampleLocationsPropertiesEXT::variableSampleLocations
-- is VK_FALSE, each element of
-- pPostSubpassSampleLocations must specify the sample
-- location state that matches the sample locations used by all pipelines
-- that will be bound to a command buffer during the specified subpass.
-- If variableSampleLocations is VK_TRUE, the sample
-- locations used for rasterization do not depend on
-- pPostSubpassSampleLocations.
[$sel:vkPPostSubpassSampleLocations:VkRenderPassSampleLocationsBeginInfoEXT] :: VkRenderPassSampleLocationsBeginInfoEXT -> Ptr VkSubpassSampleLocationsEXT
-- | VkPipelineSampleLocationsStateCreateInfoEXT - Structure specifying
-- sample locations for a pipeline
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_SAMPLE_LOCATIONS_STATE_CREATE_INFO_EXT
--
--
--
-- - sampleLocationsInfo must be a valid
-- VkSampleLocationsInfoEXT structure
--
--
-- See Also
--
-- VkBool32, VkSampleLocationsInfoEXT,
-- VkStructureType
data VkPipelineSampleLocationsStateCreateInfoEXT
VkPipelineSampleLocationsStateCreateInfoEXT :: VkStructureType -> Ptr () -> VkBool32 -> VkSampleLocationsInfoEXT -> VkPipelineSampleLocationsStateCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineSampleLocationsStateCreateInfoEXT] :: VkPipelineSampleLocationsStateCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineSampleLocationsStateCreateInfoEXT] :: VkPipelineSampleLocationsStateCreateInfoEXT -> Ptr ()
-- | sampleLocationsEnable controls whether custom sample
-- locations are used. If sampleLocationsEnable is
-- VK_FALSE, the default sample locations are used and the
-- values specified in sampleLocationsInfo are ignored.
[$sel:vkSampleLocationsEnable:VkPipelineSampleLocationsStateCreateInfoEXT] :: VkPipelineSampleLocationsStateCreateInfoEXT -> VkBool32
-- | sampleLocationsInfo is the sample locations to use during
-- rasterization if sampleLocationsEnable is VK_TRUE
-- and the graphics pipeline isn’t created with
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT.
[$sel:vkSampleLocationsInfo:VkPipelineSampleLocationsStateCreateInfoEXT] :: VkPipelineSampleLocationsStateCreateInfoEXT -> VkSampleLocationsInfoEXT
-- | VkPhysicalDeviceSampleLocationsPropertiesEXT - Structure describing
-- sample location limits that can be supported by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceSampleLocationsPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - sampleLocationSampleCounts is a bitmask of
-- VkSampleCountFlagBits indicating the sample counts supporting
-- custom sample locations.
--
--
--
-- - maxSampleLocationGridSize is the maximum size of the
-- pixel grid in which sample locations can vary that is supported
-- for all sample counts in sampleLocationSampleCounts.
-- - sampleLocationCoordinateRange[2] is the range of
-- supported sample location coordinates.
-- - sampleLocationSubPixelBits is the number of bits of
-- subpixel precision for sample locations.
-- - variableSampleLocations specifies whether the sample
-- locations used by all pipelines that will be bound to a command buffer
-- during a subpass must match. If set to VK_TRUE, the
-- implementation supports variable sample locations in a subpass. If set
-- to VK_FALSE, then the sample locations must stay
-- constant in each subpass.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLE_LOCATIONS_PROPERTIES_EXT
--
--
-- If the VkPhysicalDeviceSampleLocationsPropertiesEXT structure
-- is included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkBool32, VkExtent2D, VkSampleCountFlags,
-- VkStructureType
data VkPhysicalDeviceSampleLocationsPropertiesEXT
VkPhysicalDeviceSampleLocationsPropertiesEXT :: VkStructureType -> Ptr () -> VkSampleCountFlags -> VkExtent2D -> Vector 2 CFloat -> Word32 -> VkBool32 -> VkPhysicalDeviceSampleLocationsPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> Ptr ()
[$sel:vkSampleLocationSampleCounts:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> VkSampleCountFlags
[$sel:vkMaxSampleLocationGridSize:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> VkExtent2D
[$sel:vkSampleLocationCoordinateRange:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> Vector 2 CFloat
[$sel:vkSampleLocationSubPixelBits:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> Word32
[$sel:vkVariableSampleLocations:VkPhysicalDeviceSampleLocationsPropertiesEXT] :: VkPhysicalDeviceSampleLocationsPropertiesEXT -> VkBool32
-- | VkMultisamplePropertiesEXT - Structure returning information about
-- sample count specific additional multisampling capabilities
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MULTISAMPLE_PROPERTIES_EXT
--
--
--
--
-- See Also
--
-- VkExtent2D, VkStructureType,
-- vkGetPhysicalDeviceMultisamplePropertiesEXT
data VkMultisamplePropertiesEXT
VkMultisamplePropertiesEXT :: VkStructureType -> Ptr () -> VkExtent2D -> VkMultisamplePropertiesEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkMultisamplePropertiesEXT] :: VkMultisamplePropertiesEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMultisamplePropertiesEXT] :: VkMultisamplePropertiesEXT -> Ptr ()
-- | maxSampleLocationGridSize is the maximum size of the pixel
-- grid in which sample locations can vary.
[$sel:vkMaxSampleLocationGridSize:VkMultisamplePropertiesEXT] :: VkMultisamplePropertiesEXT -> VkExtent2D
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkMultisamplePropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkMultisamplePropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPhysicalDeviceSampleLocationsPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPhysicalDeviceSampleLocationsPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPipelineSampleLocationsStateCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPipelineSampleLocationsStateCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkRenderPassSampleLocationsBeginInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkRenderPassSampleLocationsBeginInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSubpassSampleLocationsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSubpassSampleLocationsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkAttachmentSampleLocationsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkAttachmentSampleLocationsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationsInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationsInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkMultisamplePropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPhysicalDeviceSampleLocationsPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkPipelineSampleLocationsStateCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkRenderPassSampleLocationsBeginInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSubpassSampleLocationsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkAttachmentSampleLocationsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationsInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_sample_locations.VkSampleLocationEXT
module Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter
-- | VkSurfaceCounterFlagBitsEXT - Surface-relative counter types
--
-- See Also
--
-- VkSurfaceCounterFlagsEXT, vkGetSwapchainCounterEXT
newtype VkSurfaceCounterFlagBitsEXT
VkSurfaceCounterFlagBitsEXT :: VkFlags -> VkSurfaceCounterFlagBitsEXT
-- | VK_SURFACE_COUNTER_VBLANK_EXT specifies a counter
-- incrementing once every time a vertical blanking period occurs on the
-- display associated with the surface.
-- | vkGetPhysicalDeviceSurfaceCapabilities2EXT - Query surface
-- capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- associated with the swapchain to be created, as described for
-- vkCreateSwapchainKHR.
--
--
--
-- - surface is the surface that will be associated with the
-- swapchain.
-- - pSurfaceCapabilities is a pointer to an instance of the
-- VkSurfaceCapabilities2EXT structure in which the capabilities
-- are returned.
--
--
-- Description
--
-- vkGetPhysicalDeviceSurfaceCapabilities2EXT behaves similarly
-- to vkGetPhysicalDeviceSurfaceCapabilitiesKHR, with the ability
-- to return extended information by adding extension structures to the
-- pNext chain of its pSurfaceCapabilities parameter.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pSurfaceCapabilities must be a valid pointer to a
-- VkSurfaceCapabilities2EXT structure
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkSurfaceCapabilities2EXT,
-- VkSurfaceKHR
vkGetPhysicalDeviceSurfaceCapabilities2EXT :: ("physicalDevice" ::: VkPhysicalDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pSurfaceCapabilities" ::: Ptr VkSurfaceCapabilities2EXT) -> IO VkResult
-- | VkSurfaceCapabilities2EXT - Structure describing capabilities of a
-- surface
--
-- Members
--
-- All members of VkSurfaceCapabilities2EXT are identical to the
-- corresponding members of VkSurfaceCapabilitiesKHR where one
-- exists. The remaining members are:
--
-- Description
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - supportedSurfaceCounters is a bitmask of
-- VkSurfaceCounterFlagBitsEXT indicating the supported surface
-- counter types.
--
--
-- Valid Usage
--
--
-- - supportedSurfaceCounters must not include
-- VK_SURFACE_COUNTER_VBLANK_EXT unless the surface queried is a
-- display surface.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SURFACE_CAPABILITIES_2_EXT
--
--
--
--
-- See Also
--
-- VkCompositeAlphaFlagsKHR, VkExtent2D,
-- VkImageUsageFlags, VkStructureType,
-- VkSurfaceCounterFlagsEXT, VkSurfaceTransformFlagBitsKHR,
-- VkSurfaceTransformFlagsKHR,
-- vkGetPhysicalDeviceSurfaceCapabilities2EXT
data VkSurfaceCapabilities2EXT
VkSurfaceCapabilities2EXT :: VkStructureType -> Ptr () -> Word32 -> Word32 -> VkExtent2D -> VkExtent2D -> VkExtent2D -> Word32 -> VkSurfaceTransformFlagsKHR -> VkSurfaceTransformFlagBitsKHR -> VkCompositeAlphaFlagsKHR -> VkImageUsageFlags -> VkSurfaceCounterFlagsEXT -> VkSurfaceCapabilities2EXT
[$sel:vkSType:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkStructureType
[$sel:vkPNext:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> Ptr ()
[$sel:vkMinImageCount:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> Word32
[$sel:vkMaxImageCount:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> Word32
[$sel:vkCurrentExtent:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkExtent2D
[$sel:vkMinImageExtent:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkExtent2D
[$sel:vkMaxImageExtent:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkExtent2D
[$sel:vkMaxImageArrayLayers:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> Word32
[$sel:vkSupportedTransforms:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkSurfaceTransformFlagsKHR
[$sel:vkCurrentTransform:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkSurfaceTransformFlagBitsKHR
[$sel:vkSupportedCompositeAlpha:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkCompositeAlphaFlagsKHR
[$sel:vkSupportedUsageFlags:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkImageUsageFlags
[$sel:vkSupportedSurfaceCounters:VkSurfaceCapabilities2EXT] :: VkSurfaceCapabilities2EXT -> VkSurfaceCounterFlagsEXT
-- | VkSurfaceCounterFlagsEXT - Bitmask of VkSurfaceCounterFlagBitsEXT
--
-- Description
--
-- VkSurfaceCounterFlagsEXT is a bitmask type for setting a mask
-- of zero or more VkSurfaceCounterFlagBitsEXT.
--
-- See Also
--
-- VkSurfaceCapabilities2EXT, VkSurfaceCounterFlagBitsEXT,
-- VkSwapchainCounterCreateInfoEXT
type VkSurfaceCounterFlagsEXT = VkSurfaceCounterFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCapabilities2EXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCapabilities2EXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCapabilities2EXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_display_surface_counter.VkSurfaceCounterFlagBitsEXT
module Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles
-- | VkDiscardRectangleModeEXT - Specify the discard rectangle mode
--
-- See Also
--
-- VkPipelineDiscardRectangleStateCreateInfoEXT
newtype VkDiscardRectangleModeEXT
VkDiscardRectangleModeEXT :: Int32 -> VkDiscardRectangleModeEXT
-- | VK_DISCARD_RECTANGLE_MODE_INCLUSIVE_EXT specifies that a
-- fragment within any discard rectangle satisfies the test.
-- | VK_DISCARD_RECTANGLE_MODE_EXCLUSIVE_EXT specifies that a
-- fragment not within any of the discard rectangles satisfies the test.
-- | VkPipelineDiscardRectangleStateCreateFlagsEXT - Reserved for future
-- use
--
-- Description
--
-- VkPipelineDiscardRectangleStateCreateFlagsEXT is a bitmask
-- type for setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineDiscardRectangleStateCreateInfoEXT
newtype VkPipelineDiscardRectangleStateCreateFlagsEXT
VkPipelineDiscardRectangleStateCreateFlagsEXT :: VkFlags -> VkPipelineDiscardRectangleStateCreateFlagsEXT
-- | vkCmdSetDiscardRectangleEXT - Set discard rectangles dynamically
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - firstDiscardRectangle is the index of the first discard
-- rectangle whose state is updated by the command.
-- - discardRectangleCount is the number of discard rectangles
-- whose state are updated by the command.
-- - pDiscardRectangles is a pointer to an array of
-- VkRect2D structures specifying discard rectangles.
--
--
-- Description
--
-- The discard rectangle taken from element i of
-- pDiscardRectangles replace the current state for the discard
-- rectangle index firstDiscardRectangle + i, for i in [0,
-- discardRectangleCount).
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_DISCARD_RECTANGLE_EXT dynamic state
-- enabled
--
--
--
-- - The sum of firstDiscardRectangle and
-- discardRectangleCount must be less than or equal to
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT::maxDiscardRectangles
-- - The x and y member of offset in each
-- VkRect2D element of pDiscardRectangles must be
-- greater than or equal to 0
-- - Evaluation of (offset.x + extent.width) in each
-- VkRect2D element of pDiscardRectangles must not
-- cause a signed integer addition overflow
-- - Evaluation of (offset.y + extent.height) in each
-- VkRect2D element of pDiscardRectangles must not
-- cause a signed integer addition overflow
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pDiscardRectangles must be a valid pointer to an
-- array of discardRectangleCount VkRect2D
-- structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - discardRectangleCount must be greater than
-- 0
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkRect2D
vkCmdSetDiscardRectangleEXT :: ("commandBuffer" ::: VkCommandBuffer) -> ("firstDiscardRectangle" ::: Word32) -> ("discardRectangleCount" ::: Word32) -> ("pDiscardRectangles" ::: Ptr VkRect2D) -> IO ()
-- | VkPhysicalDeviceDiscardRectanglePropertiesEXT - Structure describing
-- discard rectangle limits that can be supported by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxDiscardRectangles is the maximum number of discard
-- rectangles that can be specified.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DISCARD_RECTANGLE_PROPERTIES_EXT
--
--
-- If the VkPhysicalDeviceDiscardRectanglePropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkStructureType
data VkPhysicalDeviceDiscardRectanglePropertiesEXT
VkPhysicalDeviceDiscardRectanglePropertiesEXT :: VkStructureType -> Ptr () -> Word32 -> VkPhysicalDeviceDiscardRectanglePropertiesEXT
[$sel:vkSType:VkPhysicalDeviceDiscardRectanglePropertiesEXT] :: VkPhysicalDeviceDiscardRectanglePropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceDiscardRectanglePropertiesEXT] :: VkPhysicalDeviceDiscardRectanglePropertiesEXT -> Ptr ()
[$sel:vkMaxDiscardRectangles:VkPhysicalDeviceDiscardRectanglePropertiesEXT] :: VkPhysicalDeviceDiscardRectanglePropertiesEXT -> Word32
-- | VkPipelineDiscardRectangleStateCreateInfoEXT - Structure specifying
-- discard rectangle
--
-- Description
--
-- Valid Usage
--
--
-- - discardRectangleCount must be between 0
-- and
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT::maxDiscardRectangles,
-- inclusive
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_DISCARD_RECTANGLE_STATE_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkDiscardRectangleModeEXT,
-- VkPipelineDiscardRectangleStateCreateFlagsEXT, VkRect2D,
-- VkStructureType
data VkPipelineDiscardRectangleStateCreateInfoEXT
VkPipelineDiscardRectangleStateCreateInfoEXT :: VkStructureType -> Ptr () -> VkPipelineDiscardRectangleStateCreateFlagsEXT -> VkDiscardRectangleModeEXT -> Word32 -> Ptr VkRect2D -> VkPipelineDiscardRectangleStateCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> VkPipelineDiscardRectangleStateCreateFlagsEXT
-- | discardRectangleMode is the mode used to determine whether
-- fragments that lie within the discard rectangle are discarded or not.
[$sel:vkDiscardRectangleMode:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> VkDiscardRectangleModeEXT
-- | discardRectangleCount is the number of discard rectangles
-- used by the pipeline.
[$sel:vkDiscardRectangleCount:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> Word32
-- | pDiscardRectangles is a pointer to an array of
-- VkRect2D structures, defining the discard rectangles. If the
-- discard rectangle state is dynamic, this member is ignored.
[$sel:vkPDiscardRectangles:VkPipelineDiscardRectangleStateCreateInfoEXT] :: VkPipelineDiscardRectangleStateCreateInfoEXT -> Ptr VkRect2D
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPhysicalDeviceDiscardRectanglePropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPhysicalDeviceDiscardRectanglePropertiesEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkDiscardRectangleModeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkDiscardRectangleModeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkDiscardRectangleModeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPhysicalDeviceDiscardRectanglePropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkPipelineDiscardRectangleStateCreateFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkDiscardRectangleModeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_discard_rectangles.VkDiscardRectangleModeEXT
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2
-- | VkBindBufferMemoryDeviceGroupInfo - Structure specifying device within
-- a group to bind to
--
-- Members
--
-- If the pNext list of VkBindBufferMemoryInfo includes a
-- VkBindBufferMemoryDeviceGroupInfo structure, then that
-- structure determines how memory is bound to buffers across multiple
-- devices in a device group.
--
-- Description
--
-- The VkBindBufferMemoryDeviceGroupInfo structure is defined
-- as:
--
--
-- - sType is the type of this structure.
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - deviceIndexCount is the number of elements in
-- pDeviceIndices.
-- - pDeviceIndices is a pointer to an array of device
-- indices.
--
--
-- If deviceIndexCount is greater than zero, then on device
-- index i the buffer is attached to the instance of memory on
-- the physical device with device index pDeviceIndices[i].
--
-- If deviceIndexCount is zero and memory comes from a
-- memory heap with the VK_MEMORY_HEAP_MULTI_INSTANCE_BIT bit
-- set, then it is as if pDeviceIndices contains consecutive
-- indices from zero to the number of physical devices in the logical
-- device, minus one. In other words, by default each physical device
-- attaches to its own instance of memory.
--
-- If deviceIndexCount is zero and memory comes from a
-- memory heap without the VK_MEMORY_HEAP_MULTI_INSTANCE_BIT bit
-- set, then it is as if pDeviceIndices contains an array of
-- zeros. In other words, by default each physical device attaches to
-- instance zero.
--
-- Valid Usage
--
--
-- - deviceIndexCount must either be zero or equal to
-- the number of physical devices in the logical device
--
--
--
-- - All elements of pDeviceIndices must be valid
-- device indices
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_DEVICE_GROUP_INFO
--
--
--
-- - If deviceIndexCount is not 0,
-- pDeviceIndices must be a valid pointer to an array of
-- deviceIndexCount uint32_t values
--
--
-- See Also
--
-- VkStructureType
data VkBindBufferMemoryDeviceGroupInfo
VkBindBufferMemoryDeviceGroupInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> VkBindBufferMemoryDeviceGroupInfo
[$sel:vkSType:VkBindBufferMemoryDeviceGroupInfo] :: VkBindBufferMemoryDeviceGroupInfo -> VkStructureType
[$sel:vkPNext:VkBindBufferMemoryDeviceGroupInfo] :: VkBindBufferMemoryDeviceGroupInfo -> Ptr ()
[$sel:vkDeviceIndexCount:VkBindBufferMemoryDeviceGroupInfo] :: VkBindBufferMemoryDeviceGroupInfo -> Word32
[$sel:vkPDeviceIndices:VkBindBufferMemoryDeviceGroupInfo] :: VkBindBufferMemoryDeviceGroupInfo -> Ptr Word32
-- | VkBindImageMemoryDeviceGroupInfo - Structure specifying device within
-- a group to bind to
--
-- Members
--
-- If the pNext list of VkBindImageMemoryInfo includes a
-- VkBindImageMemoryDeviceGroupInfo structure, then that
-- structure determines how memory is bound to images across multiple
-- devices in a device group.
--
-- Description
--
-- The VkBindImageMemoryDeviceGroupInfo structure is defined as:
--
--
-- - sType is the type of this structure.
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - deviceIndexCount is the number of elements in
-- pDeviceIndices.
-- - pDeviceIndices is a pointer to an array of device
-- indices.
-- - splitInstanceBindRegionCount is the number of elements in
-- pSplitInstanceBindRegions.
-- - pSplitInstanceBindRegions is a pointer to an array of
-- rectangles describing which regions of the image are attached to each
-- instance of memory.
--
--
-- If deviceIndexCount is greater than zero, then on device
-- index i image is attached to the instance of the memory on
-- the physical device with device index pDeviceIndices[i].
--
-- Let N be the number of physical devices in the logical device. If
-- splitInstanceBindRegionCount is greater than zero, then
-- pSplitInstanceBindRegions is an array of N2 rectangles, where
-- the image region specified by the rectangle at element i*N+j in
-- resource instance i is bound to the memory instance j. The blocks of
-- the memory that are bound to each sparse image block region use an
-- offset in memory, relative to memoryOffset, computed as if
-- the whole image were being bound to a contiguous range of memory. In
-- other words, horizontally adjacent image blocks use consecutive blocks
-- of memory, vertically adjacent image blocks are separated by the
-- number of bytes per block multiplied by the width in blocks of
-- image, and the block at (0,0) corresponds to memory starting
-- at memoryOffset.
--
-- If splitInstanceBindRegionCount and deviceIndexCount
-- are zero and the memory comes from a memory heap with the
-- VK_MEMORY_HEAP_MULTI_INSTANCE_BIT bit set, then it is as if
-- pDeviceIndices contains consecutive indices from zero to the
-- number of physical devices in the logical device, minus one. In other
-- words, by default each physical device attaches to its own instance of
-- the memory.
--
-- If splitInstanceBindRegionCount and deviceIndexCount
-- are zero and the memory comes from a memory heap without the
-- VK_MEMORY_HEAP_MULTI_INSTANCE_BIT bit set, then it is as if
-- pDeviceIndices contains an array of zeros. In other words, by
-- default each physical device attaches to instance zero.
--
-- Valid Usage
--
--
-- - At least one of deviceIndexCount and
-- splitInstanceBindRegionCount must be zero.
--
--
--
-- - deviceIndexCount must either be zero or equal to
-- the number of physical devices in the logical device
-- - All elements of pDeviceIndices must be valid
-- device indices.
-- - splitInstanceBindRegionCount must either be zero
-- or equal to the number of physical devices in the logical device
-- squared
-- - Elements of pSplitInstanceBindRegions that correspond to
-- the same instance of an image must not overlap.
-- - The offset.x member of any element of
-- pSplitInstanceBindRegions must be a multiple of the
-- sparse image block width
-- (VkSparseImageFormatProperties::imageGranularity.width)
-- of all non-metadata aspects of the image
-- - The offset.y member of any element of
-- pSplitInstanceBindRegions must be a multiple of the
-- sparse image block height
-- (VkSparseImageFormatProperties::imageGranularity.height)
-- of all non-metadata aspects of the image
-- - The extent.width member of any element of
-- pSplitInstanceBindRegions must either be a multiple of
-- the sparse image block width of all non-metadata aspects of the image,
-- or else extent.width + offset.x must equal
-- the width of the image subresource
-- - The extent.height member of any element of
-- pSplitInstanceBindRegions must either be a multiple of
-- the sparse image block height of all non-metadata aspects of the
-- image, or else extent.height offset.y must
-- equal the width of the image subresource
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_DEVICE_GROUP_INFO
--
--
--
-- - If deviceIndexCount is not 0,
-- pDeviceIndices must be a valid pointer to an array of
-- deviceIndexCount uint32_t values
-- - If splitInstanceBindRegionCount is not 0,
-- pSplitInstanceBindRegions must be a valid pointer to
-- an array of splitInstanceBindRegionCount VkRect2D
-- structures
--
--
-- See Also
--
-- VkRect2D, VkStructureType
data VkBindImageMemoryDeviceGroupInfo
VkBindImageMemoryDeviceGroupInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> Word32 -> Ptr VkRect2D -> VkBindImageMemoryDeviceGroupInfo
[$sel:vkSType:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> VkStructureType
[$sel:vkPNext:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> Ptr ()
[$sel:vkDeviceIndexCount:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> Word32
[$sel:vkPDeviceIndices:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> Ptr Word32
[$sel:vkSplitInstanceBindRegionCount:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> Word32
[$sel:vkPSplitInstanceBindRegions:VkBindImageMemoryDeviceGroupInfo] :: VkBindImageMemoryDeviceGroupInfo -> Ptr VkRect2D
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindImageMemoryDeviceGroupInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindImageMemoryDeviceGroupInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindBufferMemoryDeviceGroupInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindBufferMemoryDeviceGroupInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindImageMemoryDeviceGroupInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group_and_VK_KHR_bind_memory2.VkBindBufferMemoryDeviceGroupInfo
module Graphics.Vulkan.Core10.Sampler
-- | VkBorderColor - Specify border color used for texture lookups
--
-- Description
--
--
-- - VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK specifies a
-- transparent, floating-point format, black color.
--
--
--
-- - VK_BORDER_COLOR_INT_TRANSPARENT_BLACK specifies a
-- transparent, integer format, black color.
-- - VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK specifies an opaque,
-- floating-point format, black color.
-- - VK_BORDER_COLOR_INT_OPAQUE_BLACK specifies an opaque,
-- integer format, black color.
-- - VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE specifies an opaque,
-- floating-point format, white color.
-- - VK_BORDER_COLOR_INT_OPAQUE_WHITE specifies an opaque,
-- integer format, white color.
--
--
-- These colors are described in detail in Texel Replacement.
--
-- See Also
--
-- VkSamplerCreateInfo
newtype VkBorderColor
VkBorderColor :: Int32 -> VkBorderColor
-- | VkSamplerAddressMode - Specify behavior of sampling with texture
-- coordinates outside an image
--
-- See Also
--
-- VkSamplerCreateInfo
newtype VkSamplerAddressMode
VkSamplerAddressMode :: Int32 -> VkSamplerAddressMode
-- | VK_SAMPLER_ADDRESS_MODE_REPEAT specifies that the repeat wrap
-- mode will be used.
-- | VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT specifies that the
-- mirrored repeat wrap mode will be used.
-- | VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE specifies that the
-- clamp to edge wrap mode will be used.
-- | VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER specifies that the
-- clamp to border wrap mode will be used.
-- | VkFilter - Specify filters used for texture lookups
--
-- Description
--
--
-- - VK_FILTER_NEAREST specifies nearest filtering.
--
--
--
-- - VK_FILTER_LINEAR specifies linear filtering.
-- - VK_FILTER_CUBIC_IMG specifies cubic filtering.
--
--
-- These filters are described in detail in Texel Filtering.
--
-- See Also
--
-- VkSamplerCreateInfo, VkSamplerYcbcrConversionCreateInfo,
-- vkCmdBlitImage
newtype VkFilter
VkFilter :: Int32 -> VkFilter
-- | VkSamplerMipmapMode - Specify mipmap mode used for texture lookups
--
-- Description
--
--
-- - VK_SAMPLER_MIPMAP_MODE_NEAREST specifies nearest
-- filtering.
--
--
--
-- - VK_SAMPLER_MIPMAP_MODE_LINEAR specifies linear
-- filtering.
--
--
-- These modes are described in detail in Texel Filtering.
--
-- See Also
--
-- VkSamplerCreateInfo
newtype VkSamplerMipmapMode
VkSamplerMipmapMode :: Int32 -> VkSamplerMipmapMode
-- | VkSamplerCreateFlags - Reserved for future use
--
-- Description
--
-- VkSamplerCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkSamplerCreateInfo
newtype VkSamplerCreateFlags
VkSamplerCreateFlags :: VkFlags -> VkSamplerCreateFlags
-- | VkSampler - Opaque handle to a sampler object
--
-- Description
--
-- See Also
--
-- VkDescriptorImageInfo, VkDescriptorSetLayoutBinding,
-- vkCreateSampler, vkDestroySampler
type VkSampler = Ptr VkSampler_T
-- | vkCreateSampler - Create a new sampler object
--
-- Parameters
--
--
-- - device is the logical device that creates the
-- sampler.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkSamplerCreateInfo structure specifying the state of the
-- sampler object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pSampler points to a VkSampler handle in which the
-- resulting sampler object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkSamplerCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSampler must be a valid pointer to a
-- VkSampler handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkSampler,
-- VkSamplerCreateInfo
vkCreateSampler :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkSamplerCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSampler" ::: Ptr VkSampler) -> IO VkResult
-- | vkDestroySampler - Destroy a sampler object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- sampler.
--
--
--
-- - sampler is the sampler to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to sampler must
-- have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- sampler was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- sampler was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If sampler is not VK_NULL_HANDLE, sampler
-- must be a valid VkSampler handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If sampler is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to sampler must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkSampler
vkDestroySampler :: ("device" ::: VkDevice) -> ("sampler" ::: VkSampler) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkSamplerCreateInfo - Structure specifying parameters of a newly
-- created sampler
--
-- Members
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - flags is reserved for future use.
-- - magFilter is a VkFilter value specifying the
-- magnification filter to apply to lookups.
-- - minFilter is a VkFilter value specifying the
-- minification filter to apply to lookups.
-- - mipmapMode is a VkSamplerMipmapMode value
-- specifying the mipmap filter to apply to lookups.
-- - addressModeU is a VkSamplerAddressMode value
-- specifying the addressing mode for outside [0..1] range for U
-- coordinate.
-- - addressModeV is a VkSamplerAddressMode value
-- specifying the addressing mode for outside [0..1] range for V
-- coordinate.
-- - addressModeW is a VkSamplerAddressMode value
-- specifying the addressing mode for outside [0..1] range for W
-- coordinate.
-- - mipLodBias is the bias to be added to mipmap LOD
-- (level-of-detail) calculation and bias provided by image sampling
-- functions in SPIR-V, as described in the Level-of-Detail
-- Operation section.
-- - anisotropyEnable is VK_TRUE to enable
-- anisotropic filtering, as described in the Texel Anisotropic
-- Filtering section, or VK_FALSE otherwise.
-- - maxAnisotropy is the anisotropy value clamp used by the
-- sampler when anisotropyEnable is VK_TRUE. If
-- anisotropyEnable is VK_FALSE, maxAnisotropy
-- is ignored.
-- - compareEnable is VK_TRUE to enable comparison
-- against a reference value during lookups, or VK_FALSE
-- otherwise.
- Note: Some implementations will default to shader
-- state if this member does not match.
-- - compareOp is a VkCompareOp value specifying the
-- comparison function to apply to fetched data before filtering as
-- described in the Depth Compare Operation section.
-- - minLod and maxLod are the values used to clamp
-- the computed LOD value, as described in the Level-of-Detail
-- Operation section. maxLod must be greater than or
-- equal to minLod.
-- - borderColor is a VkBorderColor value specifying
-- the predefined border color to use.
-- - unnormalizedCoordinates controls whether to use
-- unnormalized or normalized texel coordinates to address texels of the
-- image. When set to VK_TRUE, the range of the image
-- coordinates used to lookup the texel is in the range of zero to the
-- image dimensions for x, y and z. When set to VK_FALSE the
-- range of image coordinates is zero to one. When
-- unnormalizedCoordinates is VK_TRUE, samplers have
-- the following requirements:
- minFilter and
-- magFilter must be equal.
- mipmapMode
-- must be
-- VK_SAMPLER_MIPMAP_MODE_NEAREST.
- minLod and
-- maxLod must be zero.
- addressModeU and
-- addressModeV must each be either
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE or
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER.
- anisotropyEnable
-- must be VK_FALSE.
- compareEnable
-- must be VK_FALSE.
- The sampler must not
-- enable sampler Y’CBCR conversion.
-- - When unnormalizedCoordinates is VK_TRUE, images
-- the sampler is used with in the shader have the following
-- requirements:
- The viewType must be either
-- VK_IMAGE_VIEW_TYPE_1D or
-- VK_IMAGE_VIEW_TYPE_2D.
- The image view must
-- have a single layer and a single mip level.
-- - When unnormalizedCoordinates is VK_TRUE, image
-- built-in functions in the shader that use the sampler have the
-- following requirements:
- The functions must not use
-- projection.
- The functions must not use
-- offsets.
--
--
-- Description
--
-- Note
--
-- magFilter values of VK_FILTER_NEAREST and
-- VK_FILTER_LINEAR directly correspond to GL_NEAREST
-- and GL_LINEAR magnification filters. minFilter and
-- mipmapMode combine to correspond to the similarly named
-- OpenGL minification filter of GL_minFilter_MIPMAP_mipmapMode
-- (e.g. minFilter of VK_FILTER_LINEAR and
-- mipmapMode of VK_SAMPLER_MIPMAP_MODE_NEAREST
-- correspond to GL_LINEAR_MIPMAP_NEAREST).
--
-- There are no Vulkan filter modes that directly correspond to OpenGL
-- minification filters of GL_LINEAR or GL_NEAREST, but
-- they can be emulated using
-- VK_SAMPLER_MIPMAP_MODE_NEAREST, minLod = 0, and
-- maxLod = 0.25, and using minFilter =
-- VK_FILTER_LINEAR or minFilter =
-- VK_FILTER_NEAREST, respectively.
--
-- Note that using a maxLod of zero would cause
-- magnification to always be performed, and the
-- magFilter to always be used. This is valid, just not an exact
-- match for OpenGL behavior. Clamping the maximum LOD to 0.25 allows the
-- λ value to be non-zero and minification to be performed, while still
-- always rounding down to the base level. If the minFilter and
-- magFilter are equal, then using a maxLod of zero
-- also works.
--
-- The maximum number of sampler objects which can be
-- simultaneously created on a device is implementation-dependent and
-- specified by the maxSamplerAllocationCount member of the
-- VkPhysicalDeviceLimits structure. If
-- maxSamplerAllocationCount is exceeded,
-- vkCreateSampler will return
-- VK_ERROR_TOO_MANY_OBJECTS.
--
-- Since VkSampler is a non-dispatchable handle type,
-- implementations may return the same handle for sampler state
-- vectors that are identical. In such cases, all such objects would only
-- count once against the maxSamplerAllocationCount limit.
--
-- Valid Usage
--
--
-- - The absolute value of mipLodBias must be less than
-- or equal to
-- VkPhysicalDeviceLimits::maxSamplerLodBias
--
--
--
-- - If the anisotropic sampling feature is not enabled,
-- anisotropyEnable must be VK_FALSE
-- - If anisotropyEnable is VK_TRUE,
-- maxAnisotropy must be between 1.0 and
-- VkPhysicalDeviceLimits::maxSamplerAnisotropy,
-- inclusive
-- - If sampler Y’CBCR conversion is enabled and
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_SEPARATE_RECONSTRUCTION_FILTER_BIT
-- is not set for the format, minFilter and magFilter
-- must be equal to the sampler Y’CBCR conversion’s
-- chromaFilter
-- - If unnormalizedCoordinates is VK_TRUE,
-- minFilter and magFilter must be equal
-- - If unnormalizedCoordinates is VK_TRUE,
-- mipmapMode must be
-- VK_SAMPLER_MIPMAP_MODE_NEAREST
-- - If unnormalizedCoordinates is VK_TRUE,
-- minLod and maxLod must be zero
-- - If unnormalizedCoordinates is VK_TRUE,
-- addressModeU and addressModeV must each be
-- either VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE or
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER
-- - If unnormalizedCoordinates is VK_TRUE,
-- anisotropyEnable must be VK_FALSE
-- - If unnormalizedCoordinates is VK_TRUE,
-- compareEnable must be VK_FALSE
-- - If any of addressModeU, addressModeV or
-- addressModeW are
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER, borderColor
-- must be a valid VkBorderColor value
-- - If sampler Y’CBCR conversion is enabled,
-- addressModeU, addressModeV, and
-- addressModeW must be
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE,
-- anisotropyEnable must be VK_FALSE, and
-- unnormalizedCoordinates must be VK_FALSE
-- - The sampler reduction mode must be set to
-- VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT if sampler
-- Y’CBCR conversion is enabled
-- - If the
-- {html_spec_relative}#VK_KHR_sampler_mirror_clamp_to_edge
-- extension is not enabled, addressModeU, addressModeV
-- and addressModeW must not be
-- VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE
-- - If compareEnable is VK_TRUE, compareOp
-- must be a valid VkCompareOp value
-- - If either magFilter or minFilter is
-- VK_FILTER_CUBIC_IMG, anisotropyEnable must be
-- VK_FALSE
-- - If either magFilter or minFilter is
-- VK_FILTER_CUBIC_IMG, the reductionMode member of
-- VkSamplerReductionModeCreateInfoEXT must be
-- VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT
-- - If compareEnable is VK_TRUE, the
-- reductionMode member of
-- VkSamplerReductionModeCreateInfoEXT must be
-- VK_SAMPLER_REDUCTION_MODE_WEIGHTED_AVERAGE_EXT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkBool32, VkBorderColor, VkCompareOp,
-- VkFilter, VkSamplerAddressMode,
-- VkSamplerCreateFlags, VkSamplerMipmapMode,
-- VkStructureType, vkCreateSampler
data VkSamplerCreateInfo
VkSamplerCreateInfo :: VkStructureType -> Ptr () -> VkSamplerCreateFlags -> VkFilter -> VkFilter -> VkSamplerMipmapMode -> VkSamplerAddressMode -> VkSamplerAddressMode -> VkSamplerAddressMode -> CFloat -> VkBool32 -> CFloat -> VkBool32 -> VkCompareOp -> CFloat -> CFloat -> VkBorderColor -> VkBool32 -> VkSamplerCreateInfo
[$sel:vkSType:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkStructureType
[$sel:vkPNext:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> Ptr ()
[$sel:vkFlags:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkSamplerCreateFlags
[$sel:vkMagFilter:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkFilter
[$sel:vkMinFilter:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkFilter
[$sel:vkMipmapMode:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkSamplerMipmapMode
[$sel:vkAddressModeU:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkSamplerAddressMode
[$sel:vkAddressModeV:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkSamplerAddressMode
[$sel:vkAddressModeW:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkSamplerAddressMode
[$sel:vkMipLodBias:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> CFloat
[$sel:vkAnisotropyEnable:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkBool32
[$sel:vkMaxAnisotropy:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> CFloat
[$sel:vkCompareEnable:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkBool32
[$sel:vkCompareOp:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkCompareOp
[$sel:vkMinLod:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> CFloat
[$sel:vkMaxLod:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> CFloat
[$sel:vkBorderColor:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkBorderColor
[$sel:vkUnnormalizedCoordinates:VkSamplerCreateInfo] :: VkSamplerCreateInfo -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkSamplerCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkSamplerCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkSamplerMipmapMode
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Sampler.VkSamplerMipmapMode
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkSamplerMipmapMode
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkFilter
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Sampler.VkFilter
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkFilter
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkSamplerAddressMode
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Sampler.VkSamplerAddressMode
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkSamplerAddressMode
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkBorderColor
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Sampler.VkBorderColor
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Sampler.VkBorderColor
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Sampler.VkSamplerCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Sampler.VkSamplerCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkSamplerMipmapMode
instance GHC.Read.Read Graphics.Vulkan.Core10.Sampler.VkSamplerMipmapMode
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkFilter
instance GHC.Read.Read Graphics.Vulkan.Core10.Sampler.VkFilter
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkSamplerAddressMode
instance GHC.Read.Read Graphics.Vulkan.Core10.Sampler.VkSamplerAddressMode
instance GHC.Show.Show Graphics.Vulkan.Core10.Sampler.VkBorderColor
instance GHC.Read.Read Graphics.Vulkan.Core10.Sampler.VkBorderColor
module Graphics.Vulkan.Extensions.VK_KHR_sampler_mirror_clamp_to_edge
-- | VK_SAMPLER_ADDRESS_MODE_MIRROR_CLAMP_TO_EDGE specifies that
-- the mirror clamp to edge wrap mode will be used. This is only valid if
-- the {html_spec_relative}#VK_KHR_sampler_mirror_clamp_to_edge
-- extension is enabled.
module Graphics.Vulkan.Extensions.VK_IMG_filter_cubic
module Graphics.Vulkan.Core10.PipelineLayout
-- | VkPipelineLayoutCreateFlags - Reserved for future use
--
-- Description
--
-- VkPipelineLayoutCreateFlags is a bitmask type for setting a
-- mask, but is currently reserved for future use.
--
-- See Also
--
-- VkPipelineLayoutCreateInfo
newtype VkPipelineLayoutCreateFlags
VkPipelineLayoutCreateFlags :: VkFlags -> VkPipelineLayoutCreateFlags
-- | VkDescriptorSetLayout - Opaque handle to a descriptor set layout
-- object
--
-- Description
--
-- See Also
--
-- VkDescriptorSetAllocateInfo,
-- VkDescriptorUpdateTemplateCreateInfo,
-- VkPipelineLayoutCreateInfo, vkCreateDescriptorSetLayout,
-- vkDestroyDescriptorSetLayout
type VkDescriptorSetLayout = Ptr VkDescriptorSetLayout_T
-- | vkCreatePipelineLayout - Creates a new pipeline layout object
--
-- Parameters
--
--
-- - device is the logical device that creates the pipeline
-- layout.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkPipelineLayoutCreateInfo structure specifying the state of
-- the pipeline layout object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pPipelineLayout points to a VkPipelineLayout
-- handle in which the resulting pipeline layout object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkPipelineLayoutCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pPipelineLayout must be a valid pointer to a
-- VkPipelineLayout handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkPipelineLayout, VkPipelineLayoutCreateInfo
vkCreatePipelineLayout :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkPipelineLayoutCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pPipelineLayout" ::: Ptr VkPipelineLayout) -> IO VkResult
-- | vkDestroyPipelineLayout - Destroy a pipeline layout object
--
-- Parameters
--
--
-- - device is the logical device that destroys the pipeline
-- layout.
--
--
--
-- - pipelineLayout is the pipeline layout to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- pipelineLayout was created, a compatible set of callbacks
-- must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- pipelineLayout was created, pAllocator must
-- be NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If pipelineLayout is not VK_NULL_HANDLE,
-- pipelineLayout must be a valid
-- VkPipelineLayout handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If pipelineLayout is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to pipelineLayout must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkPipelineLayout
vkDestroyPipelineLayout :: ("device" ::: VkDevice) -> ("pipelineLayout" ::: VkPipelineLayout) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkPushConstantRange - Structure specifying a push constant range
--
-- Description
--
-- Valid Usage
--
--
-- - offset must be less than
-- VkPhysicalDeviceLimits::maxPushConstantsSize
--
--
--
-- - offset must be a multiple of 4
-- - size must be greater than 0
-- - size must be a multiple of 4
-- - size must be less than or equal to
-- VkPhysicalDeviceLimits::maxPushConstantsSize minus
-- offset
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - stageFlags must not be 0
--
--
-- See Also
--
-- VkPipelineLayoutCreateInfo, VkShaderStageFlags
data VkPushConstantRange
VkPushConstantRange :: VkShaderStageFlags -> Word32 -> Word32 -> VkPushConstantRange
-- | stageFlags is a set of stage flags describing the shader
-- stages that will access a range of push constants. If a particular
-- stage is not included in the range, then accessing members of that
-- range of push constants from the corresponding shader stage will
-- result in undefined data being read.
[$sel:vkStageFlags:VkPushConstantRange] :: VkPushConstantRange -> VkShaderStageFlags
-- | offset and size are the start offset and size,
-- respectively, consumed by the range. Both offset and
-- size are in units of bytes and must be a multiple of
-- 4. The layout of the push constant variables is specified in the
-- shader.
[$sel:vkOffset:VkPushConstantRange] :: VkPushConstantRange -> Word32
[$sel:vkSize:VkPushConstantRange] :: VkPushConstantRange -> Word32
-- | VkPipelineLayoutCreateInfo - Structure specifying the parameters of a
-- newly created pipeline layout object
--
-- Members
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - flags is reserved for future use.
-- - setLayoutCount is the number of descriptor sets included
-- in the pipeline layout.
-- - pSetLayouts is a pointer to an array of
-- VkDescriptorSetLayout objects.
-- - pushConstantRangeCount is the number of push constant
-- ranges included in the pipeline layout.
-- - pPushConstantRanges is a pointer to an array of
-- VkPushConstantRange structures defining a set of push
-- constant ranges for use in a single pipeline layout. In addition to
-- descriptor set layouts, a pipeline layout also describes how many push
-- constants can be accessed by each stage of the
-- pipeline.NotePush constants represent a high speed path to
-- modify constant data in pipelines that is expected to outperform
-- memory-backed resource updates.
--
--
-- Description
--
-- Valid Usage
--
--
-- - setLayoutCount must be less than or equal to
-- VkPhysicalDeviceLimits::maxBoundDescriptorSets
--
--
--
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_SAMPLER and
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorSamplers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER and
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorUniformBuffers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER and
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorStorageBuffers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, and
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorSampledImages
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, and
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorStorageImages
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT accessible to any given
-- shader stage across all elements of pSetLayouts must
-- be less than or equal to
-- VkPhysicalDeviceLimits::maxPerStageDescriptorInputAttachments
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_SAMPLER and
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindSamplers
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER and
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindUniformBuffers
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER and
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindStorageBuffers
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, and
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindSampledImages
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, and
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER accessible to any
-- given shader stage across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindStorageImages
-- - The total number of descriptors with a descriptorType of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT accessible to any given
-- shader stage across all elements of pSetLayouts must
-- be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxPerStageDescriptorUpdateAfterBindInputAttachments
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_SAMPLER and
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetSamplers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER accessible across all
-- shader stagess and and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetUniformBuffers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetUniformBuffersDynamic
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetStorageBuffers
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetStorageBuffersDynamic
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, and
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetSampledImages
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, and
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetStorageImages
-- - The total number of descriptors in descriptor set layouts created
-- without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set with a descriptorType of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxDescriptorSetInputAttachments
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_SAMPLER and
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindSamplers
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER accessible across all
-- shader stagess and and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindUniformBuffers
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindUniformBuffersDynamic
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindStorageBuffers
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC accessible across
-- all shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindStorageBuffersDynamic
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE, and
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindSampledImages
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, and
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindStorageImages
-- - The total number of descriptors of the type
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT accessible across all
-- shader stages and across all elements of pSetLayouts
-- must be less than or equal to
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT::maxDescriptorSetUpdateAfterBindInputAttachments
-- - Any two elements of pPushConstantRanges must not
-- include the same stage in stageFlags
-- - pSetLayouts must not contain more than one
-- descriptor set layout that was created with
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
-- set
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - If setLayoutCount is not 0, pSetLayouts
-- must be a valid pointer to an array of setLayoutCount
-- valid VkDescriptorSetLayout handles
-- - If pushConstantRangeCount is not 0,
-- pPushConstantRanges must be a valid pointer to an
-- array of pushConstantRangeCount valid
-- VkPushConstantRange structures
--
--
-- See Also
--
-- VkDescriptorSetLayout, VkPipelineLayoutCreateFlags,
-- VkPushConstantRange, VkStructureType,
-- vkCreatePipelineLayout
data VkPipelineLayoutCreateInfo
VkPipelineLayoutCreateInfo :: VkStructureType -> Ptr () -> VkPipelineLayoutCreateFlags -> Word32 -> Ptr VkDescriptorSetLayout -> Word32 -> Ptr VkPushConstantRange -> VkPipelineLayoutCreateInfo
[$sel:vkSType:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> VkStructureType
[$sel:vkPNext:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> Ptr ()
[$sel:vkFlags:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> VkPipelineLayoutCreateFlags
[$sel:vkSetLayoutCount:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> Word32
[$sel:vkPSetLayouts:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> Ptr VkDescriptorSetLayout
[$sel:vkPushConstantRangeCount:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> Word32
[$sel:vkPPushConstantRanges:VkPipelineLayoutCreateInfo] :: VkPipelineLayoutCreateInfo -> Ptr VkPushConstantRange
-- | VkShaderStageFlags - Bitmask of VkShaderStageFlagBits
--
-- Description
--
-- VkShaderStageFlags is a bitmask type for setting a mask of
-- zero or more VkShaderStageFlagBits.
--
-- See Also
--
-- VkDescriptorSetLayoutBinding,
-- VkObjectTablePushConstantEntryNVX,
-- VkPhysicalDeviceSubgroupProperties, VkPushConstantRange,
-- VkShaderStageFlagBits, VkShaderStatisticsInfoAMD,
-- vkCmdPushConstants
type VkShaderStageFlags = VkShaderStageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.PipelineLayout.VkPushConstantRange
instance GHC.Classes.Eq Graphics.Vulkan.Core10.PipelineLayout.VkPushConstantRange
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.PipelineLayout.VkPushConstantRange
instance GHC.Show.Show Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.PipelineLayout.VkPipelineLayoutCreateFlags
module Graphics.Vulkan.Extensions.VK_AMD_shader_info
newtype VkShaderInfoTypeAMD
VkShaderInfoTypeAMD :: Int32 -> VkShaderInfoTypeAMD
-- | vkGetShaderInfoAMD - Get information about a shader in a pipeline
--
-- Parameters
--
--
-- - device is the device that created pipeline.
--
--
--
-- - pipeline is the target of the query.
-- - shaderStage identifies the particular shader within the
-- pipeline about which information is being queried.
-- - infoType describes what kind of information is being
-- queried.
-- - pInfoSize is a pointer to a value related to the amount
-- of data the query returns, as described below.
-- - pInfo is either NULL or a pointer to a buffer.
--
--
-- Description
--
-- If pInfo is NULL, then the maximum size of the
-- information that can be retrieved about the shader, in bytes,
-- is returned in pInfoSize. Otherwise, pInfoSize
-- must point to a variable set by the user to the size of the
-- buffer, in bytes, pointed to by pInfo, and on return the
-- variable is overwritten with the amount of data actually written to
-- pInfo.
--
-- If pInfoSize is less than the maximum size that can be
-- retrieved by the pipeline cache, then at most pInfoSize bytes
-- will be written to pInfo, and vkGetShaderInfoAMD
-- will return VK_INCOMPLETE.
--
-- Not all information is available for every shader and implementations
-- may not support all kinds of information for any shader. When a
-- certain type of information is unavailable, the function returns
-- VK_ERROR_FEATURE_NOT_PRESENT.
--
-- If information is successfully and fully queried, the function will
-- return VK_SUCCESS.
--
-- For VK_SHADER_INFO_TYPE_STATISTICS_AMD, an instance of
-- VkShaderStatisticsInfoAMD will be written to the buffer
-- pointed to by pInfo. This structure will be populated with
-- statistics regarding the physical device resources used by that shader
-- along with other miscellaneous information and is described in further
-- detail below.
--
-- For VK_SHADER_INFO_TYPE_DISASSEMBLY_AMD, pInfo
-- points to a UTF-8 null-terminated string containing human-readable
-- disassembly. The exact formatting and contents of the disassembly
-- string are vendor-specific.
--
-- The formatting and contents of all other types of information,
-- including VK_SHADER_INFO_TYPE_BINARY_AMD, are left to the
-- vendor and are not further specified by this extension.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pipeline must be a valid VkPipeline
-- handle
-- - shaderStage must be a valid
-- VkShaderStageFlagBits value
-- - infoType must be a valid
-- VkShaderInfoTypeAMD value
-- - pInfoSize must be a valid pointer to a
-- size_t value
-- - If the value referenced by pInfoSize is not 0,
-- and pInfo is not NULL, pInfo must be
-- a valid pointer to an array of pInfoSize bytes
-- - pipeline must have been created, allocated, or
-- retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_FEATURE_NOT_PRESENT
--
--
-- See Also
--
-- VkDevice, VkPipeline, VkShaderInfoTypeAMD,
-- VkShaderStageFlagBits
vkGetShaderInfoAMD :: ("device" ::: VkDevice) -> ("pipeline" ::: VkPipeline) -> ("shaderStage" ::: VkShaderStageFlagBits) -> ("infoType" ::: VkShaderInfoTypeAMD) -> ("pInfoSize" ::: Ptr CSize) -> ("pInfo" ::: Ptr ()) -> IO VkResult
-- | VkShaderResourceUsageAMD - Resource usage information about a
-- particular shader within a pipeline
--
-- Description
--
-- See Also
--
-- VkShaderStatisticsInfoAMD
data VkShaderResourceUsageAMD
VkShaderResourceUsageAMD :: Word32 -> Word32 -> Word32 -> CSize -> CSize -> VkShaderResourceUsageAMD
-- | numUsedVgprs is the number of vector instruction
-- general-purpose registers used by this shader.
[$sel:vkNumUsedVgprs:VkShaderResourceUsageAMD] :: VkShaderResourceUsageAMD -> Word32
-- | numUsedSgprs is the number of scalar instruction
-- general-purpose registers used by this shader.
[$sel:vkNumUsedSgprs:VkShaderResourceUsageAMD] :: VkShaderResourceUsageAMD -> Word32
-- | ldsSizePerLocalWorkGroup is the maximum local data store size
-- per work group in bytes.
[$sel:vkLdsSizePerLocalWorkGroup:VkShaderResourceUsageAMD] :: VkShaderResourceUsageAMD -> Word32
-- | ldsUsageSizeInBytes is the LDS usage size in bytes per work
-- group by this shader.
[$sel:vkLdsUsageSizeInBytes:VkShaderResourceUsageAMD] :: VkShaderResourceUsageAMD -> CSize
-- | scratchMemUsageInBytes is the scratch memory usage in bytes
-- by this shader.
[$sel:vkScratchMemUsageInBytes:VkShaderResourceUsageAMD] :: VkShaderResourceUsageAMD -> CSize
-- | VkShaderStatisticsInfoAMD - Statistical information about a particular
-- shader within a pipeline
--
-- Description
--
-- Some implementations may merge multiple logical shader stages together
-- in a single shader. In such cases, shaderStageMask will
-- contain a bitmask of all of the stages that are active within that
-- shader. Consequently, if specifying those stages as input to
-- vkGetShaderInfoAMD, the same output information may be
-- returned for all such shader stage queries.
--
-- The number of available VGPRs and SGPRs (numAvailableVgprs
-- and numAvailableSgprs respectively) are the
-- shader-addressable subset of physical registers that is given as a
-- limit to the compiler for register assignment. These values may
-- further be limited by implementations due to performance optimizations
-- where register pressure is a bottleneck.
--
-- See Also
--
-- VkShaderResourceUsageAMD, VkShaderStageFlags
data VkShaderStatisticsInfoAMD
VkShaderStatisticsInfoAMD :: VkShaderStageFlags -> VkShaderResourceUsageAMD -> Word32 -> Word32 -> Word32 -> Word32 -> Vector 3 Word32 -> VkShaderStatisticsInfoAMD
-- | shaderStageMask are the combination of logical shader stages
-- contained within this shader.
[$sel:vkShaderStageMask:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> VkShaderStageFlags
-- | resourceUsage is an instance of
-- VkShaderResourceUsageAMD describing internal physical device
-- resources used by this shader.
[$sel:vkResourceUsage:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> VkShaderResourceUsageAMD
-- | numPhysicalVgprs is the maximum number of vector instruction
-- general-purpose registers (VGPRs) available to the physical device.
[$sel:vkNumPhysicalVgprs:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> Word32
-- | numPhysicalSgprs is the maximum number of scalar instruction
-- general-purpose registers (SGPRs) available to the physical device.
[$sel:vkNumPhysicalSgprs:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> Word32
-- | numAvailableVgprs is the maximum limit of VGPRs made
-- available to the shader compiler.
[$sel:vkNumAvailableVgprs:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> Word32
-- | numAvailableSgprs is the maximum limit of SGPRs made
-- available to the shader compiler.
[$sel:vkNumAvailableSgprs:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> Word32
-- | computeWorkGroupSize is the local workgroup size of this
-- shader in { X, Y, Z } dimensions.
[$sel:vkComputeWorkGroupSize:VkShaderStatisticsInfoAMD] :: VkShaderStatisticsInfoAMD -> Vector 3 Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderStatisticsInfoAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderStatisticsInfoAMD
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderResourceUsageAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderResourceUsageAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderInfoTypeAMD
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderInfoTypeAMD
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderInfoTypeAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderStatisticsInfoAMD
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderResourceUsageAMD
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderInfoTypeAMD
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_AMD_shader_info.VkShaderInfoTypeAMD
module Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup
-- | VkSubgroupFeatureFlagBits - Enum describing what subgroup operations
-- are supported
--
-- See Also
--
-- VkSubgroupFeatureFlags
newtype VkSubgroupFeatureFlagBits
VkSubgroupFeatureFlagBits :: VkFlags -> VkSubgroupFeatureFlagBits
-- | VK_SUBGROUP_FEATURE_BASIC_BIT specifies the device will
-- accept SPIR-V shader modules that contain the GroupNonUniform
-- capability.
-- | VK_SUBGROUP_FEATURE_VOTE_BIT specifies the device will accept
-- SPIR-V shader modules that contain the GroupNonUniformVote
-- capability.
-- | VK_SUBGROUP_FEATURE_ARITHMETIC_BIT specifies the device will
-- accept SPIR-V shader modules that contain the
-- GroupNonUniformArithmetic capability.
-- | VK_SUBGROUP_FEATURE_BALLOT_BIT specifies the device will
-- accept SPIR-V shader modules that contain the
-- GroupNonUniformBallot capability.
-- | VK_SUBGROUP_FEATURE_SHUFFLE_BIT specifies the device will
-- accept SPIR-V shader modules that contain the
-- GroupNonUniformShuffle capability.
-- | VK_SUBGROUP_FEATURE_SHUFFLE_RELATIVE_BIT specifies the device
-- will accept SPIR-V shader modules that contain the
-- GroupNonUniformShuffleRelative capability.
-- | VK_SUBGROUP_FEATURE_CLUSTERED_BIT specifies the device will
-- accept SPIR-V shader modules that contain the
-- GroupNonUniformClustered capability.
-- | VK_SUBGROUP_FEATURE_QUAD_BIT specifies the device will accept
-- SPIR-V shader modules that contain the GroupNonUniformQuad
-- capability.
-- | VkPhysicalDeviceSubgroupProperties - Structure describing subgroup
-- support for an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceSubgroupProperties
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - subgroupSize is the number of invocations in each
-- subgroup. This will match any SubgroupSize decorated variable
-- used in any shader module created on this device.
-- subgroupSize is at least 1 if any of the physical device’s
-- queues support VK_QUEUE_GRAPHICS_BIT or
-- VK_QUEUE_COMPUTE_BIT.
-- - supportedStages is a bitfield of
-- VkShaderStageFlagBits describing the shader stages that
-- subgroup operations are supported in. supportedStages will
-- have the VK_SHADER_STAGE_COMPUTE_BIT bit set if any of any of
-- the physical device’s queues support
-- VK_QUEUE_COMPUTE_BIT.
-- - supportedOperations is a bitmask of
-- VkSubgroupFeatureFlagBits specifying the sets of subgroup
-- operations supported on this device. supportedOperations will
-- have the VK_SUBGROUP_FEATURE_BASIC_BIT bit set if any of the
-- physical device’s queues support VK_QUEUE_GRAPHICS_BIT or
-- VK_QUEUE_COMPUTE_BIT.
-- - quadOperationsInAllStages is a boolean that specifies
-- whether quad subgroup operations are available in all stages,
-- or are restricted to fragment and compute stages.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SUBGROUP_PROPERTIES
--
--
-- If the VkPhysicalDeviceSubgroupProperties structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkBool32, VkShaderStageFlags, VkStructureType,
-- VkSubgroupFeatureFlags
data VkPhysicalDeviceSubgroupProperties
VkPhysicalDeviceSubgroupProperties :: VkStructureType -> Ptr () -> Word32 -> VkShaderStageFlags -> VkSubgroupFeatureFlags -> VkBool32 -> VkPhysicalDeviceSubgroupProperties
[$sel:vkSType:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> Ptr ()
[$sel:vkSubgroupSize:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> Word32
[$sel:vkSupportedStages:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> VkShaderStageFlags
[$sel:vkSupportedOperations:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> VkSubgroupFeatureFlags
[$sel:vkQuadOperationsInAllStages:VkPhysicalDeviceSubgroupProperties] :: VkPhysicalDeviceSubgroupProperties -> VkBool32
-- | VkSubgroupFeatureFlags - Bitmask of VkSubgroupFeatureFlagBits
--
-- Description
--
-- VkSubgroupFeatureFlags is a bitmask type for setting a mask
-- of zero or more VkSubgroupFeatureFlagBits.
--
-- See Also
--
-- VkPhysicalDeviceSubgroupProperties,
-- VkSubgroupFeatureFlagBits
type VkSubgroupFeatureFlags = VkSubgroupFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkPhysicalDeviceSubgroupProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkPhysicalDeviceSubgroupProperties
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkPhysicalDeviceSubgroupProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_From_VK_KHR_subgroup.VkSubgroupFeatureFlagBits
module Graphics.Vulkan.Extensions.VK_NV_shader_subgroup_partitioned
-- | VK_SUBGROUP_FEATURE_PARTITIONED_BIT_NV specifies the device
-- will accept SPIR-V shader modules that contain the
-- GroupNonUniformPartitionedNV capability.
module Graphics.Vulkan.Core10.Memory
-- | VkMemoryMapFlags - Reserved for future use
--
-- Description
--
-- VkMemoryMapFlags is a bitmask type for setting a mask, but is
-- currently reserved for future use.
--
-- See Also
--
-- vkMapMemory
newtype VkMemoryMapFlags
VkMemoryMapFlags :: VkFlags -> VkMemoryMapFlags
-- | VkDeviceMemory - Opaque handle to a device memory object
--
-- Description
--
-- See Also
--
-- VkBindBufferMemoryInfo, VkBindImageMemoryInfo,
-- VkMappedMemoryRange,
-- VkMemoryGetAndroidHardwareBufferInfoANDROID,
-- VkMemoryGetFdInfoKHR, VkMemoryGetWin32HandleInfoKHR,
-- VkSparseImageMemoryBind, VkSparseMemoryBind,
-- VkWin32KeyedMutexAcquireReleaseInfoKHR,
-- VkWin32KeyedMutexAcquireReleaseInfoNV, vkAllocateMemory,
-- vkBindBufferMemory, vkBindImageMemory,
-- vkFreeMemory, vkGetDeviceMemoryCommitment,
-- vkGetMemoryWin32HandleNV, vkMapMemory,
-- vkUnmapMemory
type VkDeviceMemory = Ptr VkDeviceMemory_T
-- | vkAllocateMemory - Allocate device memory
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - pAllocateInfo is a pointer to an instance of the
-- VkMemoryAllocateInfo structure describing parameters of the
-- allocation. A successful returned allocation must use the
-- requested parameters — no substitution is permitted by the
-- implementation.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pMemory is a pointer to a VkDeviceMemory handle
-- in which information about the allocated memory is returned.
--
--
-- Description
--
-- Allocations returned by vkAllocateMemory are guaranteed to
-- meet any alignment requirement of the implementation. For example, if
-- an implementation requires 128 byte alignment for images and 64 byte
-- alignment for buffers, the device memory returned through this
-- mechanism would be 128-byte aligned. This ensures that applications
-- can correctly suballocate objects of different types (with
-- potentially different alignment requirements) in the same memory
-- object.
--
-- When memory is allocated, its contents are undefined.
--
-- The maximum number of valid memory allocations that can exist
-- simultaneously within a VkDevice may be restricted by
-- implementation- or platform-dependent limits. If a call to
-- vkAllocateMemory would cause the total number of allocations to
-- exceed these limits, such a call will fail and must return
-- VK_ERROR_TOO_MANY_OBJECTS. The
-- maxMemoryAllocationCount feature describes the number of
-- allocations that can exist simultaneously before encountering
-- these internal limits.
--
-- Some platforms may have a limit on the maximum size of a single
-- allocation. For example, certain systems may fail to create
-- allocations with a size greater than or equal to 4GB. Such a limit is
-- implementation-dependent, and if such a failure occurs then the error
-- VK_ERROR_OUT_OF_DEVICE_MEMORY must be returned. This
-- limit is advertised in
-- VkPhysicalDeviceMaintenance3Properties::maxMemoryAllocationSize.
--
-- Valid Usage
--
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pAllocateInfo must be a valid pointer to a valid
-- VkMemoryAllocateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pMemory must be a valid pointer to a
-- VkDeviceMemory handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
VK_ERROR_OUT_OF_DEVICE_MEMORY
VK_ERROR_TOO_MANY_OBJECTS
VK_ERROR_INVALID_EXTERNAL_HANDLE
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkDeviceMemory,
-- VkMemoryAllocateInfo
vkAllocateMemory :: ("device" ::: VkDevice) -> ("pAllocateInfo" ::: Ptr VkMemoryAllocateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pMemory" ::: Ptr VkDeviceMemory) -> IO VkResult
-- | vkFreeMemory - Free device memory
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - memory is the VkDeviceMemory object to be
-- freed.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Before freeing a memory object, an application must ensure the
-- memory object is no longer in use by the device—for example by
-- command buffers in the pending state. The memory can
-- remain bound to images or buffers at the time the memory object is
-- freed, but any further use of them (on host or device) for anything
-- other than destroying those objects will result in undefined behavior.
-- If there are still any bound images or buffers, the memory may
-- not be immediately released by the implementation, but must be
-- released by the time all bound images and buffers have been destroyed.
-- Once memory is released, it is returned to the heap from which it was
-- allocated.
--
-- How memory objects are bound to Images and Buffers is described in
-- detail in the Resource Memory Association section.
--
-- If a memory object is mapped at the time it is freed, it is implicitly
-- unmapped.
--
-- Note
--
-- As described below, host writes are not implicitly flushed when
-- the memory object is unmapped, but the implementation must
-- guarantee that writes that have not been flushed do not affect any
-- other memory.
--
-- Valid Usage
--
--
-- - All submitted commands that refer to memory (via images
-- or buffers) must have completed execution
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If memory is not VK_NULL_HANDLE, memory
-- must be a valid VkDeviceMemory handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If memory is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to memory must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkDeviceMemory
vkFreeMemory :: ("device" ::: VkDevice) -> ("memory" ::: VkDeviceMemory) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkMapMemory - Map a memory object into application address space
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - memory is the VkDeviceMemory object to be
-- mapped.
-- - offset is a zero-based byte offset from the beginning of
-- the memory object.
-- - size is the size of the memory range to map, or
-- VK_WHOLE_SIZE to map from offset to the end of the
-- allocation.
-- - flags is reserved for future use.
-- - ppData points to a pointer in which is returned a
-- host-accessible pointer to the beginning of the mapped range. This
-- pointer minus offset must be aligned to at least
-- VkPhysicalDeviceLimits::minMemoryMapAlignment.
--
--
-- Description
--
-- It is an application error to call vkMapMemory on a memory
-- object that is already mapped.
--
-- Note
--
-- vkMapMemory will fail if the implementation is unable to
-- allocate an appropriately sized contiguous virtual address range, e.g.
-- due to virtual address space fragmentation or platform limits. In such
-- cases, vkMapMemory must return
-- VK_ERROR_MEMORY_MAP_FAILED. The application can
-- improve the likelihood of success by reducing the size of the mapped
-- range and/or removing unneeded mappings using VkUnmapMemory.
--
-- vkMapMemory does not check whether the device memory is
-- currently in use before returning the host-accessible pointer. The
-- application must guarantee that any previously submitted
-- command that writes to this range has completed before the host reads
-- from or writes to that range, and that any previously submitted
-- command that reads from that range has completed before the host
-- writes to that region (see here for details on fulfilling such
-- a guarantee). If the device memory was allocated without the
-- VK_MEMORY_PROPERTY_HOST_COHERENT_BIT set, these guarantees
-- must be made for an extended range: the application must
-- round down the start of the range to the nearest multiple of
-- VkPhysicalDeviceLimits::nonCoherentAtomSize, and round
-- the end of the range up to the nearest multiple of
-- VkPhysicalDeviceLimits::nonCoherentAtomSize.
--
-- While a range of device memory is mapped for host access, the
-- application is responsible for synchronizing both device and host
-- access to that memory range.
--
-- Note
--
-- It is important for the application developer to become meticulously
-- familiar with all of the mechanisms described in the chapter on
-- Synchronization and Cache Control as they are crucial to
-- maintaining memory access ordering.
--
-- Valid Usage
--
--
-- - memory must not be currently mapped
--
--
--
-- - offset must be less than the size of
-- memory
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be greater than 0
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be less than or equal to the size of the
-- memory minus offset
-- - memory must have been created with a memory type
-- that reports VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT
-- - memory must not have been allocated with multiple
-- instances.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - memory must be a valid VkDeviceMemory
-- handle
-- - flags must be 0
-- - ppData must be a valid pointer to a pointer
-- value
-- - memory must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to memory must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkDeviceMemory, VkDeviceSize,
-- VkMemoryMapFlags
vkMapMemory :: ("device" ::: VkDevice) -> ("memory" ::: VkDeviceMemory) -> ("offset" ::: VkDeviceSize) -> ("size" ::: VkDeviceSize) -> ("flags" ::: VkMemoryMapFlags) -> ("ppData" ::: Ptr (Ptr ())) -> IO VkResult
-- | vkUnmapMemory - Unmap a previously mapped memory object
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - memory is the memory object to be unmapped.
--
--
-- Description
--
-- Valid Usage
--
--
-- - memory must be currently mapped
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - memory must be a valid VkDeviceMemory
-- handle
-- - memory must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to memory must be externally
-- synchronized
--
--
-- See Also
--
-- VkDevice, VkDeviceMemory
vkUnmapMemory :: ("device" ::: VkDevice) -> ("memory" ::: VkDeviceMemory) -> IO ()
-- | vkFlushMappedMemoryRanges - Flush mapped memory ranges
--
-- Parameters
--
--
-- - device is the logical device that owns the memory
-- ranges.
--
--
--
-- - memoryRangeCount is the length of the
-- pMemoryRanges array.
-- - pMemoryRanges is a pointer to an array of
-- VkMappedMemoryRange structures describing the memory ranges to
-- flush.
--
--
-- Description
--
-- vkFlushMappedMemoryRanges guarantees that host writes to the
-- memory ranges described by pMemoryRanges can be made
-- available to device access, via availability operations from
-- the VK_ACCESS_HOST_WRITE_BIT access type.
--
-- Within each range described by pMemoryRanges, each set of
-- nonCoherentAtomSize bytes in that range is flushed if any
-- byte in that set has been written by the host since it was first
-- mapped, or the last time it was flushed. If pMemoryRanges
-- includes sets of nonCoherentAtomSize bytes where no bytes
-- have been written by the host, those bytes must not be flushed.
--
-- Unmapping non-coherent memory does not implicitly flush the mapped
-- memory, and host writes that have not been flushed may not ever
-- be visible to the device. However, implementations must ensure
-- that writes that have not been flushed do not become visible to any
-- other memory.
--
-- Note
--
-- The above guarantee avoids a potential memory corruption in scenarios
-- where host writes to a mapped memory object have not been flushed
-- before the memory is unmapped (or freed), and the virtual address
-- range is subsequently reused for a different mapping (or memory
-- allocation).
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pMemoryRanges must be a valid pointer to an array
-- of memoryRangeCount valid VkMappedMemoryRange
-- structures
-- - memoryRangeCount must be greater than
-- 0
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkMappedMemoryRange
vkFlushMappedMemoryRanges :: ("device" ::: VkDevice) -> ("memoryRangeCount" ::: Word32) -> ("pMemoryRanges" ::: Ptr VkMappedMemoryRange) -> IO VkResult
-- | vkInvalidateMappedMemoryRanges - Invalidate ranges of mapped memory
-- objects
--
-- Parameters
--
--
-- - device is the logical device that owns the memory
-- ranges.
--
--
--
-- - memoryRangeCount is the length of the
-- pMemoryRanges array.
-- - pMemoryRanges is a pointer to an array of
-- VkMappedMemoryRange structures describing the memory ranges to
-- invalidate.
--
--
-- Description
--
-- vkInvalidateMappedMemoryRanges guarantees that device writes
-- to the memory ranges described by pMemoryRanges, which have
-- been made visible to the VK_ACCESS_HOST_WRITE_BIT and
-- VK_ACCESS_HOST_READ_BIT access types, are made visible
-- to the host. If a range of non-coherent memory is written by the host
-- and then invalidated without first being flushed, its contents are
-- undefined.
--
-- Within each range described by pMemoryRanges, each set of
-- nonCoherentAtomSize bytes in that range is invalidated if any
-- byte in that set has been written by the device since it was first
-- mapped, or the last time it was invalidated.
--
-- Note
--
-- Mapping non-coherent memory does not implicitly invalidate the mapped
-- memory, and device writes that have not been invalidated must
-- be made visible before the host reads or overwrites them.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pMemoryRanges must be a valid pointer to an array
-- of memoryRangeCount valid VkMappedMemoryRange
-- structures
-- - memoryRangeCount must be greater than
-- 0
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkMappedMemoryRange
vkInvalidateMappedMemoryRanges :: ("device" ::: VkDevice) -> ("memoryRangeCount" ::: Word32) -> ("pMemoryRanges" ::: Ptr VkMappedMemoryRange) -> IO VkResult
-- | vkGetDeviceMemoryCommitment - Query the current commitment for a
-- VkDeviceMemory
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - memory is the memory object being queried.
-- - pCommittedMemoryInBytes is a pointer to a
-- VkDeviceSize value in which the number of bytes currently
-- committed is returned, on success.
--
--
-- Description
--
-- The implementation may update the commitment at any time, and
-- the value returned by this query may be out of date.
--
-- The implementation guarantees to allocate any committed memory from
-- the heapIndex indicated by the memory type that the memory object was
-- created with.
--
-- Valid Usage
--
--
-- - memory must have been created with a memory type
-- that reports VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - memory must be a valid VkDeviceMemory
-- handle
-- - pCommittedMemoryInBytes must be a valid pointer to
-- a VkDeviceSize value
-- - memory must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkDevice, VkDeviceMemory, VkDeviceSize
vkGetDeviceMemoryCommitment :: ("device" ::: VkDevice) -> ("memory" ::: VkDeviceMemory) -> ("pCommittedMemoryInBytes" ::: Ptr VkDeviceSize) -> IO ()
-- | VkMemoryAllocateInfo - Structure containing parameters of a memory
-- allocation
--
-- Description
--
-- An instance of the VkMemoryAllocateInfo structure defines a
-- memory import operation if the pNext chain contains an
-- instance of one of the following structures: *
-- VkImportMemoryWin32HandleInfoKHR with non-zero
-- handleType value * VkImportMemoryFdInfoKHR with a
-- non-zero handleType value *
-- VkImportMemoryHostPointerInfoEXT with a non-zero
-- handleType value *
-- VkImportAndroidHardwareBufferInfoANDROID with a
-- non-NULL buffer value
--
-- Importing memory must not modify the content of the memory.
-- Implementations must ensure that importing memory does not
-- enable the importing Vulkan instance to access any memory or resources
-- in other Vulkan instances other than that corresponding to the memory
-- object imported. Implementations must also ensure accessing
-- imported memory which has not been initialized does not allow the
-- importing Vulkan instance to obtain data from the exporting Vulkan
-- instance or vice-versa.
--
-- Note
--
-- How exported and imported memory is isolated is left to the
-- implementation, but applications should be aware that such isolation
-- may prevent implementations from placing multiple exportable
-- memory objects in the same physical or virtual page. Hence,
-- applications should avoid creating many small external memory
-- objects whenever possible.
--
-- When performing a memory import operation, it is the responsibility of
-- the application to ensure the external handles meet all valid usage
-- requirements. However, implementations must perform sufficient
-- validation of external handles to ensure that the operation results in
-- a valid memory object which will not cause program termination, device
-- loss, queue stalls, or corruption of other resources when used as
-- allowed according to its allocation parameters. If the external handle
-- provided does not meet these requirements, the implementation
-- must fail the memory import operation with the error code
-- VK_ERROR_INVALID_EXTERNAL_HANDLE.
--
-- Valid Usage
--
--
-- - If the pNext chain contains an instance of
-- VkExportMemoryAllocateInfo, and any of the handle types
-- specified in VkExportMemoryAllocateInfo::handleTypes
-- require a dedicated allocation, as reported by
-- vkGetPhysicalDeviceImageFormatProperties2 in
-- VkExternalImageFormatProperties::externalMemoryProperties::externalMemoryFeatures
-- or
-- VkExternalBufferProperties::externalMemoryProperties::externalMemoryFeatures,
-- the pNext chain must contain an instance of
-- VkMemoryDedicatedAllocateInfo or
-- VkDedicatedAllocationMemoryAllocateInfoNV with either its
-- image or buffer field set to a value other than
-- VK_NULL_HANDLE.
--
--
--
-- - If the pNext chain contains an instance of
-- VkExportMemoryAllocateInfo, it must not contain an
-- instance of VkExportMemoryAllocateInfoNV or
-- VkExportMemoryWin32HandleInfoNV.
-- - If the pNext chain contains an instance of
-- VkImportMemoryWin32HandleInfoKHR, it must not contain an
-- instance of VkImportMemoryWin32HandleInfoNV.
-- - If the parameters define an import operation, the external handle
-- specified was created by the Vulkan API, and the external handle type
-- is VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR, then the
-- values of allocationSize and memoryTypeIndex
-- must match those specified when the memory object being
-- imported was created.
-- - If the parameters define an import operation and the external
-- handle specified was created by the Vulkan API, the device mask
-- specified by VkMemoryAllocateFlagsInfo must match that
-- specified when the memory object being imported was allocated.
-- - 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
-- vkAllocateMemory must match the list of physical devices
-- that comprise the logical device on which the memory was originally
-- allocated.
-- - 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 memoryTypeIndex must be one
-- of those returned by vkGetMemoryWin32HandlePropertiesKHR.
-- - If the parameters define an import operation, the external handle
-- was created by the Vulkan API, and the external handle type is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT_KHR or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT_KHR, then
-- the values of allocationSize and memoryTypeIndex
-- must match those specified when the memory object being
-- imported was created.
-- - If the parameters define an import operation and the external
-- handle type is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT, or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT,
-- allocationSize must match the size reported in the
-- memory requirements of the image or buffer member of
-- the instance of VkDedicatedAllocationMemoryAllocateInfoNV
-- included in the pNext chain.
-- - If the parameters define an import operation and the external
-- handle type is VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT,
-- allocationSize must match the size specified when
-- creating the Direct3D 12 heap from which the external handle was
-- extracted.
-- - 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 memoryTypeIndex must be one of those
-- returned by vkGetMemoryFdPropertiesKHR.
-- - If the parameters define an import operation and the external
-- handle is a host pointer, the value of memoryTypeIndex
-- must be one of those returned by
-- vkGetMemoryHostPointerPropertiesEXT
-- - If the parameters define an import operation and the external
-- handle is a host pointer, allocationSize must be an
-- integer multiple of
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT::minImportedHostPointerAlignment
-- - If the parameters define an import operation and the external
-- handle type is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BIT_ANDROID:
-- - If the parameters do not define an import operation, and the
-- pNext chain contains an instance of
-- VkExportMemoryAllocateInfo with
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID
-- included in its handleTypes member, and the pNext
-- contains an instance of VkMemoryDedicatedAllocateInfo with
-- image not equal to VK_NULL_HANDLE, then
-- allocationSize must be 0, otherwise
-- allocationSize must be greater than 0.
-- - If the parameters define an import operation, the external handle
-- is an Android hardware buffer, and the pNext chain includes
-- an instance of VkMemoryDedicatedAllocateInfo with
-- image that is not VK_NULL_HANDLE:
- The Android
-- hardware buffer’s usage must include at least one of
-- AHARDWAREBUFFER_USAGE_GPU_COLOR_OUTPUT or
-- AHARDWAREBUFFER_USAGE_GPU_SAMPLED_IMAGE
- The
-- image’s format must be VK_FORMAT_UNDEFINED or
-- the format returned by
-- vkGetAndroidHardwareBufferPropertiesANDROID in
-- VkAndroidHardwareBufferFormatPropertiesANDROID::format
-- for the Android hardware buffer.
- The image’s and Android
-- hardware buffer’s width, height, and array layer dimensions
-- must be the same
- If the Android hardware buffer’s usage
-- includes AHARDWAREBUFFER_USAGE_GPU_MIPMAP_COMPLETE, the image
-- must have ⌊log2(max(width, height))⌋ + 1 mip levels,
-- otherwise it must have exactly 1 mip level.
- Each bit
-- set in the image’s usage must be listed in AHardwareBuffer
-- Usage Equivalence, and if there is a corresponding
-- AHARDWAREBUFFER_USAGE bit listed that bit must be
-- included in the Android hardware buffer’s usage
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkDedicatedAllocationMemoryAllocateInfoNV,
-- VkExportMemoryAllocateInfo,
-- VkExportMemoryAllocateInfoNV,
-- VkExportMemoryWin32HandleInfoKHR,
-- VkExportMemoryWin32HandleInfoNV,
-- VkImportAndroidHardwareBufferInfoANDROID,
-- VkImportMemoryFdInfoKHR,
-- VkImportMemoryHostPointerInfoEXT,
-- VkImportMemoryWin32HandleInfoKHR,
-- VkImportMemoryWin32HandleInfoNV,
-- VkMemoryAllocateFlagsInfo, or
-- VkMemoryDedicatedAllocateInfo
-- - Each sType member in the pNext chain must
-- be unique
--
--
-- See Also
--
-- VkDeviceSize, VkStructureType, vkAllocateMemory
data VkMemoryAllocateInfo
VkMemoryAllocateInfo :: VkStructureType -> Ptr () -> VkDeviceSize -> Word32 -> VkMemoryAllocateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryAllocateInfo] :: VkMemoryAllocateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryAllocateInfo] :: VkMemoryAllocateInfo -> Ptr ()
-- | allocationSize is the size of the allocation in bytes
[$sel:vkAllocationSize:VkMemoryAllocateInfo] :: VkMemoryAllocateInfo -> VkDeviceSize
-- | memoryTypeIndex is an index identifying a memory type from
-- the memoryTypes array of the
-- VkPhysicalDeviceMemoryProperties structure
[$sel:vkMemoryTypeIndex:VkMemoryAllocateInfo] :: VkMemoryAllocateInfo -> Word32
-- | VkMappedMemoryRange - Structure specifying a mapped memory range
--
-- Description
--
-- Valid Usage
--
--
-- - memory must be currently mapped
--
--
--
-- - If size is not equal to VK_WHOLE_SIZE,
-- offset and size must specify a range
-- contained within the currently mapped range of memory
-- - If size is equal to VK_WHOLE_SIZE,
-- offset must be within the currently mapped range of
-- memory
-- - If size is equal to VK_WHOLE_SIZE, the end of
-- the current mapping of memory must be a multiple of
-- VkPhysicalDeviceLimits::nonCoherentAtomSize bytes from
-- the beginning of the memory object.
-- - offset must be a multiple of
-- VkPhysicalDeviceLimits::nonCoherentAtomSize
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must either be a multiple of
-- VkPhysicalDeviceLimits::nonCoherentAtomSize, or
-- offset plus size must equal the size of
-- memory.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MAPPED_MEMORY_RANGE
--
--
--
-- - pNext must be NULL
-- - memory must be a valid VkDeviceMemory
-- handle
--
--
-- See Also
--
-- VkDeviceMemory, VkDeviceSize, VkStructureType,
-- vkFlushMappedMemoryRanges,
-- vkInvalidateMappedMemoryRanges
data VkMappedMemoryRange
VkMappedMemoryRange :: VkStructureType -> Ptr () -> VkDeviceMemory -> VkDeviceSize -> VkDeviceSize -> VkMappedMemoryRange
-- | sType is the type of this structure.
[$sel:vkSType:VkMappedMemoryRange] :: VkMappedMemoryRange -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMappedMemoryRange] :: VkMappedMemoryRange -> Ptr ()
-- | memory is the memory object to which this range belongs.
[$sel:vkMemory:VkMappedMemoryRange] :: VkMappedMemoryRange -> VkDeviceMemory
-- | offset is the zero-based byte offset from the beginning of
-- the memory object.
[$sel:vkOffset:VkMappedMemoryRange] :: VkMappedMemoryRange -> VkDeviceSize
-- | size is either the size of range, or VK_WHOLE_SIZE
-- to affect the range from offset to the end of the current
-- mapping of the allocation.
[$sel:vkSize:VkMappedMemoryRange] :: VkMappedMemoryRange -> VkDeviceSize
instance GHC.Show.Show Graphics.Vulkan.Core10.Memory.VkMappedMemoryRange
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Memory.VkMappedMemoryRange
instance GHC.Show.Show Graphics.Vulkan.Core10.Memory.VkMemoryAllocateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Memory.VkMemoryAllocateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Memory.VkMappedMemoryRange
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Memory.VkMemoryAllocateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Memory.VkMemoryMapFlags
module Graphics.Vulkan.Core10.MemoryManagement
-- | VkBuffer - Opaque handle to a buffer object
--
-- Description
--
-- See Also
--
-- VkBindBufferMemoryInfo, VkBufferMemoryBarrier,
-- VkBufferMemoryRequirementsInfo2, VkBufferViewCreateInfo,
-- VkCmdProcessCommandsInfoNVX,
-- VkDedicatedAllocationMemoryAllocateInfoNV,
-- VkDescriptorBufferInfo, VkIndirectCommandsTokenNVX,
-- VkMemoryDedicatedAllocateInfo,
-- VkObjectTableIndexBufferEntryNVX,
-- VkObjectTableVertexBufferEntryNVX,
-- VkSparseBufferMemoryBindInfo, vkBindBufferMemory,
-- vkCmdBindIndexBuffer, vkCmdBindVertexBuffers,
-- vkCmdCopyBuffer, vkCmdCopyBufferToImage,
-- vkCmdCopyImageToBuffer, vkCmdCopyQueryPoolResults,
-- vkCmdDispatchIndirect, vkCmdDrawIndexedIndirect,
-- vkCmdDrawIndexedIndirectCountAMD, vkCmdDrawIndirect,
-- vkCmdDrawIndirectCountAMD, vkCmdFillBuffer,
-- vkCmdUpdateBuffer, vkCmdWriteBufferMarkerAMD,
-- vkCreateBuffer, vkDestroyBuffer,
-- vkGetBufferMemoryRequirements
type VkBuffer = Ptr VkBuffer_T
-- | VkImage - Opaque handle to a image object
--
-- Description
--
-- See Also
--
-- VkBindImageMemoryInfo,
-- VkDedicatedAllocationMemoryAllocateInfoNV,
-- VkImageMemoryBarrier, VkImageMemoryRequirementsInfo2,
-- VkImageSparseMemoryRequirementsInfo2,
-- VkImageViewCreateInfo, VkMemoryDedicatedAllocateInfo,
-- VkSparseImageMemoryBindInfo,
-- VkSparseImageOpaqueMemoryBindInfo, vkBindImageMemory,
-- vkCmdBlitImage, vkCmdClearColorImage,
-- vkCmdClearDepthStencilImage, vkCmdCopyBufferToImage,
-- vkCmdCopyImage, vkCmdCopyImageToBuffer,
-- vkCmdResolveImage, vkCreateImage, vkDestroyImage,
-- vkGetImageMemoryRequirements,
-- vkGetImageSparseMemoryRequirements,
-- vkGetImageSubresourceLayout, vkGetSwapchainImagesKHR
type VkImage = Ptr VkImage_T
-- | vkGetBufferMemoryRequirements - Returns the memory requirements for
-- specified Vulkan object
--
-- Parameters
--
--
-- - device is the logical device that owns the buffer.
--
--
--
-- - buffer is the buffer to query.
-- - pMemoryRequirements points to an instance of the
-- VkMemoryRequirements structure in which the memory requirements
-- of the buffer object are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - pMemoryRequirements must be a valid pointer to a
-- VkMemoryRequirements structure
-- - buffer must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkBuffer, VkDevice, VkMemoryRequirements
vkGetBufferMemoryRequirements :: ("device" ::: VkDevice) -> ("buffer" ::: VkBuffer) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements) -> IO ()
-- | vkBindBufferMemory - Bind device memory to a buffer object
--
-- Parameters
--
--
-- - device is the logical device that owns the buffer and
-- memory.
--
--
--
-- - buffer is the buffer to be attached to memory.
-- - memory is a VkDeviceMemory object describing the
-- device memory to attach.
-- - memoryOffset is the start offset of the region of
-- memory which is to be bound to the buffer. The number of
-- bytes returned in the VkMemoryRequirements::size
-- member in memory, starting from memoryOffset bytes,
-- will be bound to the specified buffer.
--
--
-- Description
--
-- vkBindBufferMemory is equivalent to passing the same
-- parameters through VkBindBufferMemoryInfo to
-- vkBindBufferMemory2.
--
-- Valid Usage
--
--
-- - buffer must not already be backed by a memory
-- object
--
--
--
-- - buffer must not have been created with any sparse
-- memory binding flags
-- - memoryOffset must be less than the size of
-- memory
-- - If buffer was created with the
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT,
-- memoryOffset must be a multiple of
-- VkPhysicalDeviceLimits::minTexelBufferOffsetAlignment
-- - If buffer was created with the
-- VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, memoryOffset
-- must be a multiple of
-- VkPhysicalDeviceLimits::minUniformBufferOffsetAlignment
-- - If buffer was created with the
-- VK_BUFFER_USAGE_STORAGE_BUFFER_BIT, memoryOffset
-- must be a multiple of
-- VkPhysicalDeviceLimits::minStorageBufferOffsetAlignment
-- - memory must have been allocated using one of the
-- memory types allowed in the memoryTypeBits member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- - memoryOffset must be an integer multiple of the
-- alignment member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- - The size member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- must be less than or equal to the size of memory minus
-- memoryOffset
-- - If buffer requires a dedicated allocation(as reported by
-- vkGetBufferMemoryRequirements2 in
-- VkMemoryDedicatedRequirements::requiresDedicatedAllocation for
-- buffer), memory must have been created with
-- VkMemoryDedicatedAllocateInfo::buffer equal to
-- buffer
-- - If the VkMemoryAllocateInfo provided when memory
-- was allocated included an instance of
-- VkMemoryDedicatedAllocateInfo in its pNext chain, and
-- VkMemoryDedicatedAllocateInfo::buffer was not
-- VK_NULL_HANDLE, then buffer must equal
-- VkMemoryDedicatedAllocateInfo::buffer, and
-- memoryOffset must be zero.
-- - If buffer was created with
-- VkDedicatedAllocationBufferCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE, memory must have been
-- created with
-- VkDedicatedAllocationMemoryAllocateInfoNV::buffer
-- equal to a buffer handle created with identical creation parameters to
-- buffer and memoryOffset must be zero
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - memory must be a valid VkDeviceMemory
-- handle
-- - buffer must have been created, allocated, or
-- retrieved from device
-- - memory must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to buffer must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBuffer, VkDevice, VkDeviceMemory,
-- VkDeviceSize
vkBindBufferMemory :: ("device" ::: VkDevice) -> ("buffer" ::: VkBuffer) -> ("memory" ::: VkDeviceMemory) -> ("memoryOffset" ::: VkDeviceSize) -> IO VkResult
-- | vkGetImageMemoryRequirements - Returns the memory requirements for
-- specified Vulkan object
--
-- Parameters
--
--
-- - device is the logical device that owns the image.
--
--
--
-- - image is the image to query.
-- - pMemoryRequirements points to an instance of the
-- VkMemoryRequirements structure in which the memory requirements
-- of the image object are returned.
--
--
-- Description
--
-- Valid Usage
--
--
-- - image must not have been created with the
-- VK_IMAGE_CREATE_DISJOINT_BIT flag set
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - image must be a valid VkImage handle
-- - pMemoryRequirements must be a valid pointer to a
-- VkMemoryRequirements structure
-- - image must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkDevice, VkImage, VkMemoryRequirements
vkGetImageMemoryRequirements :: ("device" ::: VkDevice) -> ("image" ::: VkImage) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements) -> IO ()
-- | vkBindImageMemory - Bind device memory to an image object
--
-- Parameters
--
--
-- - device is the logical device that owns the image and
-- memory.
--
--
--
-- - image is the image.
-- - memory is the VkDeviceMemory object describing
-- the device memory to attach.
-- - memoryOffset is the start offset of the region of
-- memory which is to be bound to the image. The number of bytes
-- returned in the VkMemoryRequirements::size member in
-- memory, starting from memoryOffset bytes, will be
-- bound to the specified image.
--
--
-- Description
--
-- vkBindImageMemory is equivalent to passing the same
-- parameters through VkBindImageMemoryInfo to
-- vkBindImageMemory2.
--
-- Valid Usage
--
--
-- - image must not have been created with the
-- VK_IMAGE_CREATE_DISJOINT_BIT set.
--
--
--
-- - image must not already be backed by a memory
-- object
-- - image must not have been created with any sparse
-- memory binding flags
-- - memoryOffset must be less than the size of
-- memory
-- - memory must have been allocated using one of the
-- memory types allowed in the memoryTypeBits member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements with image
-- - memoryOffset must be an integer multiple of the
-- alignment member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetImageMemoryRequirements with image
-- - The size member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetImageMemoryRequirements with image must
-- be less than or equal to the size of memory minus
-- memoryOffset
-- - If image requires a dedicated allocation (as reported by
-- vkGetImageMemoryRequirements2 in
-- VkMemoryDedicatedRequirements::requiresDedicatedAllocation for
-- image), memory must have been created with
-- VkMemoryDedicatedAllocateInfo::image equal to
-- image
-- - If the VkMemoryAllocateInfo provided when memory
-- was allocated included an instance of
-- VkMemoryDedicatedAllocateInfo in its pNext chain, and
-- VkMemoryDedicatedAllocateInfo::image was not
-- VK_NULL_HANDLE, then image must equal
-- VkMemoryDedicatedAllocateInfo::image and
-- memoryOffset must be zero.
-- - If image was created with
-- VkDedicatedAllocationImageCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE, memory must have been
-- created with
-- VkDedicatedAllocationMemoryAllocateInfoNV::image equal
-- to an image handle created with identical creation parameters to
-- image and memoryOffset must be zero
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - image must be a valid VkImage handle
-- - memory must be a valid VkDeviceMemory
-- handle
-- - image must have been created, allocated, or
-- retrieved from device
-- - memory must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to image must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkDeviceMemory, VkDeviceSize,
-- VkImage
vkBindImageMemory :: ("device" ::: VkDevice) -> ("image" ::: VkImage) -> ("memory" ::: VkDeviceMemory) -> ("memoryOffset" ::: VkDeviceSize) -> IO VkResult
-- | VkMemoryRequirements - Structure specifying memory requirements
--
-- Description
--
-- See Also
--
-- VkDeviceSize, VkMemoryRequirements2,
-- vkGetBufferMemoryRequirements,
-- vkGetImageMemoryRequirements
data VkMemoryRequirements
VkMemoryRequirements :: VkDeviceSize -> VkDeviceSize -> Word32 -> VkMemoryRequirements
-- | size is the size, in bytes, of the memory allocation
-- required for the resource.
[$sel:vkSize:VkMemoryRequirements] :: VkMemoryRequirements -> VkDeviceSize
-- | alignment is the alignment, in bytes, of the offset within
-- the allocation required for the resource.
[$sel:vkAlignment:VkMemoryRequirements] :: VkMemoryRequirements -> VkDeviceSize
-- | memoryTypeBits is a bitmask and contains one bit set for
-- every supported memory type for the resource. Bit i is set if
-- and only if the memory type i in the
-- VkPhysicalDeviceMemoryProperties structure for the physical
-- device is supported for the resource.
[$sel:vkMemoryTypeBits:VkMemoryRequirements] :: VkMemoryRequirements -> Word32
instance GHC.Show.Show Graphics.Vulkan.Core10.MemoryManagement.VkMemoryRequirements
instance GHC.Classes.Eq Graphics.Vulkan.Core10.MemoryManagement.VkMemoryRequirements
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.MemoryManagement.VkMemoryRequirements
module Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation
-- | VkDedicatedAllocationImageCreateInfoNV - Specify that an image is
-- bound to a dedicated memory resource
--
-- Description
--
-- Note
--
-- Using a dedicated allocation for color and depth/stencil attachments
-- or other large images may improve performance on some devices.
--
-- Valid Usage
--
--
-- - If dedicatedAllocation is VK_TRUE,
-- VkImageCreateInfo::flags must not include
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT,
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT, or
-- VK_IMAGE_CREATE_SPARSE_ALIASED_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_IMAGE_CREATE_INFO_NV
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkDedicatedAllocationImageCreateInfoNV
VkDedicatedAllocationImageCreateInfoNV :: VkStructureType -> Ptr () -> VkBool32 -> VkDedicatedAllocationImageCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkDedicatedAllocationImageCreateInfoNV] :: VkDedicatedAllocationImageCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDedicatedAllocationImageCreateInfoNV] :: VkDedicatedAllocationImageCreateInfoNV -> Ptr ()
-- | dedicatedAllocation specifies whether the image will have a
-- dedicated allocation bound to it.
[$sel:vkDedicatedAllocation:VkDedicatedAllocationImageCreateInfoNV] :: VkDedicatedAllocationImageCreateInfoNV -> VkBool32
-- | VkDedicatedAllocationBufferCreateInfoNV - Specify that a buffer is
-- bound to a dedicated memory resource
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_BUFFER_CREATE_INFO_NV
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkDedicatedAllocationBufferCreateInfoNV
VkDedicatedAllocationBufferCreateInfoNV :: VkStructureType -> Ptr () -> VkBool32 -> VkDedicatedAllocationBufferCreateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkDedicatedAllocationBufferCreateInfoNV] :: VkDedicatedAllocationBufferCreateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDedicatedAllocationBufferCreateInfoNV] :: VkDedicatedAllocationBufferCreateInfoNV -> Ptr ()
-- | dedicatedAllocation specifies whether the buffer will have a
-- dedicated allocation bound to it.
[$sel:vkDedicatedAllocation:VkDedicatedAllocationBufferCreateInfoNV] :: VkDedicatedAllocationBufferCreateInfoNV -> VkBool32
-- | VkDedicatedAllocationMemoryAllocateInfoNV - Specify a dedicated memory
-- allocation resource
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - If image is not VK_NULL_HANDLE, the image
-- must have been created with
-- VkDedicatedAllocationImageCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE
-- - If buffer is not VK_NULL_HANDLE, the buffer
-- must have been created with
-- VkDedicatedAllocationBufferCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE
-- - If image is not VK_NULL_HANDLE,
-- VkMemoryAllocateInfo::allocationSize must
-- equal the VkMemoryRequirements::size of the
-- image
-- - If buffer is not VK_NULL_HANDLE,
-- VkMemoryAllocateInfo::allocationSize must
-- equal the VkMemoryRequirements::size of the
-- buffer
-- - If image is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation, the
-- memory being imported must also be a dedicated image allocation
-- and image must be identical to the image associated
-- with the imported memory.
-- - If buffer is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation, the
-- memory being imported must also be a dedicated buffer
-- allocation and buffer must be identical to the buffer
-- associated with the imported memory.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEDICATED_ALLOCATION_MEMORY_ALLOCATE_INFO_NV
--
--
--
-- - If image is not VK_NULL_HANDLE, image
-- must be a valid VkImage handle
-- - If buffer is not VK_NULL_HANDLE, buffer
-- must be a valid VkBuffer handle
-- - Both of buffer, and image that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkBuffer, VkImage, VkStructureType
data VkDedicatedAllocationMemoryAllocateInfoNV
VkDedicatedAllocationMemoryAllocateInfoNV :: VkStructureType -> Ptr () -> VkImage -> VkBuffer -> VkDedicatedAllocationMemoryAllocateInfoNV
-- | sType is the type of this structure.
[$sel:vkSType:VkDedicatedAllocationMemoryAllocateInfoNV] :: VkDedicatedAllocationMemoryAllocateInfoNV -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDedicatedAllocationMemoryAllocateInfoNV] :: VkDedicatedAllocationMemoryAllocateInfoNV -> Ptr ()
-- | image is VK_NULL_HANDLE or a handle of an image which
-- this memory will be bound to.
[$sel:vkImage:VkDedicatedAllocationMemoryAllocateInfoNV] :: VkDedicatedAllocationMemoryAllocateInfoNV -> VkImage
-- | buffer is VK_NULL_HANDLE or a handle of a buffer which
-- this memory will be bound to.
[$sel:vkBuffer:VkDedicatedAllocationMemoryAllocateInfoNV] :: VkDedicatedAllocationMemoryAllocateInfoNV -> VkBuffer
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationMemoryAllocateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationMemoryAllocateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationBufferCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationBufferCreateInfoNV
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationImageCreateInfoNV
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationImageCreateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationMemoryAllocateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationBufferCreateInfoNV
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NV_dedicated_allocation.VkDedicatedAllocationImageCreateInfoNV
module Graphics.Vulkan.Extensions.VK_AMD_draw_indirect_count
-- | vkCmdDrawIndirectCountAMD - Perform an indirect draw with the draw
-- count sourced from a buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - buffer is the buffer containing draw parameters.
-- - offset is the byte offset into buffer where
-- parameters begin.
-- - countBuffer is the buffer containing the draw count.
-- - countBufferOffset is the byte offset into
-- countBuffer where the draw count begins.
-- - maxDrawCount specifies the maximum number of draws that
-- will be executed. The actual number of executed draw calls is the
-- minimum of the count specified in countBuffer and
-- maxDrawCount.
-- - stride is the byte stride between successive sets of draw
-- parameters.
--
--
-- Description
--
-- vkCmdDrawIndirectCountAMD behaves similarly to
-- vkCmdDrawIndirect except that the draw count is read by the
-- device from a buffer during execution. The command will read an
-- unsigned 32-bit integer from countBuffer located at
-- countBufferOffset and use this as the draw count.
--
-- Valid Usage
--
--
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
--
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - If countBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - countBuffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - offset must be a multiple of 4
-- - countBufferOffset must be a multiple of
-- 4
-- - stride must be a multiple of 4 and
-- must be greater than or equal to
-- sizeof(VkDrawIndirectCommand)
-- - If maxDrawCount is greater than or equal to 1,
-- (stride × (maxDrawCount - 1) + offset +
-- sizeof(VkDrawIndirectCommand)) must be less
-- than or equal to the size of buffer
-- - If the drawIndirectFirstInstance feature is not enabled,
-- all the firstInstance members of the
-- VkDrawIndirectCommand structures accessed by this command
-- must be 0
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - If the count stored in countBuffer is equal to
-- 1, (offset +
-- sizeof(VkDrawIndirectCommand)) must be less
-- than or equal to the size of buffer
-- - If the count stored in countBuffer is greater than
-- 1, (stride × (drawCount - 1) +
-- offset + sizeof(VkDrawIndirectCommand))
-- must be less than or equal to the size of buffer
-- - The count stored in countBuffer must be less than
-- or equal to
-- VkPhysicalDeviceLimits::maxDrawIndirectCount
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - countBuffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - Each of buffer, commandBuffer, and
-- countBuffer must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdDrawIndirectCountAMD :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> ("countBuffer" ::: VkBuffer) -> ("countBufferOffset" ::: VkDeviceSize) -> ("maxDrawCount" ::: Word32) -> ("stride" ::: Word32) -> IO ()
-- | vkCmdDrawIndexedIndirectCountAMD - Perform an indexed indirect draw
-- with the draw count sourced from a buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - buffer is the buffer containing draw parameters.
-- - offset is the byte offset into buffer where
-- parameters begin.
-- - countBuffer is the buffer containing the draw count.
-- - countBufferOffset is the byte offset into
-- countBuffer where the draw count begins.
-- - maxDrawCount specifies the maximum number of draws that
-- will be executed. The actual number of executed draw calls is the
-- minimum of the count specified in countBuffer and
-- maxDrawCount.
-- - stride is the byte stride between successive sets of draw
-- parameters.
--
--
-- Description
--
-- vkCmdDrawIndexedIndirectCountAMD behaves similarly to
-- vkCmdDrawIndexedIndirect except that the draw count is read by
-- the device from a buffer during execution. The command will read an
-- unsigned 32-bit integer from countBuffer located at
-- countBufferOffset and use this as the draw count.
--
-- Valid Usage
--
--
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
--
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - If countBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - countBuffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - offset must be a multiple of 4
-- - countBufferOffset must be a multiple of
-- 4
-- - stride must be a multiple of 4 and
-- must be greater than or equal to
-- sizeof(VkDrawIndirectCommand)
-- - If maxDrawCount is greater than or equal to 1,
-- (stride × (maxDrawCount - 1) + offset +
-- sizeof(VkDrawIndirectCommand)) must be less
-- than or equal to the size of buffer
-- - If the drawIndirectFirstInstance feature is not enabled,
-- all the firstInstance members of the
-- VkDrawIndexedIndirectCommand structures accessed by this
-- command must be 0
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - If count stored in countBuffer is equal to 1,
-- (offset +
-- sizeof(VkDrawIndexedIndirectCommand)) must be
-- less than or equal to the size of buffer
-- - If count stored in countBuffer is greater than
-- 1, (stride × (drawCount - 1) +
-- offset +
-- sizeof(VkDrawIndexedIndirectCommand)) must be
-- less than or equal to the size of buffer
-- - drawCount must be less than or equal to
-- VkPhysicalDeviceLimits::maxDrawIndirectCount
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - countBuffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - Each of buffer, commandBuffer, and
-- countBuffer must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdDrawIndexedIndirectCountAMD :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> ("countBuffer" ::: VkBuffer) -> ("countBufferOffset" ::: VkDeviceSize) -> ("maxDrawCount" ::: Word32) -> ("stride" ::: Word32) -> IO ()
module Graphics.Vulkan.Extensions.VK_AMD_buffer_marker
-- | vkCmdWriteBufferMarkerAMD - Execute a pipelined write of a marker
-- value into a buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - pipelineStage is one of the
-- VkPipelineStageFlagBits values, specifying the pipeline stage
-- whose completion triggers the marker write.
-- - dstBuffer is the buffer where the marker will be written
-- to.
-- - dstOffset is the byte offset into the buffer where the
-- marker will be written to.
-- - marker is the 32-bit value of the marker.
--
--
-- Description
--
-- The command will write the 32-bit marker value into the buffer only
-- after all preceding commands have finished executing up to at least
-- the specified pipeline stage. This includes the completion of other
-- preceding vkCmdWriteBufferMarkerAMD commands so long as their
-- specified pipeline stages occur either at the same time or earlier
-- than this command’s specified pipelineStage.
--
-- While consecutive buffer marker writes with the same
-- pipelineStage parameter are implicitly complete in submission
-- order, memory and execution dependencies between buffer marker writes
-- and other operations must still be explicitly ordered using
-- synchronization commands. The access scope for buffer marker writes
-- falls under the VK_ACCESS_TRANSFER_WRITE_BIT, and the
-- pipeline stages for identifying the synchronization scope must
-- include both pipelineStage and
-- VK_PIPELINE_STAGE_TRANSFER_BIT.
--
-- Note
--
-- Similar to vkCmdWriteTimestamp, if an implementation is
-- unable to write a marker at any specific pipeline stage, it may
-- instead do so at any logically later stage.
--
-- Note
--
-- Implementations may only support a limited number of pipelined
-- marker write operations in flight at a given time, thus excessive
-- number of marker write operations may degrade command execution
-- performance.
--
-- Valid Usage
--
--
-- - dstOffset must be less than or equal to the size
-- of dstBuffer minus 4.
--
--
--
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstOffset must be a multiple of 4
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pipelineStage must be a valid
-- VkPipelineStageFlagBits value
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - Both of commandBuffer, and dstBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize,
-- VkPipelineStageFlagBits
vkCmdWriteBufferMarkerAMD :: ("commandBuffer" ::: VkCommandBuffer) -> ("pipelineStage" ::: VkPipelineStageFlagBits) -> ("dstBuffer" ::: VkBuffer) -> ("dstOffset" ::: VkDeviceSize) -> ("marker" ::: Word32) -> IO ()
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation
-- | VkMemoryDedicatedRequirements - Structure describing dedicated
-- allocation requirements of buffer and image resources
--
-- Description
--
-- If the VkMemoryDedicatedRequirements structure is included in
-- the pNext chain of the VkMemoryRequirements2 structure
-- passed as the pMemoryRequirements parameter of a
-- vkGetBufferMemoryRequirements2 call,
-- requiresDedicatedAllocation may be VK_TRUE
-- under one of the following conditions:
--
--
-- - The pNext chain of VkBufferCreateInfo for the
-- call to vkCreateBuffer used to create the buffer being
-- queried contained an instance of
-- VkExternalMemoryBufferCreateInfo, and any of the handle types
-- specified in
-- VkExternalMemoryBufferCreateInfo::handleTypes
-- requires dedicated allocation, as reported by
-- vkGetPhysicalDeviceExternalBufferProperties in
-- VkExternalBufferProperties::externalMemoryProperties::externalMemoryFeatures,
-- the requiresDedicatedAllocation field will be set to
-- VK_TRUE.
--
--
-- In all other cases, requiresDedicatedAllocation must
-- be set to VK_FALSE by the implementation whenever a
-- VkMemoryDedicatedRequirements structure is included in the
-- pNext chain of the VkMemoryRequirements2 structure
-- passed to a call to vkGetBufferMemoryRequirements2.
--
-- If the VkMemoryDedicatedRequirements structure is included in
-- the pNext chain of the VkMemoryRequirements2
-- structure passed as the pMemoryRequirements parameter of a
-- vkGetBufferMemoryRequirements2 call and
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT was set in
-- VkBufferCreateInfo::flags when buffer was
-- created then the implementation must set both
-- prefersDedicatedAllocation and
-- requiresDedicatedAllocation to VK_FALSE.
--
-- If the VkMemoryDedicatedRequirements structure is included in
-- the pNext chain of the VkMemoryRequirements2
-- structure passed as the pMemoryRequirements parameter of a
-- vkGetImageMemoryRequirements2 call,
-- requiresDedicatedAllocation may be VK_TRUE
-- under one of the following conditions:
--
--
-- - The pNext chain of VkImageCreateInfo for the
-- call to vkCreateImage used to create the image being queried
-- contained an instance of VkExternalMemoryImageCreateInfo, and
-- any of the handle types specified in
-- VkExternalMemoryImageCreateInfo::handleTypes
-- requires dedicated allocation, as reported by
-- vkGetPhysicalDeviceImageFormatProperties2 in
-- VkExternalImageFormatProperties::externalMemoryProperties::externalMemoryFeatures,
-- the requiresDedicatedAllocation field will be set to
-- VK_TRUE.
--
--
-- In all other cases, requiresDedicatedAllocation must
-- be set to VK_FALSE by the implementation whenever a
-- VkMemoryDedicatedRequirements structure is included in the
-- pNext chain of the VkMemoryRequirements2 structure
-- passed to a call to vkGetImageMemoryRequirements2.
--
-- If the VkMemoryDedicatedRequirements structure is included in
-- the pNext chain of the VkMemoryRequirements2
-- structure passed as the pMemoryRequirements parameter of a
-- vkGetImageMemoryRequirements2 call and
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT was set in
-- VkImageCreateInfo::flags when image was
-- created then the implementation must set both
-- prefersDedicatedAllocation and
-- requiresDedicatedAllocation to VK_FALSE.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_DEDICATED_REQUIREMENTS
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkMemoryDedicatedRequirements
VkMemoryDedicatedRequirements :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkMemoryDedicatedRequirements
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryDedicatedRequirements] :: VkMemoryDedicatedRequirements -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryDedicatedRequirements] :: VkMemoryDedicatedRequirements -> Ptr ()
-- | prefersDedicatedAllocation specifies that the implementation
-- would prefer a dedicated allocation for this resource. The application
-- is still free to suballocate the resource but it may get better
-- performance if a dedicated allocation is used.
[$sel:vkPrefersDedicatedAllocation:VkMemoryDedicatedRequirements] :: VkMemoryDedicatedRequirements -> VkBool32
-- | requiresDedicatedAllocation specifies that a dedicated
-- allocation is required for this resource.
[$sel:vkRequiresDedicatedAllocation:VkMemoryDedicatedRequirements] :: VkMemoryDedicatedRequirements -> VkBool32
-- | VkMemoryDedicatedAllocateInfo - Specify a dedicated memory allocation
-- resource
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - If image is not VK_NULL_HANDLE,
-- VkMemoryAllocateInfo::allocationSize must
-- equal the VkMemoryRequirements::size of the
-- image
-- - If image is not VK_NULL_HANDLE, image
-- must have been created without
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT set in
-- VkImageCreateInfo::flags
-- - If buffer is not VK_NULL_HANDLE,
-- VkMemoryAllocateInfo::allocationSize must
-- equal the VkMemoryRequirements::size of the
-- buffer
-- - If buffer is not VK_NULL_HANDLE, buffer
-- must have been created without
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT set in
-- VkBufferCreateInfo::flags
-- - If image is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation with
-- handle type VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT, or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT, and the
-- external handle was created by the Vulkan API, then the memory being
-- imported must also be a dedicated image allocation and
-- image must be identical to the image associated with the
-- imported memory.
-- - If buffer is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation with
-- handle type VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT,
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT, or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT, and the
-- external handle was created by the Vulkan API, then the memory being
-- imported must also be a dedicated buffer allocation and
-- buffer must be identical to the buffer associated with the
-- imported memory.
-- - If image is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation with
-- handle type VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT, the
-- memory being imported must also be a dedicated image allocation
-- and image must be identical to the image associated with the
-- imported memory.
-- - If buffer is not VK_NULL_HANDLE and
-- VkMemoryAllocateInfo defines a memory import operation with
-- handle type VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT, the
-- memory being imported must also be a dedicated buffer
-- allocation and buffer must be identical to the buffer
-- associated with the imported memory.
-- - If image is not VK_NULL_HANDLE, image
-- must not have been created with
-- VK_IMAGE_CREATE_DISJOINT_BIT set in
-- VkImageCreateInfo::flags
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_DEDICATED_ALLOCATE_INFO
--
--
--
-- - If image is not VK_NULL_HANDLE, image
-- must be a valid VkImage handle
-- - If buffer is not VK_NULL_HANDLE, buffer
-- must be a valid VkBuffer handle
-- - Both of buffer, and image that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkBuffer, VkImage, VkStructureType
data VkMemoryDedicatedAllocateInfo
VkMemoryDedicatedAllocateInfo :: VkStructureType -> Ptr () -> VkImage -> VkBuffer -> VkMemoryDedicatedAllocateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryDedicatedAllocateInfo] :: VkMemoryDedicatedAllocateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryDedicatedAllocateInfo] :: VkMemoryDedicatedAllocateInfo -> Ptr ()
-- | image is VK_NULL_HANDLE or a handle of an image which
-- this memory will be bound to.
[$sel:vkImage:VkMemoryDedicatedAllocateInfo] :: VkMemoryDedicatedAllocateInfo -> VkImage
-- | buffer is VK_NULL_HANDLE or a handle of a buffer which
-- this memory will be bound to.
[$sel:vkBuffer:VkMemoryDedicatedAllocateInfo] :: VkMemoryDedicatedAllocateInfo -> VkBuffer
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedAllocateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedAllocateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedRequirements
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedRequirements
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedAllocateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_dedicated_allocation.VkMemoryDedicatedRequirements
module Graphics.Vulkan.Extensions.VK_KHR_dedicated_allocation
type VkMemoryDedicatedRequirementsKHR = VkMemoryDedicatedRequirements
type VkMemoryDedicatedAllocateInfoKHR = VkMemoryDedicatedAllocateInfo
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2
-- | vkBindBufferMemory2 - Bind device memory to buffer objects
--
-- Parameters
--
--
-- - device is the logical device that owns the buffers and
-- memory.
--
--
--
-- - bindInfoCount is the number of elements in
-- pBindInfos.
-- - pBindInfos is a pointer to an array of structures of type
-- VkBindBufferMemoryInfo, describing buffers and memory to
-- bind.
--
--
-- Description
--
-- On some implementations, it may be more efficient to batch
-- memory bindings into a single command.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pBindInfos must be a valid pointer to an array of
-- bindInfoCount valid VkBindBufferMemoryInfo
-- structures
-- - bindInfoCount must be greater than 0
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBindBufferMemoryInfo, VkDevice
vkBindBufferMemory2 :: ("device" ::: VkDevice) -> ("bindInfoCount" ::: Word32) -> ("pBindInfos" ::: Ptr VkBindBufferMemoryInfo) -> IO VkResult
-- | vkBindImageMemory2 - Bind device memory to image objects
--
-- Parameters
--
--
-- - device is the logical device that owns the images and
-- memory.
--
--
--
-- - bindInfoCount is the number of elements in
-- pBindInfos.
-- - pBindInfos is a pointer to an array of structures of type
-- VkBindImageMemoryInfo, describing images and memory to
-- bind.
--
--
-- Description
--
-- On some implementations, it may be more efficient to batch
-- memory bindings into a single command.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pBindInfos must be a valid pointer to an array of
-- bindInfoCount valid VkBindImageMemoryInfo
-- structures
-- - bindInfoCount must be greater than 0
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBindImageMemoryInfo, VkDevice
vkBindImageMemory2 :: ("device" ::: VkDevice) -> ("bindInfoCount" ::: Word32) -> ("pBindInfos" ::: Ptr VkBindImageMemoryInfo) -> IO VkResult
-- | VkBindBufferMemoryInfo - Structure specifying how to bind a buffer to
-- memory
--
-- Description
--
-- Valid Usage
--
--
-- - buffer must not already be backed by a memory
-- object
--
--
--
-- - buffer must not have been created with any sparse
-- memory binding flags
-- - memoryOffset must be less than the size of
-- memory
-- - If buffer was created with the
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT,
-- memoryOffset must be a multiple of
-- VkPhysicalDeviceLimits::minTexelBufferOffsetAlignment
-- - If buffer was created with the
-- VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, memoryOffset
-- must be a multiple of
-- VkPhysicalDeviceLimits::minUniformBufferOffsetAlignment
-- - If buffer was created with the
-- VK_BUFFER_USAGE_STORAGE_BUFFER_BIT, memoryOffset
-- must be a multiple of
-- VkPhysicalDeviceLimits::minStorageBufferOffsetAlignment
-- - memory must have been allocated using one of the
-- memory types allowed in the memoryTypeBits member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- - memoryOffset must be an integer multiple of the
-- alignment member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- - The size member of the VkMemoryRequirements
-- structure returned from a call to
-- vkGetBufferMemoryRequirements with buffer
-- must be less than or equal to the size of memory minus
-- memoryOffset
-- - If buffer requires a dedicated allocation(as reported by
-- vkGetBufferMemoryRequirements2 in
-- VkMemoryDedicatedRequirements::requiresDedicatedAllocation for
-- buffer), memory must have been created with
-- VkMemoryDedicatedAllocateInfo::buffer equal to
-- buffer and memoryOffset must be zero
-- - If the VkMemoryAllocateInfo provided when memory
-- was allocated included an instance of
-- VkMemoryDedicatedAllocateInfo in its pNext chain, and
-- VkMemoryDedicatedAllocateInfo::buffer was not
-- VK_NULL_HANDLE, then buffer must equal
-- VkMemoryDedicatedAllocateInfo::buffer and
-- memoryOffset must be zero.
-- - If buffer was created with
-- VkDedicatedAllocationBufferCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE, memory must have been
-- created with
-- VkDedicatedAllocationMemoryAllocateInfoNV::buffer
-- equal to buffer and memoryOffset must be
-- zero
-- - If the pNext chain includes
-- VkBindBufferMemoryDeviceGroupInfo, all instances of
-- memory specified by
-- VkBindBufferMemoryDeviceGroupInfo::pDeviceIndices
-- must have been allocated
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_BUFFER_MEMORY_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of VkBindBufferMemoryDeviceGroupInfo
-- - buffer must be a valid VkBuffer
-- handle
-- - memory must be a valid VkDeviceMemory
-- handle
-- - Both of buffer, and memory must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkBuffer, VkDeviceMemory, VkDeviceSize,
-- VkStructureType, vkBindBufferMemory2,
-- vkBindBufferMemory2KHR
data VkBindBufferMemoryInfo
VkBindBufferMemoryInfo :: VkStructureType -> Ptr () -> VkBuffer -> VkDeviceMemory -> VkDeviceSize -> VkBindBufferMemoryInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBindBufferMemoryInfo] :: VkBindBufferMemoryInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBindBufferMemoryInfo] :: VkBindBufferMemoryInfo -> Ptr ()
-- | buffer is the buffer to be attached to memory.
[$sel:vkBuffer:VkBindBufferMemoryInfo] :: VkBindBufferMemoryInfo -> VkBuffer
-- | memory is a VkDeviceMemory object describing the
-- device memory to attach.
[$sel:vkMemory:VkBindBufferMemoryInfo] :: VkBindBufferMemoryInfo -> VkDeviceMemory
-- | memoryOffset is the start offset of the region of
-- memory which is to be bound to the buffer. The number of
-- bytes returned in the VkMemoryRequirements::size
-- member in memory, starting from memoryOffset bytes,
-- will be bound to the specified buffer.
[$sel:vkMemoryOffset:VkBindBufferMemoryInfo] :: VkBindBufferMemoryInfo -> VkDeviceSize
-- | VkBindImageMemoryInfo - Structure specifying how to bind an image to
-- memory
--
-- Description
--
-- Valid Usage
--
--
-- - image must not already be backed by a memory
-- object
--
--
--
-- - image must not have been created with any sparse
-- memory binding flags
-- - memoryOffset must be less than the size of
-- memory
-- - If the pNext chain does not include an instance of the
-- VkBindImagePlaneMemoryInfo structure, memory
-- must have been allocated using one of the memory types allowed
-- in the memoryTypeBits member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with image
-- - If the pNext chain does not include an instance of the
-- VkBindImagePlaneMemoryInfo structure, memoryOffset
-- must be an integer multiple of the alignment member of
-- the VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with image
-- - If the pNext chain does not include an instance of the
-- VkBindImagePlaneMemoryInfo structure, the difference of the
-- size of memory and memoryOffset must be
-- greater than or equal to the size member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with the same image
-- - If the pNext chain includes an instance of the
-- VkBindImagePlaneMemoryInfo structure, image
-- must have been created with the
-- VK_IMAGE_CREATE_DISJOINT_BIT bit set.
-- - If the pNext chain includes an instance of the
-- VkBindImagePlaneMemoryInfo structure, memory
-- must have been allocated using one of the memory types allowed
-- in the memoryTypeBits member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with image and the
-- correct planeAspect for this plane in the
-- VkImagePlaneMemoryRequirementsInfo structure attached to the
-- VkImageMemoryRequirementsInfo2’s pNext chain
-- - If the pNext chain includes an instance of the
-- VkBindImagePlaneMemoryInfo structure, memoryOffset
-- must be an integer multiple of the alignment member of
-- the VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with image and the
-- correct planeAspect for this plane in the
-- VkImagePlaneMemoryRequirementsInfo structure attached to the
-- VkImageMemoryRequirementsInfo2’s pNext chain
-- - If the pNext chain includes an instance of the
-- VkBindImagePlaneMemoryInfo structure, the difference of the
-- size of memory and memoryOffset must be
-- greater than or equal to the size member of the
-- VkMemoryRequirements structure returned from a call to
-- vkGetImageMemoryRequirements2 with the same image and
-- the correct planeAspect for this plane in the
-- VkImagePlaneMemoryRequirementsInfo structure attached to the
-- VkImageMemoryRequirementsInfo2’s pNext chain
-- - If image requires a dedicated allocation (as reported by
-- vkGetImageMemoryRequirements2 in
-- VkMemoryDedicatedRequirements::requiresDedicatedAllocation for
-- image), memory must have been created with
-- VkMemoryDedicatedAllocateInfo::image equal to
-- image and memoryOffset must be zero
-- - If the VkMemoryAllocateInfo provided when memory
-- was allocated included an instance of
-- VkMemoryDedicatedAllocateInfo in its pNext chain, and
-- VkMemoryDedicatedAllocateInfo::image was not
-- VK_NULL_HANDLE, then image must equal
-- VkMemoryDedicatedAllocateInfo::image and
-- memoryOffset must be zero.
-- - If image was created with
-- VkDedicatedAllocationImageCreateInfoNV::dedicatedAllocation
-- equal to VK_TRUE, memory must have been
-- created with
-- VkDedicatedAllocationMemoryAllocateInfoNV::image equal
-- to image and memoryOffset must be zero
-- - If the pNext chain includes
-- VkBindImageMemoryDeviceGroupInfo, all instances of
-- memory specified by
-- VkBindImageMemoryDeviceGroupInfo::pDeviceIndices
-- must have been allocated
-- - If the pNext chain includes
-- VkBindImageMemoryDeviceGroupInfo, and
-- VkBindImageMemoryDeviceGroupInfo::splitInstanceBindRegionCount
-- is not zero, then image must have been created with
-- the VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT bit
-- set
-- - If the pNext chain includes
-- VkBindImageMemoryDeviceGroupInfo, all elements of
-- VkBindImageMemoryDeviceGroupInfo::pSplitInstanceBindRegions
-- must be valid rectangles contained within the dimensions of
-- image
-- - If the pNext chain includes
-- VkBindImageMemoryDeviceGroupInfo, the union of the areas of all
-- elements of
-- VkBindImageMemoryDeviceGroupInfo::pSplitInstanceBindRegions
-- that correspond to the same instance of image must
-- cover the entire image.
-- - If image was created with a valid swapchain handle in
-- VkImageSwapchainCreateInfoKHR::swapchain, then the
-- pNext chain must include a valid instance of
-- VkBindImageMemorySwapchainInfoKHR
-- - If the pNext chain includes an instance of
-- VkBindImageMemorySwapchainInfoKHR, memory must
-- be VK_NULL_HANDLE
-- - If the pNext chain does not include an instance of
-- VkBindImageMemorySwapchainInfoKHR, memory must
-- be a valid VkDeviceMemory handle
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkBindImageMemoryDeviceGroupInfo,
-- VkBindImageMemorySwapchainInfoKHR, or
-- VkBindImagePlaneMemoryInfo
-- - Each sType member in the pNext chain must
-- be unique
-- - image must be a valid VkImage handle
-- - Both of image, and memory that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkDeviceMemory, VkDeviceSize, VkImage,
-- VkStructureType, vkBindImageMemory2,
-- vkBindImageMemory2KHR
data VkBindImageMemoryInfo
VkBindImageMemoryInfo :: VkStructureType -> Ptr () -> VkImage -> VkDeviceMemory -> VkDeviceSize -> VkBindImageMemoryInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBindImageMemoryInfo] :: VkBindImageMemoryInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBindImageMemoryInfo] :: VkBindImageMemoryInfo -> Ptr ()
-- | image is the image to be attached to memory.
[$sel:vkImage:VkBindImageMemoryInfo] :: VkBindImageMemoryInfo -> VkImage
-- | memory is a VkDeviceMemory object describing the
-- device memory to attach.
[$sel:vkMemory:VkBindImageMemoryInfo] :: VkBindImageMemoryInfo -> VkDeviceMemory
-- | memoryOffset is the start offset of the region of
-- memory which is to be bound to the image. The number of bytes
-- returned in the VkMemoryRequirements::size member in
-- memory, starting from memoryOffset bytes, will be
-- bound to the specified image.
[$sel:vkMemoryOffset:VkBindImageMemoryInfo] :: VkBindImageMemoryInfo -> VkDeviceSize
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindImageMemoryInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindImageMemoryInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindBufferMemoryInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindBufferMemoryInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindImageMemoryInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_bind_memory2.VkBindBufferMemoryInfo
module Graphics.Vulkan.Extensions.VK_KHR_bind_memory2
vkBindBufferMemory2KHR :: ("device" ::: VkDevice) -> ("bindInfoCount" ::: Word32) -> ("pBindInfos" ::: Ptr VkBindBufferMemoryInfo) -> IO VkResult
vkBindImageMemory2KHR :: ("device" ::: VkDevice) -> ("bindInfoCount" ::: Word32) -> ("pBindInfos" ::: Ptr VkBindImageMemoryInfo) -> IO VkResult
type VkBindBufferMemoryInfoKHR = VkBindBufferMemoryInfo
type VkBindImageMemoryInfoKHR = VkBindImageMemoryInfo
module Graphics.Vulkan.Core10.SparseResourceMemoryManagement
-- | VkImageAspectFlagBits - Bitmask specifying which aspects of an image
-- are included in a view
--
-- See Also
--
-- VkBindImagePlaneMemoryInfo, VkImageAspectFlags,
-- VkImagePlaneMemoryRequirementsInfo
newtype VkImageAspectFlagBits
VkImageAspectFlagBits :: VkFlags -> VkImageAspectFlagBits
-- | VK_IMAGE_ASPECT_COLOR_BIT specifies the color aspect.
-- | VK_IMAGE_ASPECT_DEPTH_BIT specifies the depth aspect.
-- | VK_IMAGE_ASPECT_STENCIL_BIT specifies the stencil aspect.
-- | VK_IMAGE_ASPECT_METADATA_BIT specifies the metadata aspect,
-- used for sparse sparse resource operations.
-- | VkSparseMemoryBindFlagBits - Bitmask specifying usage of a sparse
-- memory binding operation
--
-- See Also
--
-- VkSparseMemoryBindFlags
newtype VkSparseMemoryBindFlagBits
VkSparseMemoryBindFlagBits :: VkFlags -> VkSparseMemoryBindFlagBits
-- | VK_SPARSE_MEMORY_BIND_METADATA_BIT specifies that the memory
-- being bound is only for the metadata aspect.
-- | VkSparseImageFormatFlagBits - Bitmask specifying additional
-- information about a sparse image resource
--
-- See Also
--
-- VkSparseImageFormatFlags
newtype VkSparseImageFormatFlagBits
VkSparseImageFormatFlagBits :: VkFlags -> VkSparseImageFormatFlagBits
-- | VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT specifies that the
-- image uses a single mip tail region for all array layers.
-- | VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT specifies that
-- the first mip level whose dimensions are not integer multiples of the
-- corresponding dimensions of the sparse image block begins the mip tail
-- region.
-- | VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT specifies
-- that the image uses non-standard sparse image block dimensions, and
-- the imageGranularity values do not match the standard sparse
-- image block dimensions for the given format.
-- | vkGetImageSparseMemoryRequirements - Query the memory requirements for
-- a sparse image
--
-- Parameters
--
--
-- - device is the logical device that owns the image.
--
--
--
-- - image is the VkImage object to get the memory
-- requirements for.
-- - pSparseMemoryRequirementCount is a pointer to an integer
-- related to the number of sparse memory requirements available or
-- queried, as described below.
-- - pSparseMemoryRequirements is either NULL or a
-- pointer to an array of VkSparseImageMemoryRequirements
-- structures.
--
--
-- Description
--
-- If pSparseMemoryRequirements is NULL, then the
-- number of sparse memory requirements available is returned in
-- pSparseMemoryRequirementCount. Otherwise,
-- pSparseMemoryRequirementCount must point to a variable
-- set by the user to the number of elements in the
-- pSparseMemoryRequirements array, and on return the variable
-- is overwritten with the number of structures actually written to
-- pSparseMemoryRequirements. If
-- pSparseMemoryRequirementCount is less than the number of
-- sparse memory requirements available, at most
-- pSparseMemoryRequirementCount structures will be written.
--
-- If the image was not created with
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT then
-- pSparseMemoryRequirementCount will be set to zero and
-- pSparseMemoryRequirements will not be written to.
--
-- Note
--
-- It is legal for an implementation to report a larger value in
-- VkMemoryRequirements::size than would be obtained by
-- adding together memory sizes for all
-- VkSparseImageMemoryRequirements returned by
-- vkGetImageSparseMemoryRequirements. This may occur
-- when the implementation requires unused padding in the address range
-- describing the resource.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - image must be a valid VkImage handle
-- - pSparseMemoryRequirementCount must be a valid
-- pointer to a uint32_t value
-- - If the value referenced by pSparseMemoryRequirementCount
-- is not 0, and pSparseMemoryRequirements is not
-- NULL, pSparseMemoryRequirements must be a
-- valid pointer to an array of pSparseMemoryRequirementCount
-- VkSparseImageMemoryRequirements structures
-- - image must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkDevice, VkImage,
-- VkSparseImageMemoryRequirements
vkGetImageSparseMemoryRequirements :: ("device" ::: VkDevice) -> ("image" ::: VkImage) -> ("pSparseMemoryRequirementCount" ::: Ptr Word32) -> ("pSparseMemoryRequirements" ::: Ptr VkSparseImageMemoryRequirements) -> IO ()
-- | vkGetPhysicalDeviceSparseImageFormatProperties - Retrieve properties
-- of an image format applied to sparse images
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the sparse image capabilities.
--
--
--
-- - format is the image format.
-- - type is the dimensionality of image.
-- - samples is the number of samples per texel as defined in
-- VkSampleCountFlagBits.
-- - usage is a bitmask describing the intended usage of the
-- image.
-- - tiling is the tiling arrangement of the data elements in
-- memory.
-- - pPropertyCount is a pointer to an integer related to the
-- number of sparse format properties available or queried, as described
-- below.
-- - pProperties is either NULL or a pointer to an
-- array of VkSparseImageFormatProperties structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of sparse
-- format properties available is returned in pPropertyCount.
-- Otherwise, pPropertyCount must point to a variable set
-- by the user to the number of elements in the pProperties
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pProperties. If
-- pPropertyCount is less than the number of sparse format
-- properties available, at most pPropertyCount structures will
-- be written.
--
-- If VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT is not supported for
-- the given arguments, pPropertyCount will be set to zero upon
-- return, and no data will be written to pProperties.
--
-- Multiple aspects are returned for depth/stencil images that are
-- implemented as separate planes by the implementation. The depth and
-- stencil data planes each have unique
-- VkSparseImageFormatProperties data.
--
-- Depth/stencil images with depth and stencil data interleaved into a
-- single plane will return a single
-- VkSparseImageFormatProperties structure with the
-- aspectMask set to VK_IMAGE_ASPECT_DEPTH_BIT |
-- VK_IMAGE_ASPECT_STENCIL_BIT.
--
-- Valid Usage
--
--
-- - samples must be a bit value that is set in
-- VkImageFormatProperties::sampleCounts returned by
-- vkGetPhysicalDeviceImageFormatProperties with
-- format, type, tiling, and usage
-- equal to those in this command and flags equal to the value
-- that is set in VkImageCreateInfo::flags when the
-- image is created
--
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - format must be a valid VkFormat value
-- - type must be a valid VkImageType value
-- - samples must be a valid
-- VkSampleCountFlagBits value
-- - usage must be a valid combination of
-- VkImageUsageFlagBits values
-- - usage must not be 0
-- - tiling must be a valid VkImageTiling
-- value
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkSparseImageFormatProperties
-- structures
--
--
-- See Also
--
-- VkFormat, VkImageTiling, VkImageType,
-- VkImageUsageFlags, VkPhysicalDevice,
-- VkSampleCountFlagBits, VkSparseImageFormatProperties
vkGetPhysicalDeviceSparseImageFormatProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("type" ::: VkImageType) -> ("samples" ::: VkSampleCountFlagBits) -> ("usage" ::: VkImageUsageFlags) -> ("tiling" ::: VkImageTiling) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkSparseImageFormatProperties) -> IO ()
-- | vkQueueBindSparse - Bind device memory to a sparse resource object
--
-- Parameters
--
--
-- - queue is the queue that the sparse binding operations
-- will be submitted to.
--
--
--
-- - bindInfoCount is the number of elements in the
-- pBindInfo array.
-- - pBindInfo is an array of VkBindSparseInfo
-- structures, each specifying a sparse binding submission batch.
-- - fence is an optional handle to a fence to be
-- signaled. If fence is not VK_NULL_HANDLE, it defines a
-- fence signal operation.
--
--
-- Description
--
-- vkQueueBindSparse is a queue submission command, with
-- each batch defined by an element of pBindInfo as an instance
-- of the VkBindSparseInfo structure. Batches begin execution in
-- the order they appear in pBindInfo, but may complete
-- out of order.
--
-- Within a batch, a given range of a resource must not be bound
-- more than once. Across batches, if a range is to be bound to one
-- allocation and offset and then to another allocation and offset, then
-- the application must guarantee (usually using semaphores) that
-- the binding operations are executed in the correct order, as well as
-- to order binding operations against the execution of command buffer
-- submissions.
--
-- As no operation to vkQueueBindSparse causes any pipeline stage
-- to access memory, synchronization primitives used in this command
-- effectively only define execution dependencies.
--
-- Additional information about fence and semaphore operation is
-- described in the synchronization chapter.
--
-- Valid Usage
--
--
--
--
-- - If fence is not VK_NULL_HANDLE, fence
-- must not be associated with any other queue command that has
-- not yet completed execution on that queue
-- - Each element of the pSignalSemaphores member of each
-- element of pBindInfo must be unsignaled when the
-- semaphore signal operation it defines is executed on the device
-- - When a semaphore unsignal operation defined by any element of the
-- pWaitSemaphores member of any element of pBindInfo
-- executes on queue, no other queue must be waiting on
-- the same semaphore.
-- - All elements of the pWaitSemaphores member of all
-- elements of pBindInfo must be semaphores that are
-- signaled, or have semaphore signal operations previously
-- submitted for execution.
--
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
--
-- - If bindInfoCount is not 0, pBindInfo
-- must be a valid pointer to an array of bindInfoCount
-- valid VkBindSparseInfo structures
-- - If fence is not VK_NULL_HANDLE, fence
-- must be a valid VkFence handle
-- - The queue must support sparse binding
-- operations
-- - Both of fence, and queue that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to queue must be externally
-- synchronized
--
--
--
-- - Host access to pBindInfo[].pWaitSemaphores[] must
-- be externally synchronized
-- - Host access to pBindInfo[].pSignalSemaphores[]
-- must be externally synchronized
-- - Host access to pBindInfo[].pBufferBinds[].buffer
-- must be externally synchronized
-- - Host access to pBindInfo[].pImageOpaqueBinds[].image
-- must be externally synchronized
-- - Host access to pBindInfo[].pImageBinds[].image
-- must be externally synchronized
-- - Host access to fence must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | SPARSE_BINDING | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBindSparseInfo, VkFence, VkQueue
vkQueueBindSparse :: ("queue" ::: VkQueue) -> ("bindInfoCount" ::: Word32) -> ("pBindInfo" ::: Ptr VkBindSparseInfo) -> ("fence" ::: VkFence) -> IO VkResult
-- | VkOffset3D - Structure specifying a three-dimensional offset
--
-- Description
--
-- See Also
--
-- VkBufferImageCopy, VkImageBlit, VkImageCopy,
-- VkImageResolve, VkSparseImageMemoryBind
data VkOffset3D
VkOffset3D :: Int32 -> Int32 -> Int32 -> VkOffset3D
-- | x is the x offset.
[$sel:vkX:VkOffset3D] :: VkOffset3D -> Int32
-- | y is the y offset.
[$sel:vkY:VkOffset3D] :: VkOffset3D -> Int32
-- | z is the z offset.
[$sel:vkZ:VkOffset3D] :: VkOffset3D -> Int32
-- | VkSparseImageFormatProperties - Structure specifying sparse image
-- format properties
--
-- Description
--
-- See Also
--
-- VkExtent3D, VkImageAspectFlags,
-- VkSparseImageFormatFlags,
-- VkSparseImageFormatProperties2,
-- VkSparseImageMemoryRequirements,
-- vkGetPhysicalDeviceSparseImageFormatProperties
data VkSparseImageFormatProperties
VkSparseImageFormatProperties :: VkImageAspectFlags -> VkExtent3D -> VkSparseImageFormatFlags -> VkSparseImageFormatProperties
-- | aspectMask is a bitmask VkImageAspectFlagBits
-- specifying which aspects of the image the properties apply to.
[$sel:vkAspectMask:VkSparseImageFormatProperties] :: VkSparseImageFormatProperties -> VkImageAspectFlags
-- | imageGranularity is the width, height, and depth of the
-- sparse image block in texels or compressed texel blocks.
[$sel:vkImageGranularity:VkSparseImageFormatProperties] :: VkSparseImageFormatProperties -> VkExtent3D
-- | flags is a bitmask of VkSparseImageFormatFlagBits
-- specifying additional information about the sparse resource.
[$sel:vkFlags:VkSparseImageFormatProperties] :: VkSparseImageFormatProperties -> VkSparseImageFormatFlags
-- | VkSparseImageMemoryRequirements - Structure specifying sparse image
-- memory requirements
--
-- Members
--
--
-- - formatProperties.aspectMask is the set of aspects of the
-- image that this sparse memory requirement applies to. This will
-- usually have a single aspect specified. However, depth/stencil images
-- may have depth and stencil data interleaved in the same sparse
-- block, in which case both VK_IMAGE_ASPECT_DEPTH_BIT and
-- VK_IMAGE_ASPECT_STENCIL_BIT would be present.
--
--
--
-- - formatProperties.imageGranularity describes the
-- dimensions of a single bindable sparse image block in texel units. For
-- aspect VK_IMAGE_ASPECT_METADATA_BIT, all dimensions will be
-- zero. All metadata is located in the mip tail region.
-- - formatProperties.flags is a bitmask of
-- VkSparseImageFormatFlagBits:
- If
-- VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT is set the image
-- uses a single mip tail region for all array layers.
- If
-- VK_SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT is set the
-- dimensions of mip levels must be integer multiples of the
-- corresponding dimensions of the sparse image block for levels not
-- located in the mip tail.
- If
-- VK_SPARSE_IMAGE_FORMAT_NONSTANDARD_BLOCK_SIZE_BIT is set the
-- image uses non-standard sparse image block dimensions. The
-- formatProperties.imageGranularity values do not match the
-- standard sparse image block dimension corresponding to the image’s
-- format.
-- - imageMipTailFirstLod is the first mip level at which
-- image subresources are included in the mip tail region.
-- - imageMipTailSize is the memory size (in bytes) of the mip
-- tail region. If formatProperties.flags contains
-- VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT, this is the size
-- of the whole mip tail, otherwise this is the size of the mip tail of a
-- single array layer. This value is guaranteed to be a multiple of the
-- sparse block size in bytes.
-- - imageMipTailOffset is the opaque memory offset used with
-- VkSparseImageOpaqueMemoryBindInfo to bind the mip tail
-- region(s).
-- - imageMipTailStride is the offset stride between each
-- array-layer’s mip tail, if formatProperties.flags does not
-- contain VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT (otherwise
-- the value is undefined).
--
--
-- Description
--
-- See Also
--
-- VkDeviceSize, VkSparseImageFormatProperties,
-- VkSparseImageMemoryRequirements2,
-- vkGetImageSparseMemoryRequirements
data VkSparseImageMemoryRequirements
VkSparseImageMemoryRequirements :: VkSparseImageFormatProperties -> Word32 -> VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkSparseImageMemoryRequirements
[$sel:vkFormatProperties:VkSparseImageMemoryRequirements] :: VkSparseImageMemoryRequirements -> VkSparseImageFormatProperties
[$sel:vkImageMipTailFirstLod:VkSparseImageMemoryRequirements] :: VkSparseImageMemoryRequirements -> Word32
[$sel:vkImageMipTailSize:VkSparseImageMemoryRequirements] :: VkSparseImageMemoryRequirements -> VkDeviceSize
[$sel:vkImageMipTailOffset:VkSparseImageMemoryRequirements] :: VkSparseImageMemoryRequirements -> VkDeviceSize
[$sel:vkImageMipTailStride:VkSparseImageMemoryRequirements] :: VkSparseImageMemoryRequirements -> VkDeviceSize
-- | VkImageSubresource - Structure specifying a image subresource
--
-- Description
--
-- Valid Usage (Implicit)
--
--
--
--
-- - aspectMask must not be 0
--
--
-- See Also
--
-- VkImageAspectFlags, VkSparseImageMemoryBind,
-- vkGetImageSubresourceLayout
data VkImageSubresource
VkImageSubresource :: VkImageAspectFlags -> Word32 -> Word32 -> VkImageSubresource
-- | aspectMask is a VkImageAspectFlags selecting the image
-- aspect.
[$sel:vkAspectMask:VkImageSubresource] :: VkImageSubresource -> VkImageAspectFlags
-- | mipLevel selects the mipmap level.
[$sel:vkMipLevel:VkImageSubresource] :: VkImageSubresource -> Word32
-- | arrayLayer selects the array layer.
[$sel:vkArrayLayer:VkImageSubresource] :: VkImageSubresource -> Word32
-- | VkSparseMemoryBind - Structure specifying a sparse memory bind
-- operation
--
-- Description
--
-- The binding range [resourceOffset,
-- resourceOffset + size) has different constraints
-- based on flags. If flags contains
-- VK_SPARSE_MEMORY_BIND_METADATA_BIT, the binding range
-- must be within the mip tail region of the metadata aspect. This
-- metadata region is defined by:
--
--
-- - metadataRegion = [base, base + imageMipTailSize)
-- - base = imageMipTailOffset + imageMipTailStride ×
-- n
--
--
-- and imageMipTailOffset, imageMipTailSize, and
-- imageMipTailStride values are from the
-- VkSparseImageMemoryRequirements corresponding to the metadata
-- aspect of the image, and n is a valid array layer index for the image,
--
-- imageMipTailStride is considered to be zero for aspects where
-- VkSparseImageMemoryRequirements::formatProperties.flags
-- contains VK_SPARSE_IMAGE_FORMAT_SINGLE_MIPTAIL_BIT.
--
-- If flags does not contain
-- VK_SPARSE_MEMORY_BIND_METADATA_BIT, the binding range
-- must be within the range
-- [0,VkMemoryRequirements::size).
--
-- Valid Usage
--
--
--
--
-- - If memory is not VK_NULL_HANDLE, memory
-- must not have been created with a memory type that reports
-- VK_MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT bit set
-- - size must be greater than 0
-- - resourceOffset must be less than the size of the
-- resource
-- - size must be less than or equal to the size of the
-- resource minus resourceOffset
-- - memoryOffset must be less than the size of
-- memory
-- - size must be less than or equal to the size of
-- memory minus memoryOffset
--
--
-- Valid Usage (Implicit)
--
--
-- - If memory is not VK_NULL_HANDLE, memory
-- must be a valid VkDeviceMemory handle
--
--
--
--
-- See Also
--
-- VkDeviceMemory, VkDeviceSize,
-- VkSparseBufferMemoryBindInfo,
-- VkSparseImageOpaqueMemoryBindInfo,
-- VkSparseMemoryBindFlags
data VkSparseMemoryBind
VkSparseMemoryBind :: VkDeviceSize -> VkDeviceSize -> VkDeviceMemory -> VkDeviceSize -> VkSparseMemoryBindFlags -> VkSparseMemoryBind
-- | resourceOffset is the offset into the resource.
[$sel:vkResourceOffset:VkSparseMemoryBind] :: VkSparseMemoryBind -> VkDeviceSize
-- | size is the size of the memory region to be bound.
[$sel:vkSize:VkSparseMemoryBind] :: VkSparseMemoryBind -> VkDeviceSize
-- | memory is the VkDeviceMemory object that the range
-- of the resource is bound to. If memory is
-- VK_NULL_HANDLE, the range is unbound.
[$sel:vkMemory:VkSparseMemoryBind] :: VkSparseMemoryBind -> VkDeviceMemory
-- | memoryOffset is the offset into the VkDeviceMemory
-- object to bind the resource range to. If memory is
-- VK_NULL_HANDLE, this value is ignored.
[$sel:vkMemoryOffset:VkSparseMemoryBind] :: VkSparseMemoryBind -> VkDeviceSize
-- | flags is a bitmask of VkSparseMemoryBindFlagBits
-- specifying usage of the binding operation.
[$sel:vkFlags:VkSparseMemoryBind] :: VkSparseMemoryBind -> VkSparseMemoryBindFlags
-- | VkSparseImageMemoryBind - Structure specifying sparse image memory
-- bind
--
-- Description
--
-- Valid Usage
--
--
-- - If the sparse aliased residency feature is not enabled, and
-- if any other resources are bound to ranges of memory, the
-- range of memory being bound must not overlap with
-- those bound ranges
--
--
--
-- - memory and memoryOffset must match the
-- memory requirements of the calling command’s image, as
-- described in section
-- {html_spec_relative}#resources-association
-- - subresource must be a valid image subresource for
-- image (see
-- {html_spec_relative}#resources-image-views)
-- - offset.x must be a multiple of the sparse image
-- block width
-- (VkSparseImageFormatProperties::imageGranularity.width)
-- of the image
-- - extent.width must either be a multiple of the
-- sparse image block width of the image, or else (extent.width
-- + offset.x) must equal the width of the image
-- subresource
-- - offset.y must be a multiple of the sparse image
-- block height
-- (VkSparseImageFormatProperties::imageGranularity.height)
-- of the image
-- - extent.height must either be a multiple of the
-- sparse image block height of the image, or else
-- (extent.height + offset.y) must equal the
-- height of the image subresource
-- - offset.z must be a multiple of the sparse image
-- block depth
-- (VkSparseImageFormatProperties::imageGranularity.depth)
-- of the image
-- - extent.depth must either be a multiple of the
-- sparse image block depth of the image, or else (extent.depth
-- + offset.z) must equal the depth of the image
-- subresource
--
--
-- Valid Usage (Implicit)
--
--
-- - subresource must be a valid
-- VkImageSubresource structure
--
--
--
--
-- See Also
--
-- VkDeviceMemory, VkDeviceSize, VkExtent3D,
-- VkImageSubresource, VkOffset3D,
-- VkSparseImageMemoryBindInfo, VkSparseMemoryBindFlags
data VkSparseImageMemoryBind
VkSparseImageMemoryBind :: VkImageSubresource -> VkOffset3D -> VkExtent3D -> VkDeviceMemory -> VkDeviceSize -> VkSparseMemoryBindFlags -> VkSparseImageMemoryBind
-- | subresource is the aspectMask and region of interest in the
-- image.
[$sel:vkSubresource:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkImageSubresource
-- | offset are the coordinates of the first texel within the
-- image subresource to bind.
[$sel:vkOffset:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkOffset3D
-- | extent is the size in texels of the region within the image
-- subresource to bind. The extent must be a multiple of the
-- sparse image block dimensions, except when binding sparse image blocks
-- along the edge of an image subresource it can instead be such
-- that any coordinate of offset + extent equals the
-- corresponding dimensions of the image subresource.
[$sel:vkExtent:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkExtent3D
-- | memory is the VkDeviceMemory object that the sparse
-- image blocks of the image are bound to. If memory is
-- VK_NULL_HANDLE, the sparse image blocks are unbound.
[$sel:vkMemory:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkDeviceMemory
-- | memoryOffset is an offset into VkDeviceMemory
-- object. If memory is VK_NULL_HANDLE, this value is
-- ignored.
[$sel:vkMemoryOffset:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkDeviceSize
-- | flags are sparse memory binding flags.
[$sel:vkFlags:VkSparseImageMemoryBind] :: VkSparseImageMemoryBind -> VkSparseMemoryBindFlags
-- | VkSparseBufferMemoryBindInfo - Structure specifying a sparse buffer
-- memory bind operation
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - buffer must be a valid VkBuffer
-- handle
--
--
--
-- - pBinds must be a valid pointer to an array of
-- bindCount valid VkSparseMemoryBind structures
-- - bindCount must be greater than 0
--
--
-- See Also
--
-- VkBindSparseInfo, VkBuffer, VkSparseMemoryBind
data VkSparseBufferMemoryBindInfo
VkSparseBufferMemoryBindInfo :: VkBuffer -> Word32 -> Ptr VkSparseMemoryBind -> VkSparseBufferMemoryBindInfo
-- | buffer is the VkBuffer object to be bound.
[$sel:vkBuffer:VkSparseBufferMemoryBindInfo] :: VkSparseBufferMemoryBindInfo -> VkBuffer
-- | bindCount is the number of VkSparseMemoryBind
-- structures in the pBinds array.
[$sel:vkBindCount:VkSparseBufferMemoryBindInfo] :: VkSparseBufferMemoryBindInfo -> Word32
-- | pBinds is a pointer to array of VkSparseMemoryBind
-- structures.
[$sel:vkPBinds:VkSparseBufferMemoryBindInfo] :: VkSparseBufferMemoryBindInfo -> Ptr VkSparseMemoryBind
-- | VkSparseImageOpaqueMemoryBindInfo - Structure specifying sparse image
-- opaque memory bind info
--
-- Description
--
-- Valid Usage
--
--
-- - If the flags member of any element of pBinds
-- contains VK_SPARSE_MEMORY_BIND_METADATA_BIT, the binding
-- range defined must be within the mip tail region of the
-- metadata aspect of image
--
--
-- Valid Usage (Implicit)
--
--
-- - image must be a valid VkImage handle
--
--
--
-- - pBinds must be a valid pointer to an array of
-- bindCount valid VkSparseMemoryBind structures
-- - bindCount must be greater than 0
--
--
-- See Also
--
-- VkBindSparseInfo, VkImage, VkSparseMemoryBind
data VkSparseImageOpaqueMemoryBindInfo
VkSparseImageOpaqueMemoryBindInfo :: VkImage -> Word32 -> Ptr VkSparseMemoryBind -> VkSparseImageOpaqueMemoryBindInfo
-- | image is the VkImage object to be bound.
[$sel:vkImage:VkSparseImageOpaqueMemoryBindInfo] :: VkSparseImageOpaqueMemoryBindInfo -> VkImage
-- | bindCount is the number of VkSparseMemoryBind
-- structures in the pBinds array.
[$sel:vkBindCount:VkSparseImageOpaqueMemoryBindInfo] :: VkSparseImageOpaqueMemoryBindInfo -> Word32
-- | pBinds is a pointer to array of VkSparseMemoryBind
-- structures.
[$sel:vkPBinds:VkSparseImageOpaqueMemoryBindInfo] :: VkSparseImageOpaqueMemoryBindInfo -> Ptr VkSparseMemoryBind
-- | VkSparseImageMemoryBindInfo - Structure specifying sparse image memory
-- bind info
--
-- Description
--
-- Valid Usage
--
--
-- - The subresource.mipLevel member of each element of
-- pBinds must be less than the mipLevels
-- specified in VkImageCreateInfo when image was
-- created
--
--
--
-- - The subresource.arrayLayer member of each element of
-- pBinds must be less than the arrayLayers
-- specified in VkImageCreateInfo when image was
-- created
--
--
-- Valid Usage (Implicit)
--
--
-- - image must be a valid VkImage handle
--
--
--
-- - pBinds must be a valid pointer to an array of
-- bindCount valid VkSparseImageMemoryBind
-- structures
-- - bindCount must be greater than 0
--
--
-- See Also
--
-- VkBindSparseInfo, VkImage,
-- VkSparseImageMemoryBind
data VkSparseImageMemoryBindInfo
VkSparseImageMemoryBindInfo :: VkImage -> Word32 -> Ptr VkSparseImageMemoryBind -> VkSparseImageMemoryBindInfo
-- | image is the VkImage object to be bound
[$sel:vkImage:VkSparseImageMemoryBindInfo] :: VkSparseImageMemoryBindInfo -> VkImage
-- | bindCount is the number of VkSparseImageMemoryBind
-- structures in pBinds array
[$sel:vkBindCount:VkSparseImageMemoryBindInfo] :: VkSparseImageMemoryBindInfo -> Word32
-- | pBinds is a pointer to array of
-- VkSparseImageMemoryBind structures
[$sel:vkPBinds:VkSparseImageMemoryBindInfo] :: VkSparseImageMemoryBindInfo -> Ptr VkSparseImageMemoryBind
-- | VkBindSparseInfo - Structure specifying a sparse binding operation
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_SPARSE_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of VkDeviceGroupBindSparseInfo
-- - If waitSemaphoreCount is not 0,
-- pWaitSemaphores must be a valid pointer to an array of
-- waitSemaphoreCount valid VkSemaphore handles
-- - If bufferBindCount is not 0,
-- pBufferBinds must be a valid pointer to an array of
-- bufferBindCount valid VkSparseBufferMemoryBindInfo
-- structures
-- - If imageOpaqueBindCount is not 0,
-- pImageOpaqueBinds must be a valid pointer to an array
-- of imageOpaqueBindCount valid
-- VkSparseImageOpaqueMemoryBindInfo structures
-- - If imageBindCount is not 0, pImageBinds
-- must be a valid pointer to an array of imageBindCount
-- valid VkSparseImageMemoryBindInfo structures
-- - If signalSemaphoreCount is not 0,
-- pSignalSemaphores must be a valid pointer to an array
-- of signalSemaphoreCount valid VkSemaphore
-- handles
-- - Both of the elements of pSignalSemaphores, and the
-- elements of pWaitSemaphores that are valid handles
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkSemaphore, VkSparseBufferMemoryBindInfo,
-- VkSparseImageMemoryBindInfo,
-- VkSparseImageOpaqueMemoryBindInfo, VkStructureType,
-- vkQueueBindSparse
data VkBindSparseInfo
VkBindSparseInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr VkSemaphore -> Word32 -> Ptr VkSparseBufferMemoryBindInfo -> Word32 -> Ptr VkSparseImageOpaqueMemoryBindInfo -> Word32 -> Ptr VkSparseImageMemoryBindInfo -> Word32 -> Ptr VkSemaphore -> VkBindSparseInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBindSparseInfo] :: VkBindSparseInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr ()
-- | waitSemaphoreCount is the number of semaphores upon which to
-- wait before executing the sparse binding operations for the batch.
[$sel:vkWaitSemaphoreCount:VkBindSparseInfo] :: VkBindSparseInfo -> Word32
-- | pWaitSemaphores is a pointer to an array of semaphores upon
-- which to wait on before the sparse binding operations for this batch
-- begin execution. If semaphores to wait on are provided, they define a
-- semaphore wait operation.
[$sel:vkPWaitSemaphores:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr VkSemaphore
-- | bufferBindCount is the number of sparse buffer bindings to
-- perform in the batch.
[$sel:vkBufferBindCount:VkBindSparseInfo] :: VkBindSparseInfo -> Word32
-- | pBufferBinds is a pointer to an array of
-- VkSparseBufferMemoryBindInfo structures.
[$sel:vkPBufferBinds:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr VkSparseBufferMemoryBindInfo
-- | imageOpaqueBindCount is the number of opaque sparse image
-- bindings to perform.
[$sel:vkImageOpaqueBindCount:VkBindSparseInfo] :: VkBindSparseInfo -> Word32
-- | pImageOpaqueBinds is a pointer to an array of
-- VkSparseImageOpaqueMemoryBindInfo structures, indicating opaque
-- sparse image bindings to perform.
[$sel:vkPImageOpaqueBinds:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr VkSparseImageOpaqueMemoryBindInfo
-- | imageBindCount is the number of sparse image bindings to
-- perform.
[$sel:vkImageBindCount:VkBindSparseInfo] :: VkBindSparseInfo -> Word32
-- | pImageBinds is a pointer to an array of
-- VkSparseImageMemoryBindInfo structures, indicating sparse image
-- bindings to perform.
[$sel:vkPImageBinds:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr VkSparseImageMemoryBindInfo
-- | signalSemaphoreCount is the number of semaphores to be
-- signaled once the sparse binding operations specified by the structure
-- have completed execution.
[$sel:vkSignalSemaphoreCount:VkBindSparseInfo] :: VkBindSparseInfo -> Word32
-- | pSignalSemaphores is a pointer to an array of semaphores
-- which will be signaled when the sparse binding operations for this
-- batch have completed execution. If semaphores to be signaled are
-- provided, they define a semaphore signal operation.
[$sel:vkPSignalSemaphores:VkBindSparseInfo] :: VkBindSparseInfo -> Ptr VkSemaphore
-- | VkImageAspectFlags - Bitmask of VkImageAspectFlagBits
--
-- Description
--
-- VkImageAspectFlags is a bitmask type for setting a mask of
-- zero or more VkImageAspectFlagBits.
--
-- See Also
--
-- VkClearAttachment, VkImageAspectFlagBits,
-- VkImageSubresource, VkImageSubresourceLayers,
-- VkImageSubresourceRange,
-- VkInputAttachmentAspectReference,
-- VkSparseImageFormatProperties
type VkImageAspectFlags = VkImageAspectFlagBits
-- | VkSparseMemoryBindFlags - Bitmask of VkSparseMemoryBindFlagBits
--
-- Description
--
-- VkSparseMemoryBindFlags is a bitmask type for setting a mask
-- of zero or more VkSparseMemoryBindFlagBits.
--
-- See Also
--
-- VkSparseImageMemoryBind, VkSparseMemoryBind,
-- VkSparseMemoryBindFlagBits
type VkSparseMemoryBindFlags = VkSparseMemoryBindFlagBits
-- | VkSparseImageFormatFlags - Bitmask of VkSparseImageFormatFlagBits
--
-- Description
--
-- VkSparseImageFormatFlags is a bitmask type for setting a mask
-- of zero or more VkSparseImageFormatFlagBits.
--
-- See Also
--
-- VkSparseImageFormatFlagBits,
-- VkSparseImageFormatProperties
type VkSparseImageFormatFlags = VkSparseImageFormatFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryRequirements
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryRequirements
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatProperties
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkBindSparseInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkBindSparseInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseBufferMemoryBindInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseBufferMemoryBindInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageOpaqueMemoryBindInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageOpaqueMemoryBindInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBind
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBind
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBindInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBindInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBind
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBind
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageSubresource
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageSubresource
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkOffset3D
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkOffset3D
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryRequirements
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkBindSparseInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseBufferMemoryBindInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageOpaqueMemoryBindInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBind
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBindInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageMemoryBind
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageSubresource
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkOffset3D
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseImageFormatFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkSparseMemoryBindFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.SparseResourceMemoryManagement.VkImageAspectFlagBits
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2
-- | vkGetPhysicalDeviceFeatures2 - Reports capabilities of a physical
-- device
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the supported features.
--
--
--
-- - pFeatures is a pointer to a
-- VkPhysicalDeviceFeatures2 structure in which the physical
-- device features are returned.
--
--
-- Description
--
-- Each structure in pFeatures and its pNext chain
-- contain members corresponding to fine-grained features.
-- vkGetPhysicalDeviceFeatures2 writes each member to a boolean
-- value indicating whether that feature is supported.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pFeatures must be a valid pointer to a
-- VkPhysicalDeviceFeatures2 structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceFeatures2
vkGetPhysicalDeviceFeatures2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFeatures" ::: Ptr VkPhysicalDeviceFeatures2) -> IO ()
-- | vkGetPhysicalDeviceProperties2 - Returns properties of a physical
-- device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the physical device whose
-- properties will be queried.
--
--
--
-- - pProperties points to an instance of the
-- VkPhysicalDeviceProperties2 structure, that will be filled with
-- returned information.
--
--
-- Description
--
-- Each structure in pProperties and its pNext chain
-- contain members corresponding to properties or
-- implementation-dependent limits.
-- vkGetPhysicalDeviceProperties2 writes each member to a value
-- indicating the value of that property or limit.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pProperties must be a valid pointer to a
-- VkPhysicalDeviceProperties2 structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceProperties2
vkGetPhysicalDeviceProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pProperties" ::: Ptr VkPhysicalDeviceProperties2) -> IO ()
-- | vkGetPhysicalDeviceFormatProperties2 - Lists physical device’s format
-- capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the format properties.
--
--
--
-- - format is the format whose properties are queried.
-- - pFormatProperties is a pointer to a
-- VkFormatProperties2 structure in which physical device
-- properties for format are returned.
--
--
-- Description
--
-- vkGetPhysicalDeviceFormatProperties2 behaves similarly to
-- vkGetPhysicalDeviceFormatProperties, with the ability to return
-- extended information in a pNext chain of output structures.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - format must be a valid VkFormat value
-- - pFormatProperties must be a valid pointer to a
-- VkFormatProperties2 structure
--
--
-- See Also
--
-- VkFormat, VkFormatProperties2, VkPhysicalDevice
vkGetPhysicalDeviceFormatProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("pFormatProperties" ::: Ptr VkFormatProperties2) -> IO ()
-- | vkGetPhysicalDeviceImageFormatProperties2 - Lists physical device’s
-- image format capabilities
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the image capabilities.
--
--
--
--
-- Description
--
-- vkGetPhysicalDeviceImageFormatProperties2 behaves similarly
-- to vkGetPhysicalDeviceImageFormatProperties, with the ability
-- to return extended information in a pNext chain of output
-- structures.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pImageFormatInfo must be a valid pointer to a
-- valid VkPhysicalDeviceImageFormatInfo2 structure
-- - pImageFormatProperties must be a valid pointer to
-- a VkImageFormatProperties2 structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkImageFormatProperties2, VkPhysicalDevice,
-- VkPhysicalDeviceImageFormatInfo2
vkGetPhysicalDeviceImageFormatProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pImageFormatInfo" ::: Ptr VkPhysicalDeviceImageFormatInfo2) -> ("pImageFormatProperties" ::: Ptr VkImageFormatProperties2) -> IO VkResult
-- | vkGetPhysicalDeviceQueueFamilyProperties2 - Reports properties of the
-- queues of the specified physical device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the physical device whose
-- properties will be queried.
--
--
--
--
-- Description
--
-- vkGetPhysicalDeviceQueueFamilyProperties2 behaves similarly
-- to vkGetPhysicalDeviceQueueFamilyProperties, with the ability
-- to return extended information in a pNext chain of output
-- structures.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pQueueFamilyPropertyCount must be a valid pointer
-- to a uint32_t value
-- - If the value referenced by pQueueFamilyPropertyCount is
-- not 0, and pQueueFamilyProperties is not
-- NULL, pQueueFamilyProperties must be a valid
-- pointer to an array of pQueueFamilyPropertyCount
-- VkQueueFamilyProperties2 structures
--
--
-- See Also
--
-- VkPhysicalDevice, VkQueueFamilyProperties2
vkGetPhysicalDeviceQueueFamilyProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pQueueFamilyPropertyCount" ::: Ptr Word32) -> ("pQueueFamilyProperties" ::: Ptr VkQueueFamilyProperties2) -> IO ()
-- | vkGetPhysicalDeviceMemoryProperties2 - Reports memory information for
-- the specified physical device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the device to query.
--
--
--
-- - pMemoryProperties points to an instance of
-- VkPhysicalDeviceMemoryProperties2 structure in which the
-- properties are returned.
--
--
-- Description
--
-- vkGetPhysicalDeviceMemoryProperties2 behaves similarly to
-- vkGetPhysicalDeviceMemoryProperties, with the ability to return
-- extended information in a pNext chain of output structures.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pMemoryProperties must be a valid pointer to a
-- VkPhysicalDeviceMemoryProperties2 structure
--
--
-- See Also
--
-- VkPhysicalDevice, VkPhysicalDeviceMemoryProperties2
vkGetPhysicalDeviceMemoryProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pMemoryProperties" ::: Ptr VkPhysicalDeviceMemoryProperties2) -> IO ()
-- | vkGetPhysicalDeviceSparseImageFormatProperties2 - Retrieve properties
-- of an image format applied to sparse images
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the sparse image capabilities.
--
--
--
-- - pFormatInfo is a pointer to a structure of type
-- VkPhysicalDeviceSparseImageFormatInfo2 containing input
-- parameters to the command.
-- - pPropertyCount is a pointer to an integer related to the
-- number of sparse format properties available or queried, as described
-- below.
-- - pProperties is either NULL or a pointer to an
-- array of VkSparseImageFormatProperties2 structures.
--
--
-- Description
--
-- vkGetPhysicalDeviceSparseImageFormatProperties2 behaves
-- identically to vkGetPhysicalDeviceSparseImageFormatProperties,
-- with the ability to return extended information by adding extension
-- structures to the pNext chain of its pProperties
-- parameter.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pFormatInfo must be a valid pointer to a valid
-- VkPhysicalDeviceSparseImageFormatInfo2 structure
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkSparseImageFormatProperties2
-- structures
--
--
-- See Also
--
-- VkPhysicalDevice,
-- VkPhysicalDeviceSparseImageFormatInfo2,
-- VkSparseImageFormatProperties2
vkGetPhysicalDeviceSparseImageFormatProperties2 :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFormatInfo" ::: Ptr VkPhysicalDeviceSparseImageFormatInfo2) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkSparseImageFormatProperties2) -> IO ()
-- | VkPhysicalDeviceFeatures2 - Structure describing the fine-grained
-- features that can be supported by an implementation
--
-- Members
--
-- The VkPhysicalDeviceFeatures2 structure is defined as:
--
-- Description
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - features is a structure of type
-- VkPhysicalDeviceFeatures describing the fine-grained features
-- of the Vulkan 1.0 API.
--
--
-- The pNext chain of this structure is used to extend the
-- structure with features defined by extensions. This structure
-- can be used in vkGetPhysicalDeviceFeatures2 or
-- can be in the pNext chain of a
-- VkDeviceCreateInfo structure, in which case it controls which
-- features are enabled in the device in lieu of
-- pEnabledFeatures.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2
--
--
-- See Also
--
-- VkPhysicalDeviceFeatures, VkStructureType,
-- vkGetPhysicalDeviceFeatures2,
-- vkGetPhysicalDeviceFeatures2KHR
data VkPhysicalDeviceFeatures2
VkPhysicalDeviceFeatures2 :: VkStructureType -> Ptr () -> VkPhysicalDeviceFeatures -> VkPhysicalDeviceFeatures2
[$sel:vkSType:VkPhysicalDeviceFeatures2] :: VkPhysicalDeviceFeatures2 -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceFeatures2] :: VkPhysicalDeviceFeatures2 -> Ptr ()
[$sel:vkFeatures:VkPhysicalDeviceFeatures2] :: VkPhysicalDeviceFeatures2 -> VkPhysicalDeviceFeatures
-- | VkPhysicalDeviceProperties2 - Structure specifying physical device
-- properties
--
-- Description
--
-- The pNext chain of this structure is used to extend the
-- structure with properties defined by extensions.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT,
-- VkPhysicalDeviceConservativeRasterizationPropertiesEXT,
-- VkPhysicalDeviceDiscardRectanglePropertiesEXT,
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT,
-- VkPhysicalDeviceIDProperties,
-- VkPhysicalDeviceMaintenance3Properties,
-- VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX,
-- VkPhysicalDeviceMultiviewProperties,
-- VkPhysicalDevicePointClippingProperties,
-- VkPhysicalDeviceProtectedMemoryProperties,
-- VkPhysicalDevicePushDescriptorPropertiesKHR,
-- VkPhysicalDeviceSampleLocationsPropertiesEXT,
-- VkPhysicalDeviceSamplerFilterMinmaxPropertiesEXT,
-- VkPhysicalDeviceShaderCorePropertiesAMD,
-- VkPhysicalDeviceSubgroupProperties, or
-- VkPhysicalDeviceVertexAttributeDivisorPropertiesEXT
-- - Each sType member in the pNext chain must
-- be unique
--
--
-- See Also
--
-- VkPhysicalDeviceProperties, VkStructureType,
-- vkGetPhysicalDeviceProperties2,
-- vkGetPhysicalDeviceProperties2KHR
data VkPhysicalDeviceProperties2
VkPhysicalDeviceProperties2 :: VkStructureType -> Ptr () -> VkPhysicalDeviceProperties -> VkPhysicalDeviceProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceProperties2] :: VkPhysicalDeviceProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceProperties2] :: VkPhysicalDeviceProperties2 -> Ptr ()
-- | properties is a structure of type
-- VkPhysicalDeviceProperties describing the properties of the
-- physical device. This structure is written with the same values as if
-- it were written by vkGetPhysicalDeviceProperties.
[$sel:vkProperties:VkPhysicalDeviceProperties2] :: VkPhysicalDeviceProperties2 -> VkPhysicalDeviceProperties
-- | VkFormatProperties2 - Structure specifying image format properties
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_FORMAT_PROPERTIES_2
--
--
--
--
-- See Also
--
-- VkFormatProperties, VkStructureType,
-- vkGetPhysicalDeviceFormatProperties2,
-- vkGetPhysicalDeviceFormatProperties2KHR
data VkFormatProperties2
VkFormatProperties2 :: VkStructureType -> Ptr () -> VkFormatProperties -> VkFormatProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkFormatProperties2] :: VkFormatProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkFormatProperties2] :: VkFormatProperties2 -> Ptr ()
-- | formatProperties is a structure of type
-- VkFormatProperties describing features supported by the
-- requested format.
[$sel:vkFormatProperties:VkFormatProperties2] :: VkFormatProperties2 -> VkFormatProperties
-- | VkImageFormatProperties2 - Structure specifying a image format
-- properties
--
-- Description
--
-- If the combination of parameters to
-- vkGetPhysicalDeviceImageFormatProperties2 is not supported by
-- the implementation for use in vkCreateImage, then all members
-- of imageFormatProperties will be filled with zero.
--
-- Note
--
-- Filling imageFormatProperties with zero for unsupported
-- formats is an exception to the usual rule that output structures have
-- undefined contents on error. This exception was unintentional, but is
-- preserved for backwards compatibility. This exeption only applies to
-- imageFormatProperties, not sType, pNext, or
-- any structures chained from pNext.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_FORMAT_PROPERTIES_2
--
--
--
--
-- See Also
--
-- VkImageFormatProperties, VkStructureType,
-- vkGetPhysicalDeviceImageFormatProperties2,
-- vkGetPhysicalDeviceImageFormatProperties2KHR
data VkImageFormatProperties2
VkImageFormatProperties2 :: VkStructureType -> Ptr () -> VkImageFormatProperties -> VkImageFormatProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkImageFormatProperties2] :: VkImageFormatProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure. The pNext chain of
-- VkImageFormatProperties2 is used to allow the specification
-- of additional capabilities to be returned from
-- vkGetPhysicalDeviceImageFormatProperties2.
[$sel:vkPNext:VkImageFormatProperties2] :: VkImageFormatProperties2 -> Ptr ()
-- | imageFormatProperties is an instance of a
-- VkImageFormatProperties structure in which capabilities are
-- returned.
[$sel:vkImageFormatProperties:VkImageFormatProperties2] :: VkImageFormatProperties2 -> VkImageFormatProperties
-- | VkPhysicalDeviceImageFormatInfo2 - Structure specifying image creation
-- parameters
--
-- Description
--
-- The members of VkPhysicalDeviceImageFormatInfo2 correspond to
-- the arguments to vkGetPhysicalDeviceImageFormatProperties, with
-- sType and pNext added for extensibility.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_IMAGE_FORMAT_INFO_2
--
--
--
--
-- See Also
--
-- VkFormat, VkImageCreateFlags, VkImageTiling,
-- VkImageType, VkImageUsageFlags, VkStructureType,
-- vkGetPhysicalDeviceImageFormatProperties2,
-- vkGetPhysicalDeviceImageFormatProperties2KHR
data VkPhysicalDeviceImageFormatInfo2
VkPhysicalDeviceImageFormatInfo2 :: VkStructureType -> Ptr () -> VkFormat -> VkImageType -> VkImageTiling -> VkImageUsageFlags -> VkImageCreateFlags -> VkPhysicalDeviceImageFormatInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure. The pNext chain of
-- VkPhysicalDeviceImageFormatInfo2 is used to provide
-- additional image parameters to
-- vkGetPhysicalDeviceImageFormatProperties2.
[$sel:vkPNext:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> Ptr ()
-- | format is a VkFormat value indicating the image
-- format, corresponding to VkImageCreateInfo::format.
[$sel:vkFormat:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkFormat
-- | type is a VkImageType value indicating the image type,
-- corresponding to VkImageCreateInfo::imageType.
[$sel:vkType:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkImageType
-- | tiling is a VkImageTiling value indicating the image
-- tiling, corresponding to VkImageCreateInfo::tiling.
[$sel:vkTiling:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkImageTiling
-- | usage is a bitmask of VkImageUsageFlagBits indicating
-- the intended usage of the image, corresponding to
-- VkImageCreateInfo::usage.
[$sel:vkUsage:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkImageUsageFlags
-- | flags is a bitmask of VkImageCreateFlagBits indicating
-- additional parameters of the image, corresponding to
-- VkImageCreateInfo::flags.
[$sel:vkFlags:VkPhysicalDeviceImageFormatInfo2] :: VkPhysicalDeviceImageFormatInfo2 -> VkImageCreateFlags
-- | VkQueueFamilyProperties2 - Structure providing information about a
-- queue family
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_QUEUE_FAMILY_PROPERTIES_2
--
--
--
--
-- See Also
--
-- VkQueueFamilyProperties, VkStructureType,
-- vkGetPhysicalDeviceQueueFamilyProperties2,
-- vkGetPhysicalDeviceQueueFamilyProperties2KHR
data VkQueueFamilyProperties2
VkQueueFamilyProperties2 :: VkStructureType -> Ptr () -> VkQueueFamilyProperties -> VkQueueFamilyProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkQueueFamilyProperties2] :: VkQueueFamilyProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkQueueFamilyProperties2] :: VkQueueFamilyProperties2 -> Ptr ()
-- | queueFamilyProperties is a structure of type
-- VkQueueFamilyProperties which is populated with the same values
-- as in vkGetPhysicalDeviceQueueFamilyProperties.
[$sel:vkQueueFamilyProperties:VkQueueFamilyProperties2] :: VkQueueFamilyProperties2 -> VkQueueFamilyProperties
-- | VkPhysicalDeviceMemoryProperties2 - Structure specifying physical
-- device memory properties
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MEMORY_PROPERTIES_2
--
--
--
--
-- See Also
--
-- VkPhysicalDeviceMemoryProperties, VkStructureType,
-- vkGetPhysicalDeviceMemoryProperties2,
-- vkGetPhysicalDeviceMemoryProperties2KHR
data VkPhysicalDeviceMemoryProperties2
VkPhysicalDeviceMemoryProperties2 :: VkStructureType -> Ptr () -> VkPhysicalDeviceMemoryProperties -> VkPhysicalDeviceMemoryProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceMemoryProperties2] :: VkPhysicalDeviceMemoryProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceMemoryProperties2] :: VkPhysicalDeviceMemoryProperties2 -> Ptr ()
-- | memoryProperties is a structure of type
-- VkPhysicalDeviceMemoryProperties which is populated with the
-- same values as in vkGetPhysicalDeviceMemoryProperties.
[$sel:vkMemoryProperties:VkPhysicalDeviceMemoryProperties2] :: VkPhysicalDeviceMemoryProperties2 -> VkPhysicalDeviceMemoryProperties
-- | VkSparseImageFormatProperties2 - Structure specifying sparse image
-- format properties
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SPARSE_IMAGE_FORMAT_PROPERTIES_2
--
--
--
--
-- See Also
--
-- VkSparseImageFormatProperties, VkStructureType,
-- vkGetPhysicalDeviceSparseImageFormatProperties2,
-- vkGetPhysicalDeviceSparseImageFormatProperties2KHR
data VkSparseImageFormatProperties2
VkSparseImageFormatProperties2 :: VkStructureType -> Ptr () -> VkSparseImageFormatProperties -> VkSparseImageFormatProperties2
-- | sType is the type of this structure.
[$sel:vkSType:VkSparseImageFormatProperties2] :: VkSparseImageFormatProperties2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSparseImageFormatProperties2] :: VkSparseImageFormatProperties2 -> Ptr ()
-- | properties is a structure of type
-- VkSparseImageFormatProperties which is populated with the same
-- values as in vkGetPhysicalDeviceSparseImageFormatProperties.
[$sel:vkProperties:VkSparseImageFormatProperties2] :: VkSparseImageFormatProperties2 -> VkSparseImageFormatProperties
-- | VkPhysicalDeviceSparseImageFormatInfo2 - Structure specifying sparse
-- image format inputs
--
-- Description
--
-- Valid Usage
--
--
-- - samples must be a bit value that is set in
-- VkImageFormatProperties::sampleCounts returned by
-- vkGetPhysicalDeviceImageFormatProperties with
-- format, type, tiling, and usage
-- equal to those in this command and flags equal to the value
-- that is set in VkImageCreateInfo::flags when the
-- image is created
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SPARSE_IMAGE_FORMAT_INFO_2
--
--
--
--
-- See Also
--
-- VkFormat, VkImageTiling, VkImageType,
-- VkImageUsageFlags, VkSampleCountFlagBits,
-- VkStructureType,
-- vkGetPhysicalDeviceSparseImageFormatProperties2,
-- vkGetPhysicalDeviceSparseImageFormatProperties2KHR
data VkPhysicalDeviceSparseImageFormatInfo2
VkPhysicalDeviceSparseImageFormatInfo2 :: VkStructureType -> Ptr () -> VkFormat -> VkImageType -> VkSampleCountFlagBits -> VkImageUsageFlags -> VkImageTiling -> VkPhysicalDeviceSparseImageFormatInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> Ptr ()
-- | format is the image format.
[$sel:vkFormat:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkFormat
-- | type is the dimensionality of image.
[$sel:vkType:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkImageType
-- | samples is the number of samples per texel as defined in
-- VkSampleCountFlagBits.
[$sel:vkSamples:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkSampleCountFlagBits
-- | usage is a bitmask describing the intended usage of the
-- image.
[$sel:vkUsage:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkImageUsageFlags
-- | tiling is the tiling arrangement of the data elements in
-- memory.
[$sel:vkTiling:VkPhysicalDeviceSparseImageFormatInfo2] :: VkPhysicalDeviceSparseImageFormatInfo2 -> VkImageTiling
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceSparseImageFormatInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceSparseImageFormatInfo2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkSparseImageFormatProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkSparseImageFormatProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceMemoryProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceMemoryProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkQueueFamilyProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkQueueFamilyProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceImageFormatInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceImageFormatInfo2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkImageFormatProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkImageFormatProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkFormatProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkFormatProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceProperties2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceProperties2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceFeatures2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceFeatures2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceSparseImageFormatInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkSparseImageFormatProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceMemoryProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkQueueFamilyProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceImageFormatInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkImageFormatProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkFormatProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceProperties2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_physical_device_properties2.VkPhysicalDeviceFeatures2
module Graphics.Vulkan.Extensions.VK_KHR_get_physical_device_properties2
vkGetPhysicalDeviceFeatures2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFeatures" ::: Ptr VkPhysicalDeviceFeatures2) -> IO ()
vkGetPhysicalDeviceProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pProperties" ::: Ptr VkPhysicalDeviceProperties2) -> IO ()
vkGetPhysicalDeviceFormatProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("format" ::: VkFormat) -> ("pFormatProperties" ::: Ptr VkFormatProperties2) -> IO ()
vkGetPhysicalDeviceImageFormatProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pImageFormatInfo" ::: Ptr VkPhysicalDeviceImageFormatInfo2) -> ("pImageFormatProperties" ::: Ptr VkImageFormatProperties2) -> IO VkResult
vkGetPhysicalDeviceQueueFamilyProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pQueueFamilyPropertyCount" ::: Ptr Word32) -> ("pQueueFamilyProperties" ::: Ptr VkQueueFamilyProperties2) -> IO ()
vkGetPhysicalDeviceMemoryProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pMemoryProperties" ::: Ptr VkPhysicalDeviceMemoryProperties2) -> IO ()
vkGetPhysicalDeviceSparseImageFormatProperties2KHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFormatInfo" ::: Ptr VkPhysicalDeviceSparseImageFormatInfo2) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkSparseImageFormatProperties2) -> IO ()
type VkPhysicalDeviceFeatures2KHR = VkPhysicalDeviceFeatures2
type VkPhysicalDeviceProperties2KHR = VkPhysicalDeviceProperties2
type VkFormatProperties2KHR = VkFormatProperties2
type VkImageFormatProperties2KHR = VkImageFormatProperties2
type VkPhysicalDeviceImageFormatInfo2KHR = VkPhysicalDeviceImageFormatInfo2
type VkQueueFamilyProperties2KHR = VkQueueFamilyProperties2
type VkPhysicalDeviceMemoryProperties2KHR = VkPhysicalDeviceMemoryProperties2
type VkSparseImageFormatProperties2KHR = VkSparseImageFormatProperties2
type VkPhysicalDeviceSparseImageFormatInfo2KHR = VkPhysicalDeviceSparseImageFormatInfo2
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2
-- | vkGetBufferMemoryRequirements2 - Returns the memory requirements for
-- specified Vulkan object
--
-- Parameters
--
--
-- - device is the logical device that owns the buffer.
--
--
--
-- - pInfo is a pointer to an instance of the
-- VkBufferMemoryRequirementsInfo2 structure containing
-- parameters required for the memory requirements query.
-- - pMemoryRequirements points to an instance of the
-- VkMemoryRequirements2 structure in which the memory
-- requirements of the buffer object are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pInfo must be a valid pointer to a valid
-- VkBufferMemoryRequirementsInfo2 structure
-- - pMemoryRequirements must be a valid pointer to a
-- VkMemoryRequirements2 structure
--
--
-- See Also
--
-- VkBufferMemoryRequirementsInfo2, VkDevice,
-- VkMemoryRequirements2
vkGetBufferMemoryRequirements2 :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkBufferMemoryRequirementsInfo2) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements2) -> IO ()
-- | vkGetImageMemoryRequirements2 - Returns the memory requirements for
-- specified Vulkan object
--
-- Parameters
--
--
-- - device is the logical device that owns the image.
--
--
--
-- - pInfo is a pointer to an instance of the
-- VkImageMemoryRequirementsInfo2 structure containing
-- parameters required for the memory requirements query.
-- - pMemoryRequirements points to an instance of the
-- VkMemoryRequirements2 structure in which the memory
-- requirements of the image object are returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pInfo must be a valid pointer to a valid
-- VkImageMemoryRequirementsInfo2 structure
-- - pMemoryRequirements must be a valid pointer to a
-- VkMemoryRequirements2 structure
--
--
-- See Also
--
-- VkDevice, VkImageMemoryRequirementsInfo2,
-- VkMemoryRequirements2
vkGetImageMemoryRequirements2 :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkImageMemoryRequirementsInfo2) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements2) -> IO ()
-- | vkGetImageSparseMemoryRequirements2 - Query the memory requirements
-- for a sparse image
--
-- Parameters
--
--
-- - device is the logical device that owns the image.
--
--
--
-- - pInfo is a pointer to an instance of the
-- VkImageSparseMemoryRequirementsInfo2 structure containing
-- parameters required for the memory requirements query.
-- - pSparseMemoryRequirementCount is a pointer to an integer
-- related to the number of sparse memory requirements available or
-- queried, as described below.
-- - pSparseMemoryRequirements is either NULL or a
-- pointer to an array of VkSparseImageMemoryRequirements2
-- structures.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pInfo must be a valid pointer to a valid
-- VkImageSparseMemoryRequirementsInfo2 structure
-- - pSparseMemoryRequirementCount must be a valid
-- pointer to a uint32_t value
-- - If the value referenced by pSparseMemoryRequirementCount
-- is not 0, and pSparseMemoryRequirements is not
-- NULL, pSparseMemoryRequirements must be a
-- valid pointer to an array of pSparseMemoryRequirementCount
-- VkSparseImageMemoryRequirements2 structures
--
--
-- See Also
--
-- VkDevice, VkImageSparseMemoryRequirementsInfo2,
-- VkSparseImageMemoryRequirements2
vkGetImageSparseMemoryRequirements2 :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkImageSparseMemoryRequirementsInfo2) -> ("pSparseMemoryRequirementCount" ::: Ptr Word32) -> ("pSparseMemoryRequirements" ::: Ptr VkSparseImageMemoryRequirements2) -> IO ()
-- | VkBufferMemoryRequirementsInfo2 - (None)
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BUFFER_MEMORY_REQUIREMENTS_INFO_2
--
--
--
-- - pNext must be NULL
-- - buffer must be a valid VkBuffer
-- handle
--
--
-- See Also
--
-- VkBuffer, VkStructureType,
-- vkGetBufferMemoryRequirements2,
-- vkGetBufferMemoryRequirements2KHR
data VkBufferMemoryRequirementsInfo2
VkBufferMemoryRequirementsInfo2 :: VkStructureType -> Ptr () -> VkBuffer -> VkBufferMemoryRequirementsInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkBufferMemoryRequirementsInfo2] :: VkBufferMemoryRequirementsInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBufferMemoryRequirementsInfo2] :: VkBufferMemoryRequirementsInfo2 -> Ptr ()
-- | buffer is the buffer to query.
[$sel:vkBuffer:VkBufferMemoryRequirementsInfo2] :: VkBufferMemoryRequirementsInfo2 -> VkBuffer
-- | VkImageMemoryRequirementsInfo2 - (None)
--
-- Description
--
-- Valid Usage
--
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_MEMORY_REQUIREMENTS_INFO_2
--
--
--
--
-- See Also
--
-- VkImage, VkStructureType,
-- vkGetImageMemoryRequirements2,
-- vkGetImageMemoryRequirements2KHR
data VkImageMemoryRequirementsInfo2
VkImageMemoryRequirementsInfo2 :: VkStructureType -> Ptr () -> VkImage -> VkImageMemoryRequirementsInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkImageMemoryRequirementsInfo2] :: VkImageMemoryRequirementsInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageMemoryRequirementsInfo2] :: VkImageMemoryRequirementsInfo2 -> Ptr ()
-- | image is the image to query.
[$sel:vkImage:VkImageMemoryRequirementsInfo2] :: VkImageMemoryRequirementsInfo2 -> VkImage
-- | VkImageSparseMemoryRequirementsInfo2 - (None)
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_SPARSE_MEMORY_REQUIREMENTS_INFO_2
--
--
--
-- - pNext must be NULL
-- - image must be a valid VkImage handle
--
--
-- See Also
--
-- VkImage, VkStructureType,
-- vkGetImageSparseMemoryRequirements2,
-- vkGetImageSparseMemoryRequirements2KHR
data VkImageSparseMemoryRequirementsInfo2
VkImageSparseMemoryRequirementsInfo2 :: VkStructureType -> Ptr () -> VkImage -> VkImageSparseMemoryRequirementsInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkImageSparseMemoryRequirementsInfo2] :: VkImageSparseMemoryRequirementsInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageSparseMemoryRequirementsInfo2] :: VkImageSparseMemoryRequirementsInfo2 -> Ptr ()
-- | image is the image to query.
[$sel:vkImage:VkImageSparseMemoryRequirementsInfo2] :: VkImageSparseMemoryRequirementsInfo2 -> VkImage
-- | VkMemoryRequirements2 - Structure specifying memory requirements
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_REQUIREMENTS_2
--
--
--
--
-- See Also
--
-- VkMemoryRequirements, VkStructureType,
-- vkGetBufferMemoryRequirements2,
-- vkGetBufferMemoryRequirements2KHR,
-- vkGetImageMemoryRequirements2,
-- vkGetImageMemoryRequirements2KHR
data VkMemoryRequirements2
VkMemoryRequirements2 :: VkStructureType -> Ptr () -> VkMemoryRequirements -> VkMemoryRequirements2
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryRequirements2] :: VkMemoryRequirements2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryRequirements2] :: VkMemoryRequirements2 -> Ptr ()
-- | memoryRequirements is a structure of type
-- VkMemoryRequirements describing the memory requirements of the
-- resource.
[$sel:vkMemoryRequirements:VkMemoryRequirements2] :: VkMemoryRequirements2 -> VkMemoryRequirements
-- | VkSparseImageMemoryRequirements2 - (None)
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SPARSE_IMAGE_MEMORY_REQUIREMENTS_2
--
--
--
--
-- See Also
--
-- VkSparseImageMemoryRequirements, VkStructureType,
-- vkGetImageSparseMemoryRequirements2,
-- vkGetImageSparseMemoryRequirements2KHR
data VkSparseImageMemoryRequirements2
VkSparseImageMemoryRequirements2 :: VkStructureType -> Ptr () -> VkSparseImageMemoryRequirements -> VkSparseImageMemoryRequirements2
-- | sType is the type of this structure.
[$sel:vkSType:VkSparseImageMemoryRequirements2] :: VkSparseImageMemoryRequirements2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSparseImageMemoryRequirements2] :: VkSparseImageMemoryRequirements2 -> Ptr ()
-- | memoryRequirements is a structure of type
-- VkSparseImageMemoryRequirements describing the memory
-- requirements of the sparse image.
[$sel:vkMemoryRequirements:VkSparseImageMemoryRequirements2] :: VkSparseImageMemoryRequirements2 -> VkSparseImageMemoryRequirements
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkSparseImageMemoryRequirements2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkSparseImageMemoryRequirements2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkMemoryRequirements2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkMemoryRequirements2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageSparseMemoryRequirementsInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageSparseMemoryRequirementsInfo2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageMemoryRequirementsInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageMemoryRequirementsInfo2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkBufferMemoryRequirementsInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkBufferMemoryRequirementsInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkSparseImageMemoryRequirements2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkMemoryRequirements2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageSparseMemoryRequirementsInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkImageMemoryRequirementsInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_get_memory_requirements2.VkBufferMemoryRequirementsInfo2
module Graphics.Vulkan.Extensions.VK_KHR_get_memory_requirements2
vkGetBufferMemoryRequirements2KHR :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkBufferMemoryRequirementsInfo2) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements2) -> IO ()
vkGetImageMemoryRequirements2KHR :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkImageMemoryRequirementsInfo2) -> ("pMemoryRequirements" ::: Ptr VkMemoryRequirements2) -> IO ()
vkGetImageSparseMemoryRequirements2KHR :: ("device" ::: VkDevice) -> ("pInfo" ::: Ptr VkImageSparseMemoryRequirementsInfo2) -> ("pSparseMemoryRequirementCount" ::: Ptr Word32) -> ("pSparseMemoryRequirements" ::: Ptr VkSparseImageMemoryRequirements2) -> IO ()
type VkBufferMemoryRequirementsInfo2KHR = VkBufferMemoryRequirementsInfo2
type VkImageMemoryRequirementsInfo2KHR = VkImageMemoryRequirementsInfo2
type VkImageSparseMemoryRequirementsInfo2KHR = VkImageSparseMemoryRequirementsInfo2
type VkMemoryRequirements2KHR = VkMemoryRequirements2
type VkSparseImageMemoryRequirements2KHR = VkSparseImageMemoryRequirements2
module Graphics.Vulkan.Core10.ImageView
-- | VkComponentSwizzle - Specify how a component is swizzled
--
-- Description
--
--
-- - VK_COMPONENT_SWIZZLE_IDENTITY specifies that the
-- component is set to the identity swizzle.
--
--
--
-- - VK_COMPONENT_SWIZZLE_ZERO specifies that the component is
-- set to zero.
-- - VK_COMPONENT_SWIZZLE_ONE specifies that the component is
-- set to either 1 or 1.0, depending on whether the type of the image
-- view format is integer or floating-point respectively, as determined
-- by the Format Definition section for each VkFormat.
-- - VK_COMPONENT_SWIZZLE_R specifies that the component is
-- set to the value of the R component of the image.
-- - VK_COMPONENT_SWIZZLE_G specifies that the component is
-- set to the value of the G component of the image.
-- - VK_COMPONENT_SWIZZLE_B specifies that the component is
-- set to the value of the B component of the image.
-- - VK_COMPONENT_SWIZZLE_A specifies that the component is
-- set to the value of the A component of the image.
--
--
-- Setting the identity swizzle on a component is equivalent to setting
-- the identity mapping on that component. That is:
--
--
-- +-----------------------------------+-----------------------------------+
-- | Component | Identity Mapping |
-- +===================================+===================================+
-- | @components.r@ | @VK_COMPONENT_SWIZZLE_R@ |
-- +-----------------------------------+-----------------------------------+
-- | @components.g@ | @VK_COMPONENT_SWIZZLE_G@ |
-- +-----------------------------------+-----------------------------------+
-- | @components.b@ | @VK_COMPONENT_SWIZZLE_B@ |
-- +-----------------------------------+-----------------------------------+
-- | @components.a@ | @VK_COMPONENT_SWIZZLE_A@ |
-- +-----------------------------------+-----------------------------------+
--
-- Component Mappings Equivalent To @VK_COMPONENT_SWIZZLE_IDENTITY@
--
--
-- See Also
--
-- VkComponentMapping
newtype VkComponentSwizzle
VkComponentSwizzle :: Int32 -> VkComponentSwizzle
-- | VkImageViewType - Image view types
--
-- Description
--
-- The exact image view type is partially implicit, based on the image’s
-- type and sample count, as well as the view creation parameters as
-- described in the image view compatibility table for
-- vkCreateImageView. This table also shows which SPIR-V
-- OpTypeImage Dim and Arrayed parameters
-- correspond to each image view type.
--
-- See Also
--
-- VkImageViewCreateInfo
newtype VkImageViewType
VkImageViewType :: Int32 -> VkImageViewType
-- | VkImageViewCreateFlags - Reserved for future use
--
-- Description
--
-- VkImageViewCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkImageViewCreateInfo
newtype VkImageViewCreateFlags
VkImageViewCreateFlags :: VkFlags -> VkImageViewCreateFlags
-- | VkImageView - Opaque handle to a image view object
--
-- Description
--
-- See Also
--
-- VkDescriptorImageInfo, VkFramebufferCreateInfo,
-- vkCreateImageView, vkDestroyImageView
type VkImageView = Ptr VkImageView_T
-- | vkCreateImageView - Create an image view from an existing image
--
-- Parameters
--
--
-- - device is the logical device that creates the image
-- view.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkImageViewCreateInfo structure containing parameters to be
-- used to create the image view.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pView points to a VkImageView handle in which
-- the resulting image view object is returned.
--
--
-- Description
--
-- Some of the image creation parameters are inherited by the view. In
-- particular, image view creation inherits the implicit parameter
-- usage specifying the allowed usages of the image view that,
-- by default, takes the value of the corresponding usage
-- parameter specified in VkImageCreateInfo at image creation
-- time. This implicit parameter can be overriden by chaining a
-- VkImageViewUsageCreateInfo structure through the pNext
-- member to VkImageViewCreateInfo as described later in this
-- section.
--
-- The remaining parameters are contained in the pCreateInfo.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkImageViewCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pView must be a valid pointer to a
-- VkImageView handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkImageView,
-- VkImageViewCreateInfo
vkCreateImageView :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkImageViewCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pView" ::: Ptr VkImageView) -> IO VkResult
-- | vkDestroyImageView - Destroy an image view object
--
-- Parameters
--
--
-- - device is the logical device that destroys the image
-- view.
--
--
--
-- - imageView is the image view to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to imageView
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- imageView was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- imageView was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If imageView is not VK_NULL_HANDLE,
-- imageView must be a valid VkImageView
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If imageView is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to imageView must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkImageView
vkDestroyImageView :: ("device" ::: VkDevice) -> ("imageView" ::: VkImageView) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkComponentMapping - Structure specifying a color component mapping
--
-- Description
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkComponentSwizzle, VkImageViewCreateInfo,
-- VkSamplerYcbcrConversionCreateInfo
data VkComponentMapping
VkComponentMapping :: VkComponentSwizzle -> VkComponentSwizzle -> VkComponentSwizzle -> VkComponentSwizzle -> VkComponentMapping
-- | r is a VkComponentSwizzle specifying the component
-- value placed in the R component of the output vector.
[$sel:vkR:VkComponentMapping] :: VkComponentMapping -> VkComponentSwizzle
-- | g is a VkComponentSwizzle specifying the component
-- value placed in the G component of the output vector.
[$sel:vkG:VkComponentMapping] :: VkComponentMapping -> VkComponentSwizzle
-- | b is a VkComponentSwizzle specifying the component
-- value placed in the B component of the output vector.
[$sel:vkB:VkComponentMapping] :: VkComponentMapping -> VkComponentSwizzle
-- | a is a VkComponentSwizzle specifying the component
-- value placed in the A component of the output vector.
[$sel:vkA:VkComponentMapping] :: VkComponentMapping -> VkComponentSwizzle
-- | VkImageSubresourceRange - Structure specifying a image subresource
-- range
--
-- Description
--
-- The number of mipmap levels and array layers must be a subset
-- of the image subresources in the image. If an application wants to use
-- all mip levels or layers in an image after the baseMipLevel
-- or baseArrayLayer, it can set levelCount and
-- layerCount to the special values
-- VK_REMAINING_MIP_LEVELS and
-- VK_REMAINING_ARRAY_LAYERS without knowing the exact number of
-- mip levels or layers.
--
-- For cube and cube array image views, the layers of the image view
-- starting at baseArrayLayer correspond to faces in the order
-- +X, -X, +Y, -Y, +Z, -Z. For cube arrays, each set of six sequential
-- layers is a single cube, so the number of cube maps in a cube map
-- array view is layerCount / 6, and image array layer
-- (baseArrayLayer + i) is face index (i mod 6) of cube i /
-- 6. If the number of layers in the view, whether set explicitly in
-- layerCount or implied by VK_REMAINING_ARRAY_LAYERS,
-- is not a multiple of 6, behavior when indexing the last cube is
-- undefined.
--
-- aspectMask must be only
-- VK_IMAGE_ASPECT_COLOR_BIT, VK_IMAGE_ASPECT_DEPTH_BIT
-- or VK_IMAGE_ASPECT_STENCIL_BIT if format is a color,
-- depth-only or stencil-only format, respectively, except if
-- format is a multi-planar format. If using a
-- depth/stencil format with both depth and stencil components,
-- aspectMask must include at least one of
-- VK_IMAGE_ASPECT_DEPTH_BIT and
-- VK_IMAGE_ASPECT_STENCIL_BIT, and can include both.
--
-- When the VkImageSubresourceRange structure is used to select
-- a subset of the slices of a 3D image’s mip level in order to create a
-- 2D or 2D array image view of a 3D image created with
-- VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT,
-- baseArrayLayer and layerCount specify the first
-- slice index and the number of slices to include in the created image
-- view. Such an image view can be used as a framebuffer
-- attachment that refers only to the specified range of slices of the
-- selected mip level. However, any layout transitions performed on such
-- an attachment view during a render pass instance still apply to the
-- entire subresource referenced which includes all the slices of the
-- selected mip level.
--
-- When using an imageView of a depth/stencil image to populate a
-- descriptor set (e.g. for sampling in the shader, or for use as an
-- input attachment), the aspectMask must only include
-- one bit and selects whether the imageView is used for depth reads
-- (i.e. using a floating-point sampler or input attachment in the
-- shader) or stencil reads (i.e. using an unsigned integer sampler or
-- input attachment in the shader). When an imageView of a depth/stencil
-- image is used as a depth/stencil framebuffer attachment, the
-- aspectMask is ignored and both depth and stencil image
-- subresources are used.
--
-- The components member is of type VkComponentMapping,
-- and describes a remapping from components of the image to components
-- of the vector returned by shader image instructions. This remapping
-- must be identity for storage image descriptors, input
-- attachment descriptors, framebuffer attachments, and any
-- VkImageView used with a combined image sampler that enables
-- sampler Y’CBCR conversion.
--
-- When creating a VkImageView, if sampler Y’CBCR
-- conversion is enabled in the sampler, the aspectMask of a
-- subresourceRange used by the VkImageView must
-- be VK_IMAGE_ASPECT_COLOR_BIT.
--
-- When creating a VkImageView, if sampler Y’CBCR conversion is
-- not enabled in the sampler and the image format is
-- multi-planar, the image must have been created with
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT, and the
-- aspectMask of the VkImageView’s
-- subresourceRange must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT or
-- VK_IMAGE_ASPECT_PLANE_2_BIT.
--
-- Valid Usage
--
--
-- - If levelCount is not VK_REMAINING_MIP_LEVELS, it
-- must be greater than 0
--
--
--
-- - If layerCount is not VK_REMAINING_ARRAY_LAYERS,
-- it must be greater than 0
-- - If aspectMask includes
-- VK_IMAGE_ASPECT_COLOR_BIT, then it must not include
-- any of VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - aspectMask must not be 0
--
--
-- See Also
--
-- VkImageAspectFlags, VkImageMemoryBarrier,
-- VkImageViewCreateInfo, vkCmdClearColorImage,
-- vkCmdClearDepthStencilImage
data VkImageSubresourceRange
VkImageSubresourceRange :: VkImageAspectFlags -> Word32 -> Word32 -> Word32 -> Word32 -> VkImageSubresourceRange
-- | aspectMask is a bitmask of VkImageAspectFlagBits
-- specifying which aspect(s) of the image are included in the view.
[$sel:vkAspectMask:VkImageSubresourceRange] :: VkImageSubresourceRange -> VkImageAspectFlags
-- | baseMipLevel is the first mipmap level accessible to the
-- view.
[$sel:vkBaseMipLevel:VkImageSubresourceRange] :: VkImageSubresourceRange -> Word32
-- | levelCount is the number of mipmap levels (starting from
-- baseMipLevel) accessible to the view.
[$sel:vkLevelCount:VkImageSubresourceRange] :: VkImageSubresourceRange -> Word32
-- | baseArrayLayer is the first array layer accessible to the
-- view.
[$sel:vkBaseArrayLayer:VkImageSubresourceRange] :: VkImageSubresourceRange -> Word32
-- | layerCount is the number of array layers (starting from
-- baseArrayLayer) accessible to the view.
[$sel:vkLayerCount:VkImageSubresourceRange] :: VkImageSubresourceRange -> Word32
-- | VkImageViewCreateInfo - Structure specifying parameters of a newly
-- created image view
--
-- Description
--
-- If image was created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT flag, and if the
-- format of the image is not multi-planar,
-- format can be different from the image’s format, but
-- if image was created without the
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT flag and they
-- are not equal they must be compatible. Image format
-- compatibility is defined in the Format Compatibility Classes
-- section. Views of compatible formats will have the same mapping
-- between texel coordinates and memory locations irrespective of the
-- format, with only the interpretation of the bit pattern
-- changing.
--
-- Note
--
-- Values intended to be used with one view format may not be
-- exactly preserved when written or read through a different format. For
-- example, an integer value that happens to have the bit pattern of a
-- floating point denorm or NaN may be flushed or canonicalized
-- when written or read through a view with a floating point format.
-- Similarly, a value written through a signed normalized format that has
-- a bit pattern exactly equal to -2b may be changed to -2b + 1 as
-- described in Conversion from Normalized Fixed-Point to
-- Floating-Point.
--
-- If image was created with the
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT flag,
-- format must be compatible with the image’s
-- format as described above, or must be an uncompressed format in
-- which case it must be size-compatible with the image’s
-- format, as defined for copying data between images In this case
-- the resulting image view’s texel dimensions equal the dimensions of
-- the selected mip level divided by the compressed texel block size and
-- rounded up.
--
-- If the image view is to be used with a sampler which supports
-- sampler Y’CBCR conversion, an identically defined object
-- of type VkSamplerYcbcrConversion to that used to create the
-- sampler must be passed to vkCreateImageView in a
-- VkSamplerYcbcrConversionInfo added to the pNext chain
-- of VkImageViewCreateInfo.
--
-- If the image has a multi-planar format and
-- subresourceRange.aspectMask is
-- VK_IMAGE_ASPECT_COLOR_BIT, format must be
-- identical to the image format, and the sampler to be used
-- with the image view must enable sampler Y’CBCR
-- conversion.
--
-- If image was created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT and the image has a
-- multi-planar format, and if
-- subresourceRange.aspectMask is
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT, format must be
-- compatible with the corresponding plane of the image, and the
-- sampler to be used with the image view must not enable
-- sampler Y’CBCR conversion. The width and
-- height of the single-plane image view must be derived
-- from the multi-planar image’s dimensions in the manner listed for
-- plane compatibility for the plane.
--
-- Any view of an image plane will have the same mapping between texel
-- coordinates and memory locations as used by the channels of the color
-- aspect, subject to the formulae relating texel coordinates to
-- lower-resolution planes as described in Chroma Reconstruction.
-- That is, if an R or B plane has a reduced resolution relative to the G
-- plane of the multi-planar image, the image view operates using the
-- (uplane, vplane) unnormalized coordinates of the
-- reduced-resolution plane, and these coordinates access the same memory
-- locations as the (ucolor, vcolor) unnormalized
-- coordinates of the color aspect for which chroma reconstruction
-- operations operate on the same (uplane, vplane) or
-- (iplane, jplane) coordinates.
--
--
-- +---------+------------------------+-----------------------------------+
-- | Dim, | Image parameters | View parameters |
-- | Arrayed | | |
-- | , | | |
-- | MS | | |
-- +=========+========================+===================================+
-- | | @imageType@ = | @baseArrayLayer@, @layerCount@, |
-- | | ci.@imageType@ | and @levelCount@ are members of |
-- | | @width@ = | the @subresourceRange@ member. |
-- | | ci.@extent.width@ | |
-- | | @height@ = | |
-- | | ci.@extent.height@ | |
-- | | @depth@ = | |
-- | | ci.@extent.depth@ | |
-- | | @arrayLayers@ = | |
-- | | ci.@arrayLayers@ | |
-- | | @samples@ = | |
-- | | ci.@samples@ | |
-- | | @flags@ = ci.@flags@ | |
-- | | where ci is the | |
-- | | 'Graphics.Vulkan.Core1 | |
-- | | 0.Image.VkImageCreateI | |
-- | | nfo' | |
-- | | used to create | |
-- | | @image@. | |
-- +---------+------------------------+-----------------------------------+
-- | __1D, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_1D@ | @VK_IMAGE_VIEW_TYPE_1D@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ = 1 | @layerCount@ = 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ = 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __1D, | @imageType@ = | @viewType@ = |
-- | 1, 0__ | @VK_IMAGE_TYPE_1D@ | @VK_IMAGE_VIEW_TYPE_1D_ARRAY@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ = 1 | @layerCount@ ≥ 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ = 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __2D, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_2D@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ ≥ 1 | @layerCount@ = 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ = 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __2D, | @imageType@ = | @viewType@ = |
-- | 1, 0__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_2D_ARRAY@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ ≥ 1 | @layerCount@ ≥ 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ = 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __2D, | @imageType@ = | @viewType@ = |
-- | 0, 1__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_2D@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ ≥ 1 | @layerCount@ = 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ > 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __2D, | @imageType@ = | @viewType@ = |
-- | 1, 1__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_2D_ARRAY@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ ≥ 1 | @layerCount@ ≥ 1 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 1 | |
-- | | @samples@ > 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __CUBE, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_CUBE@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ = @width@ | @layerCount@ = 6 |
-- | | @depth@ = 1 | |
-- | | @arrayLayers@ ≥ 6 | |
-- | | @samples@ = 1 | |
-- | | @flags@ includes | |
-- | | @VK_IMAGE_CREATE_CUBE_ | |
-- | | COMPATIBLE_BIT@ | |
-- +---------+------------------------+-----------------------------------+
-- | __CUBE, | @imageType@ = | @viewType@ = |
-- | 1, 0__ | @VK_IMAGE_TYPE_2D@ | @VK_IMAGE_VIEW_TYPE_CUBE_ARRAY@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @height@ = width | @layerCount@ = 6 × /N/, /N/ ≥ 1 |
-- | | @depth@ = 1 | |
-- | | /N/ ≥ 1 | |
-- | | @arrayLayers@ ≥ 6 × | |
-- | | /N/ | |
-- | | @samples@ = 1 | |
-- | | @flags@ includes | |
-- | | @VK_IMAGE_CREATE_CUBE_ | |
-- | | COMPATIBLE_BIT@ | |
-- +---------+------------------------+-----------------------------------+
-- | __3D, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_3D@ | @VK_IMAGE_VIEW_TYPE_3D@ |
-- | | @width@ ≥ 1 | @baseArrayLayer@ = 0 |
-- | | @height@ ≥ 1 | @layerCount@ = 1 |
-- | | @depth@ ≥ 1 | |
-- | | @arrayLayers@ = 1 | |
-- | | @samples@ = 1 | |
-- +---------+------------------------+-----------------------------------+
-- | __3D, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_3D@ | @VK_IMAGE_VIEW_TYPE_2D@ |
-- | | @width@ ≥ 1 | @levelCount@ = 1 |
-- | | @height@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @depth@ ≥ 1 | @layerCount@ = 1 |
-- | | @arrayLayers@ = 1 | |
-- | | @samples@ = 1 | |
-- | | @flags@ includes | |
-- | | @VK_IMAGE_CREATE_2D_AR | |
-- | | RAY_COMPATIBLE_BIT@ | |
-- | | @flags@ does not | |
-- | | include | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_BINDING_BIT@, | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_RESIDENCY_BIT@, | |
-- | | and | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_ALIASED_BIT@ | |
-- +---------+------------------------+-----------------------------------+
-- | __3D, | @imageType@ = | @viewType@ = |
-- | 0, 0__ | @VK_IMAGE_TYPE_3D@ | @VK_IMAGE_VIEW_TYPE_2D_ARRAY@ |
-- | | @width@ ≥ 1 | @levelCount@ = 1 |
-- | | @height@ ≥ 1 | @baseArrayLayer@ ≥ 0 |
-- | | @depth@ ≥ 1 | @layerCount@ ≥ 1 |
-- | | @arrayLayers@ = 1 | |
-- | | @samples@ = 1 | |
-- | | @flags@ includes | |
-- | | @VK_IMAGE_CREATE_2D_AR | |
-- | | RAY_COMPATIBLE_BIT@ | |
-- | | @flags@ does not | |
-- | | include | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_BINDING_BIT@, | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_RESIDENCY_BIT@, | |
-- | | and | |
-- | | @VK_IMAGE_CREATE_SPARS | |
-- | | E_ALIASED_BIT@ | |
-- +---------+------------------------+-----------------------------------+
--
-- Image and image view parameter compatibility requirements
--
--
-- Valid Usage
--
--
-- - If image was not created with
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT then viewType
-- must not be VK_IMAGE_VIEW_TYPE_CUBE or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
--
--
--
-- - If the image cubemap arrays feature is not enabled,
-- viewType must not be
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- - If image was created with VK_IMAGE_TYPE_3D but
-- without VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT set then
-- viewType must not be VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY
-- - If image was created with
-- VK_IMAGE_TILING_LINEAR, format must be format
-- that has at least one supported feature bit present in the value of
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - image must have been created with a usage
-- value containing at least one of VK_IMAGE_USAGE_SAMPLED_BIT,
-- VK_IMAGE_USAGE_STORAGE_BIT,
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT
-- - If image was created with VK_IMAGE_TILING_LINEAR
-- and usage contains VK_IMAGE_USAGE_SAMPLED_BIT,
-- format must be supported for sampled images, as
-- specified by the VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT flag in
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with VK_IMAGE_TILING_LINEAR
-- and usage contains VK_IMAGE_USAGE_STORAGE_BIT,
-- format must be supported for storage images, as
-- specified by the VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT flag in
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with VK_IMAGE_TILING_LINEAR
-- and usage contains
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, format
-- must be supported for color attachments, as specified by the
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT flag in
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with VK_IMAGE_TILING_LINEAR
-- and usage contains
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, format
-- must be supported for depth/stencil attachments, as specified
-- by the VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT flag in
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with
-- VK_IMAGE_TILING_OPTIMAL, format must be
-- format that has at least one supported feature bit present in the
-- value of VkFormatProperties::optimalTilingFeatures
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format
-- - If image was created with
-- VK_IMAGE_TILING_OPTIMAL and usage contains
-- VK_IMAGE_USAGE_SAMPLED_BIT, format must be
-- supported for sampled images, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT flag in
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with
-- VK_IMAGE_TILING_OPTIMAL and usage contains
-- VK_IMAGE_USAGE_STORAGE_BIT, format must be
-- supported for storage images, as specified by the
-- VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT flag in
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with
-- VK_IMAGE_TILING_OPTIMAL and usage contains
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT, format
-- must be supported for color attachments, as specified by the
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT flag in
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If image was created with
-- VK_IMAGE_TILING_OPTIMAL and usage contains
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, format
-- must be supported for depth/stencil attachments, as specified
-- by the VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT flag in
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - subresourceRange.baseMipLevel must be less than
-- the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - If subresourceRange.levelCount is not
-- VK_REMAINING_MIP_LEVELS,
-- subresourceRange.baseMipLevel +
-- subresourceRange.levelCount must be less than or equal
-- to the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - If image is not a 3D image created with
-- VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT set, or
-- viewType is not VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY,
-- subresourceRange::baseArrayLayer must be less
-- than the arrayLayers specified in VkImageCreateInfo
-- when image was created
-- - If subresourceRange::layerCount is not
-- VK_REMAINING_ARRAY_LAYERS, image is not a 3D image
-- created with VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT set, or
-- viewType is not VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY,
-- subresourceRange::layerCount must be non-zero
-- and subresourceRange::baseArrayLayer +
-- subresourceRange::layerCount must be less
-- than or equal to the arrayLayers specified in
-- VkImageCreateInfo when image was created
-- - If image is a 3D image created with
-- VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT set, and
-- viewType is VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY,
-- subresourceRange::baseArrayLayer must be less
-- than the extent.depth specified in VkImageCreateInfo
-- when image was created
-- - If subresourceRange::layerCount is not
-- VK_REMAINING_ARRAY_LAYERS, image is a 3D image
-- created with VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT set, and
-- viewType is VK_IMAGE_VIEW_TYPE_2D or
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY,
-- subresourceRange::layerCount must be non-zero
-- and subresourceRange::baseArrayLayer +
-- subresourceRange::layerCount must be less
-- than or equal to the extent.depth specified in
-- VkImageCreateInfo when image was created
-- - If image was created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT flag, format
-- must be compatible with the format used to create
-- image, as defined in Format Compatibility Classes
-- - If image was created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT flag, but without the
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT flag, and if
-- the format of the image is not a multi-planar
-- format, format must be compatible with the
-- format used to create image, as defined in Format
-- Compatibility Classes
-- - If image was created with the
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT flag,
-- format must be compatible with, or must be an
-- uncompressed format that is size-compatible with, the format
-- used to create image.
-- - If image was created with the
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT flag, the
-- levelCount and layerCount members of
-- subresourceRange must both be 1.
-- - If a VkImageFormatListCreateInfoKHR structure was
-- included in the pNext chain of the VkImageCreateInfo
-- struct used when creating image and the
-- viewFormatCount field of
-- VkImageFormatListCreateInfoKHR is not zero then
-- format must be one of the formats in
-- VkImageFormatListCreateInfoKHR::pViewFormats.
-- - If image was created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT flag, if the
-- format of the image is a multi-planar format,
-- and if subresourceRange.aspectMask is one of
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT, then format must
-- be compatible with the VkFormat for the plane of the
-- image format indicated by
-- subresourceRange.aspectMask, as defined in
-- {html_spec_relative}#features-formats-compatible-planes
-- - If image was not created with the
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT flag, or if the
-- format of the image is a multi-planar format
-- and if subresourceRange.aspectMask is
-- VK_IMAGE_ASPECT_COLOR_BIT, format must be
-- identical to the format used to create image
-- - If image is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - subresourceRange and viewType must be
-- compatible with the image, as described in the compatibility
-- table
-- - If image has an external
-- format:
- format must be
-- VK_FORMAT_UNDEFINED
- The pNext chain must
-- contain an instance of VkSamplerYcbcrConversionInfo with a
-- conversion object created with the same external format as
-- image
- All members of components must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of VkImageViewUsageCreateInfo or
-- VkSamplerYcbcrConversionInfo
-- - Each sType member in the pNext chain must
-- be unique
-- - flags must be 0
-- - image must be a valid VkImage handle
-- - viewType must be a valid VkImageViewType
-- value
-- - format must be a valid VkFormat value
-- - components must be a valid
-- VkComponentMapping structure
-- - subresourceRange must be a valid
-- VkImageSubresourceRange structure
--
--
-- See Also
--
-- VkComponentMapping, VkFormat, VkImage,
-- VkImageSubresourceRange, VkImageViewCreateFlags,
-- VkImageViewType, VkStructureType,
-- vkCreateImageView
data VkImageViewCreateInfo
VkImageViewCreateInfo :: VkStructureType -> Ptr () -> VkImageViewCreateFlags -> VkImage -> VkImageViewType -> VkFormat -> VkComponentMapping -> VkImageSubresourceRange -> VkImageViewCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkImageViewCreateFlags
-- | image is a VkImage on which the view will be
-- created.
[$sel:vkImage:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkImage
-- | viewType is an VkImageViewType value specifying the
-- type of the image view.
[$sel:vkViewType:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkImageViewType
-- | format is a VkFormat describing the format and type
-- used to interpret data elements in the image.
[$sel:vkFormat:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkFormat
-- | components is a VkComponentMapping specifies a
-- remapping of color components (or of depth or stencil components after
-- they have been converted into color components).
[$sel:vkComponents:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkComponentMapping
-- | subresourceRange is a VkImageSubresourceRange
-- selecting the set of mipmap levels and array layers to be accessible
-- to the view.
[$sel:vkSubresourceRange:VkImageViewCreateInfo] :: VkImageViewCreateInfo -> VkImageSubresourceRange
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkImageViewCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkImageViewCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkImageSubresourceRange
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkImageSubresourceRange
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkComponentMapping
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkComponentMapping
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkImageViewType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.ImageView.VkImageViewType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkImageViewType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkComponentSwizzle
instance GHC.Classes.Ord Graphics.Vulkan.Core10.ImageView.VkComponentSwizzle
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ImageView.VkComponentSwizzle
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkImageViewCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkImageSubresourceRange
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ImageView.VkComponentMapping
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.ImageView.VkImageViewCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkImageViewType
instance GHC.Read.Read Graphics.Vulkan.Core10.ImageView.VkImageViewType
instance GHC.Show.Show Graphics.Vulkan.Core10.ImageView.VkComponentSwizzle
instance GHC.Read.Read Graphics.Vulkan.Core10.ImageView.VkComponentSwizzle
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion
-- | VkSamplerYcbcrModelConversion - Color model component of a color space
--
-- Description
--
--
-- - VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY specifies
-- that the input values to the conversion are unmodified.
--
--
--
-- - VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_IDENTITY
-- specifies no model conversion but the inputs are range expanded as for
-- Y’CBCR.
-- - VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_709 specifies the
-- color model conversion from Y’CBCR to R’G’B' defined in BT.709 and
-- described in the “BT.709 Y’CBCR conversion” section of the Khronos
-- Data Format Specification.
-- - VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_601 specifies the
-- color model conversion from Y’CBCR to R’G’B' defined in BT.601 and
-- described in the “BT.601 Y’CBCR conversion” section of the Khronos
-- Data Format Specification.
-- - VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_2020 specifies
-- the color model conversion from Y’CBCR to R’G’B' defined in BT.2020
-- and described in the “BT.2020 Y’CBCR conversion” section of the
-- Khronos Data Format Specification.
--
--
-- In the VK_SAMPLER_YCBCR_MODEL_CONVERSION_YCBCR_* color
-- models, for the input to the sampler Y’CBCR range expansion and model
-- conversion:
--
--
-- - the Y (Y' luma) channel corresponds to the G channel of an RGB
-- image.
-- - the CB (CB or “U” blue color difference) channel corresponds to
-- the B channel of an RGB image.
-- - the CR (CR or “V” red color difference) channel corresponds to the
-- R channel of an RGB image.
-- - the alpha channel, if present, is not modified by color model
-- conversion.
--
--
-- These rules reflect the mapping of channels after the channel swizzle
-- operation (controlled by
-- VkSamplerYcbcrConversionCreateInfo::components).
--
-- Note
--
-- For example, an “YUVA” 32-bit format comprising four 8-bit channels
-- can be implemented as VK_FORMAT_R8G8B8A8_UNORM with a
-- component mapping:
--
--
-- - components.a =
-- VK_COMPONENT_SWIZZLE_IDENTITY
-- - components.r = VK_COMPONENT_SWIZZLE_B
-- - components.g = VK_COMPONENT_SWIZZLE_R
-- - components.b = VK_COMPONENT_SWIZZLE_G
--
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkSamplerYcbcrConversionCreateInfo
newtype VkSamplerYcbcrModelConversion
VkSamplerYcbcrModelConversion :: Int32 -> VkSamplerYcbcrModelConversion
-- | VkSamplerYcbcrRange - Range of encoded values in a color space
--
-- Description
--
--
-- - VK_SAMPLER_YCBCR_RANGE_ITU_FULL specifies that the full
-- range of the encoded values are valid and interpreted according to the
-- ITU “full range” quantization rules.
--
--
--
-- - VK_SAMPLER_YCBCR_RANGE_ITU_NARROW specifies that headroom
-- and foot room are reserved in the numerical range of encoded values,
-- and the remaining values are expanded according to the ITU “narrow
-- range” quantization rules.
--
--
-- The formulae for these conversions is described in the Sampler
-- Y’CBCR Range Expansion section of the Image Operations
-- chapter.
--
-- No range modification takes place if ycbcrModel is
-- VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY; the
-- ycbcrRange field of
-- VkSamplerYcbcrConversionCreateInfo is ignored in this case.
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkSamplerYcbcrConversionCreateInfo
newtype VkSamplerYcbcrRange
VkSamplerYcbcrRange :: Int32 -> VkSamplerYcbcrRange
-- | VkChromaLocation - Position of downsampled chroma samples
--
-- See Also
--
-- VkAndroidHardwareBufferFormatPropertiesANDROID,
-- VkSamplerYcbcrConversionCreateInfo
newtype VkChromaLocation
VkChromaLocation :: Int32 -> VkChromaLocation
-- | VK_CHROMA_LOCATION_COSITED_EVEN specifies that downsampled
-- chroma samples are aligned with luma samples with even coordinates.
-- | VK_CHROMA_LOCATION_MIDPOINT specifies that downsampled chroma
-- samples are located half way between each even luma sample and the
-- nearest higher odd luma sample.
-- | VK_FORMAT_G8B8G8R8_422_UNORM specifies a four-component,
-- 32-bit format containing a pair of G components, an R component, and a
-- B component, collectively encoding a 2×1 rectangle of unsigned
-- normalized RGB texel data. One G value is present at each i
-- coordinate, with the B and R values shared across both G values and
-- thus recorded at half the horizontal resolution of the image. This
-- format has an 8-bit G component for the even i coordinate in
-- byte 0, an 8-bit B component in byte 1, an 8-bit G component for the
-- odd i coordinate in byte 2, and an 8-bit R component in byte 3.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_B8G8R8G8_422_UNORM specifies a four-component,
-- 32-bit format containing a pair of G components, an R component, and a
-- B component, collectively encoding a 2×1 rectangle of unsigned
-- normalized RGB texel data. One G value is present at each i
-- coordinate, with the B and R values shared across both G values and
-- thus recorded at half the horizontal resolution of the image. This
-- format has an 8-bit B component in byte 0, an 8-bit G component for
-- the even i coordinate in byte 1, an 8-bit R component in byte
-- 2, and an 8-bit G component for the odd i coordinate in byte 3.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM specifies a unsigned
-- normalized multi-planar format that has an 8-bit G component in
-- plane 0, an 8-bit B component in plane 1, and an 8-bit R component in
-- plane 2. The horizontal and vertical dimensions of the R and B planes
-- are halved relative to the image dimensions, and each R and B
-- component is shared with the G components for which (\lfloor i_G
-- \times 0.5 \rfloor = i_B = i_R) and (\lfloor j_G \times 0.5 \rfloor =
-- j_B = j_R). The location of each plane when this image is in linear
-- layout can be determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G8_B8R8_2PLANE_420_UNORM specifies a unsigned
-- normalized multi-planar format that has an 8-bit G component in
-- plane 0, and a two-component, 16-bit BR plane 1 consisting of an 8-bit
-- B component in byte 0 and an 8-bit R component in byte 1. The
-- horizontal and vertical dimensions of the BR plane is halved relative
-- to the image dimensions, and each R and B value is shared with the G
-- components for which (\lfloor i_G \times 0.5 \rfloor = i_B = i_R) and
-- <math>. The location of each plane when this image is in linear
-- layout can be determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G8_B8_R8_3PLANE_422_UNORM specifies a unsigned
-- normalized multi-planar format that has an 8-bit G component in
-- plane 0, an 8-bit B component in plane 1, and an 8-bit R component in
-- plane 2. The horizontal dimension of the R and B plane is halved
-- relative to the image dimensions, and each R and B value is shared
-- with the G components for which <math>. The location of each
-- plane when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G8_B8R8_2PLANE_422_UNORM specifies a unsigned
-- normalized multi-planar format that has an 8-bit G component in
-- plane 0, and a two-component, 16-bit BR plane 1 consisting of an 8-bit
-- B component in byte 0 and an 8-bit R component in byte 1. The
-- horizontal dimensions of the BR plane is halved relative to the image
-- dimensions, and each R and B value is shared with the G components for
-- which <math>. The location of each plane when this image is in
-- linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G8_B8_R8_3PLANE_444_UNORM specifies a unsigned
-- normalized multi-planar format that has an 8-bit G component in
-- plane 0, an 8-bit B component in plane 1, and an 8-bit R component in
-- plane 2. Each plane has the same dimensions and each R, G and B
-- component contributes to a single texel. The location of each plane
-- when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane.
-- | VK_FORMAT_R10X6_UNORM_PACK16 specifies a one-component,
-- 16-bit unsigned normalized format that has a single 10-bit R component
-- in the top 10 bits of a 16-bit word, with the bottom 6 bits set to 0.
-- | VK_FORMAT_R10X6G10X6_UNORM_2PACK16 specifies a two-component,
-- 32-bit unsigned normalized format that has a 10-bit R component in the
-- top 10 bits of the word in bytes 0..1, and a 10-bit G component in the
-- top 10 bits of the word in bytes 2..3, with the bottom 6 bits of each
-- word set to 0.
-- | VK_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16 specifies a
-- four-component, 64-bit unsigned normalized format that has a 10-bit R
-- component in the top 10 bits of the word in bytes 0..1, a 10-bit G
-- component in the top 10 bits of the word in bytes 2..3, a 10-bit B
-- component in the top 10 bits of the word in bytes 4..5, and a 10-bit A
-- component in the top 10 bits of the word in bytes 6..7, with the
-- bottom 6 bits of each word set to 0.
-- | VK_FORMAT_G10X6B10X6G10X6R10X6_422_UNORM_4PACK16 specifies a
-- four-component, 64-bit format containing a pair of G components, an R
-- component, and a B component, collectively encoding a 2×1 rectangle of
-- unsigned normalized RGB texel data. One G value is present at each
-- i coordinate, with the B and R values shared across both G
-- values and thus recorded at half the horizontal resolution of the
-- image. This format has a 10-bit G component for the even i
-- coordinate in the top 10 bits of the word in bytes 0..1, a 10-bit B
-- component in the top 10 bits of the word in bytes 2..3, a 10-bit G
-- component for the odd i coordinate in the top 10 bits of the
-- word in bytes 4..5, and a 10-bit R component in the top 10 bits of the
-- word in bytes 6..7, with the bottom 6 bits of each word set to 0.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_B10X6G10X6R10X6G10X6_422_UNORM_4PACK16 specifies a
-- four-component, 64-bit format containing a pair of G components, an R
-- component, and a B component, collectively encoding a 2×1 rectangle of
-- unsigned normalized RGB texel data. One G value is present at each
-- i coordinate, with the B and R values shared across both G
-- values and thus recorded at half the horizontal resolution of the
-- image. This format has a 10-bit B component in the top 10 bits of the
-- word in bytes 0..1, a 10-bit G component for the even i
-- coordinate in the top 10 bits of the word in bytes 2..3, a 10-bit R
-- component in the top 10 bits of the word in bytes 4..5, and a 10-bit G
-- component for the odd i coordinate in the top 10 bits of the
-- word in bytes 6..7, with the bottom 6 bits of each word set to 0.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 10-bit G component in the top 10 bits of each 16-bit word of plane 0,
-- a 10-bit B component in the top 10 bits of each 16-bit word of plane
-- 1, and a 10-bit R component in the top 10 bits of each 16-bit word of
-- plane 2, with the bottom 6 bits of each word set to 0. The horizontal
-- and vertical dimensions of the R and B planes are halved relative to
-- the image dimensions, and each R and B component is shared with the G
-- components for which (\lfloor i_G \times 0.5 \rfloor = i_B = i_R) and
-- (\lfloor j_G \times 0.5 \rfloor = j_B = j_R). The location of each
-- plane when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G10X6_B10X6R10X6_2PLANE_420_UNORM_3PACK16 specifies
-- a unsigned normalized multi-planar format that has a 10-bit G
-- component in the top 10 bits of each 16-bit word of plane 0, and a
-- two-component, 32-bit BR plane 1 consisting of a 10-bit B component in
-- the top 10 bits of the word in bytes 0..1, and a 10-bit R component in
-- the top 10 bits of the word in bytes 2..3, the bottom 6 bits of each
-- word set to 0. The horizontal and vertical dimensions of the BR plane
-- is halved relative to the image dimensions, and each R and B value is
-- shared with the G components for which (\lfloor i_G \times 0.5 \rfloor
-- = i_B = i_R) and <math>. The location of each plane when this
-- image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_422_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 10-bit G component in the top 10 bits of each 16-bit word of plane 0,
-- a 10-bit B component in the top 10 bits of each 16-bit word of plane
-- 1, and a 10-bit R component in the top 10 bits of each 16-bit word of
-- plane 2, with the bottom 6 bits of each word set to 0. The horizontal
-- dimension of the R and B plane is halved relative to the image
-- dimensions, and each R and B value is shared with the G components for
-- which <math>. The location of each plane when this image is in
-- linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G10X6_B10X6R10X6_2PLANE_422_UNORM_3PACK16 specifies
-- a unsigned normalized multi-planar format that has a 10-bit G
-- component in the top 10 bits of each 16-bit word of plane 0, and a
-- two-component, 32-bit BR plane 1 consisting of a 10-bit B component in
-- the top 10 bits of the word in bytes 0..1, and a 10-bit R component in
-- the top 10 bits of the word in bytes 2..3, the bottom 6 bits of each
-- word set to 0. The horizontal dimensions of the BR plane is halved
-- relative to the image dimensions, and each R and B value is shared
-- with the G components for which <math>. The location of each
-- plane when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_444_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 10-bit G component in the top 10 bits of each 16-bit word of plane 0,
-- a 10-bit B component in the top 10 bits of each 16-bit word of plane
-- 1, and a 10-bit R component in the top 10 bits of each 16-bit word of
-- plane 2, with the bottom 6 bits of each word set to 0. Each plane has
-- the same dimensions and each R, G and B component contributes to a
-- single texel. The location of each plane when this image is in linear
-- layout can be determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane.
-- | VK_FORMAT_R12X4_UNORM_PACK16 specifies a one-component,
-- 16-bit unsigned normalized format that has a single 12-bit R component
-- in the top 12 bits of a 16-bit word, with the bottom 4 bits set to 0.
-- | VK_FORMAT_R12X4G12X4_UNORM_2PACK16 specifies a two-component,
-- 32-bit unsigned normalized format that has a 12-bit R component in the
-- top 12 bits of the word in bytes 0..1, and a 12-bit G component in the
-- top 12 bits of the word in bytes 2..3, with the bottom 4 bits of each
-- word set to 0.
-- | VK_FORMAT_R12X4G12X4B12X4A12X4_UNORM_4PACK16 specifies a
-- four-component, 64-bit unsigned normalized format that has a 12-bit R
-- component in the top 12 bits of the word in bytes 0..1, a 12-bit G
-- component in the top 12 bits of the word in bytes 2..3, a 12-bit B
-- component in the top 12 bits of the word in bytes 4..5, and a 12-bit A
-- component in the top 12 bits of the word in bytes 6..7, with the
-- bottom 4 bits of each word set to 0.
-- | VK_FORMAT_G12X4B12X4G12X4R12X4_422_UNORM_4PACK16 specifies a
-- four-component, 64-bit format containing a pair of G components, an R
-- component, and a B component, collectively encoding a 2×1 rectangle of
-- unsigned normalized RGB texel data. One G value is present at each
-- i coordinate, with the B and R values shared across both G
-- values and thus recorded at half the horizontal resolution of the
-- image. This format has a 12-bit G component for the even i
-- coordinate in the top 12 bits of the word in bytes 0..1, a 12-bit B
-- component in the top 12 bits of the word in bytes 2..3, a 12-bit G
-- component for the odd i coordinate in the top 12 bits of the
-- word in bytes 4..5, and a 12-bit R component in the top 12 bits of the
-- word in bytes 6..7, with the bottom 4 bits of each word set to 0.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_B12X4G12X4R12X4G12X4_422_UNORM_4PACK16 specifies a
-- four-component, 64-bit format containing a pair of G components, an R
-- component, and a B component, collectively encoding a 2×1 rectangle of
-- unsigned normalized RGB texel data. One G value is present at each
-- i coordinate, with the B and R values shared across both G
-- values and thus recorded at half the horizontal resolution of the
-- image. This format has a 12-bit B component in the top 12 bits of the
-- word in bytes 0..1, a 12-bit G component for the even i
-- coordinate in the top 12 bits of the word in bytes 2..3, a 12-bit R
-- component in the top 12 bits of the word in bytes 4..5, and a 12-bit G
-- component for the odd i coordinate in the top 12 bits of the
-- word in bytes 6..7, with the bottom 4 bits of each word set to 0.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_420_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 12-bit G component in the top 12 bits of each 16-bit word of plane 0,
-- a 12-bit B component in the top 12 bits of each 16-bit word of plane
-- 1, and a 12-bit R component in the top 12 bits of each 16-bit word of
-- plane 2, with the bottom 4 bits of each word set to 0. The horizontal
-- and vertical dimensions of the R and B planes are halved relative to
-- the image dimensions, and each R and B component is shared with the G
-- components for which (\lfloor i_G \times 0.5 \rfloor = i_B = i_R) and
-- (\lfloor j_G \times 0.5 \rfloor = j_B = j_R). The location of each
-- plane when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16 specifies
-- a unsigned normalized multi-planar format that has a 12-bit G
-- component in the top 12 bits of each 16-bit word of plane 0, and a
-- two-component, 32-bit BR plane 1 consisting of a 12-bit B component in
-- the top 12 bits of the word in bytes 0..1, and a 12-bit R component in
-- the top 12 bits of the word in bytes 2..3, the bottom 4 bits of each
-- word set to 0. The horizontal and vertical dimensions of the BR plane
-- is halved relative to the image dimensions, and each R and B value is
-- shared with the G components for which (\lfloor i_G \times 0.5 \rfloor
-- = i_B = i_R) and <math>. The location of each plane when this
-- image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 12-bit G component in the top 12 bits of each 16-bit word of plane 0,
-- a 12-bit B component in the top 12 bits of each 16-bit word of plane
-- 1, and a 12-bit R component in the top 12 bits of each 16-bit word of
-- plane 2, with the bottom 4 bits of each word set to 0. The horizontal
-- dimension of the R and B plane is halved relative to the image
-- dimensions, and each R and B value is shared with the G components for
-- which <math>. The location of each plane when this image is in
-- linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16 specifies
-- a unsigned normalized multi-planar format that has a 12-bit G
-- component in the top 12 bits of each 16-bit word of plane 0, and a
-- two-component, 32-bit BR plane 1 consisting of a 12-bit B component in
-- the top 12 bits of the word in bytes 0..1, and a 12-bit R component in
-- the top 12 bits of the word in bytes 2..3, the bottom 4 bits of each
-- word set to 0. The horizontal dimensions of the BR plane is halved
-- relative to the image dimensions, and each R and B value is shared
-- with the G components for which <math>. The location of each
-- plane when this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16
-- specifies a unsigned normalized multi-planar format that has a
-- 12-bit G component in the top 12 bits of each 16-bit word of plane 0,
-- a 12-bit B component in the top 12 bits of each 16-bit word of plane
-- 1, and a 12-bit R component in the top 12 bits of each 16-bit word of
-- plane 2, with the bottom 4 bits of each word set to 0. Each plane has
-- the same dimensions and each R, G and B component contributes to a
-- single texel. The location of each plane when this image is in linear
-- layout can be determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane.
-- | VK_FORMAT_G16B16G16R16_422_UNORM specifies a four-component,
-- 64-bit format containing a pair of G components, an R component, and a
-- B component, collectively encoding a 2×1 rectangle of unsigned
-- normalized RGB texel data. One G value is present at each i
-- coordinate, with the B and R values shared across both G values and
-- thus recorded at half the horizontal resolution of the image. This
-- format has a 16-bit G component for the even i coordinate in
-- the word in bytes 0..1, a 16-bit B component in the word in bytes
-- 2..3, a 16-bit G component for the odd i coordinate in the word
-- in bytes 4..5, and a 16-bit R component in the word in bytes 6..7.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_B16G16R16G16_422_UNORM specifies a four-component,
-- 64-bit format containing a pair of G components, an R component, and a
-- B component, collectively encoding a 2×1 rectangle of unsigned
-- normalized RGB texel data. One G value is present at each i
-- coordinate, with the B and R values shared across both G values and
-- thus recorded at half the horizontal resolution of the image. This
-- format has a 16-bit B component in the word in bytes 0..1, a 16-bit G
-- component for the even i coordinate in the word in bytes 2..3,
-- a 16-bit R component in the word in bytes 4..5, and a 16-bit G
-- component for the odd i coordinate in the word in bytes 6..7.
-- Images in this format must be defined with a width that is a
-- multiple of two. For the purposes of the constraints on copy extents,
-- this format is treated as a compressed format with a 2×1 compressed
-- texel block.
-- | VK_FORMAT_G16_B16_R16_3PLANE_420_UNORM specifies a unsigned
-- normalized multi-planar format that has a 16-bit G component in
-- each 16-bit word of plane 0, a 16-bit B component in each 16-bit word
-- of plane 1, and a 16-bit R component in each 16-bit word of plane 2.
-- The horizontal and vertical dimensions of the R and B planes are
-- halved relative to the image dimensions, and each R and B component is
-- shared with the G components for which (\lfloor i_G \times 0.5 \rfloor
-- = i_B = i_R) and (\lfloor j_G \times 0.5 \rfloor = j_B = j_R). The
-- location of each plane when this image is in linear layout can be
-- determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G16_B16R16_2PLANE_420_UNORM specifies a unsigned
-- normalized multi-planar format that has a 16-bit G component in
-- each 16-bit word of plane 0, and a two-component, 32-bit BR plane 1
-- consisting of a 16-bit B component in the word in bytes 0..1, and a
-- 16-bit R component in the word in bytes 2..3. The horizontal and
-- vertical dimensions of the BR plane is halved relative to the image
-- dimensions, and each R and B value is shared with the G components for
-- which (\lfloor i_G \times 0.5 \rfloor = i_B = i_R) and <math>.
-- The location of each plane when this image is in linear layout can be
-- determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width and height that is a
-- multiple of two.
-- | VK_FORMAT_G16_B16_R16_3PLANE_422_UNORM specifies a unsigned
-- normalized multi-planar format that has a 16-bit G component in
-- each 16-bit word of plane 0, a 16-bit B component in each 16-bit word
-- of plane 1, and a 16-bit R component in each 16-bit word of plane 2.
-- The horizontal dimension of the R and B plane is halved relative to
-- the image dimensions, and each R and B value is shared with the G
-- components for which <math>. The location of each plane when
-- this image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G16_B16R16_2PLANE_422_UNORM specifies a unsigned
-- normalized multi-planar format that has a 16-bit G component in
-- each 16-bit word of plane 0, and a two-component, 32-bit BR plane 1
-- consisting of a 16-bit B component in the word in bytes 0..1, and a
-- 16-bit R component in the word in bytes 2..3. The horizontal
-- dimensions of the BR plane is halved relative to the image dimensions,
-- and each R and B value is shared with the G components for which
-- <math>. The location of each plane when this image is in linear
-- layout can be determined via vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane, and
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the BR plane. Images in this
-- format must be defined with a width that is a multiple of two.
-- | VK_FORMAT_G16_B16_R16_3PLANE_444_UNORM specifies a unsigned
-- normalized multi-planar format that has a 16-bit G component in
-- each 16-bit word of plane 0, a 16-bit B component in each 16-bit word
-- of plane 1, and a 16-bit R component in each 16-bit word of plane 2.
-- Each plane has the same dimensions and each R, G and B component
-- contributes to a single texel. The location of each plane when this
-- image is in linear layout can be determined via
-- vkGetImageSubresourceLayout, using
-- VK_IMAGE_ASPECT_PLANE_0_BIT for the G plane,
-- VK_IMAGE_ASPECT_PLANE_1_BIT for the B plane, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT for the R plane.
-- | VkSamplerYcbcrConversion - NO SHORT DESCRIPTION PROVIDED
--
-- Description
--
-- See Also
--
-- VkSamplerYcbcrConversionInfo,
-- vkCreateSamplerYcbcrConversion,
-- vkCreateSamplerYcbcrConversionKHR,
-- vkDestroySamplerYcbcrConversion,
-- vkDestroySamplerYcbcrConversionKHR
type VkSamplerYcbcrConversion = Ptr VkSamplerYcbcrConversion_T
-- | vkCreateSamplerYcbcrConversion - Create a new Ycbcr conversion
--
-- Parameters
--
--
-- - device is the logical device that creates the sampler
-- Y’CBCR conversion.
--
--
--
--
-- Description
--
-- The interpretation of the configured sampler Y’CBCR conversion is
-- described in more detail in the description of sampler Y’CBCR
-- conversion in the Image Operations chapter.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkSamplerYcbcrConversionCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pYcbcrConversion must be a valid pointer to a
-- VkSamplerYcbcrConversion handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkSamplerYcbcrConversion,
-- VkSamplerYcbcrConversionCreateInfo
vkCreateSamplerYcbcrConversion :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkSamplerYcbcrConversionCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pYcbcrConversion" ::: Ptr VkSamplerYcbcrConversion) -> IO VkResult
-- | vkDestroySamplerYcbcrConversion - Destroy a created Y’CbCr conversion
--
-- Parameters
--
--
-- - device is the logical device that destroys the Y’CBCR
-- conversion.
--
--
--
-- - ycbcrConversion is the conversion to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If ycbcrConversion is not VK_NULL_HANDLE,
-- ycbcrConversion must be a valid
-- VkSamplerYcbcrConversion handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If ycbcrConversion is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to ycbcrConversion must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkSamplerYcbcrConversion
vkDestroySamplerYcbcrConversion :: ("device" ::: VkDevice) -> ("ycbcrConversion" ::: VkSamplerYcbcrConversion) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkSamplerYcbcrConversionInfo - Structure specifying Y’CbCr conversion
-- to a sampler or image view
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_INFO
--
--
--
-- - conversion must be a valid
-- VkSamplerYcbcrConversion handle
--
--
-- See Also
--
-- VkSamplerYcbcrConversion, VkStructureType
data VkSamplerYcbcrConversionInfo
VkSamplerYcbcrConversionInfo :: VkStructureType -> Ptr () -> VkSamplerYcbcrConversion -> VkSamplerYcbcrConversionInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkSamplerYcbcrConversionInfo] :: VkSamplerYcbcrConversionInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSamplerYcbcrConversionInfo] :: VkSamplerYcbcrConversionInfo -> Ptr ()
-- | conversion is a VkSamplerYcbcrConversion handle
-- created with vkCreateSamplerYcbcrConversion.
[$sel:vkConversion:VkSamplerYcbcrConversionInfo] :: VkSamplerYcbcrConversionInfo -> VkSamplerYcbcrConversion
-- | VkSamplerYcbcrConversionCreateInfo - Structure specifying the
-- parameters of the newly created conversion
--
-- Description
--
-- Note
--
-- Setting forceExplicitReconstruction to VK_TRUE
-- may have a performance penalty on implementations where
-- explicit reconstruction is not the default mode of operation.
--
-- If the pNext chain has an instance of
-- VkExternalFormatANDROID with non-zero externalFormat
-- member, the sampler Y’CBCR conversion object represents an external
-- format conversion, and format must be
-- VK_FORMAT_UNDEFINED. Such conversions must only be
-- used to sample image views with a matching external format.
-- When creating an external format conversion, the value of
-- components is ignored.
--
-- Valid Usage
--
--
-- - If an external format conversion is being created, format
-- must be VK_FORMAT_UNDEFINED, otherwise it must
-- not be VK_FORMAT_UNDEFINED.
--
--
--
-- - format must support
-- VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT or
-- VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT
-- - If the format does not support
-- VK_FORMAT_FEATURE_COSITED_CHROMA_SAMPLES_BIT,
-- xChromaOffset and yChromaOffset must not be
-- VK_CHROMA_LOCATION_COSITED_EVEN
-- - If the format does not support
-- VK_FORMAT_FEATURE_MIDPOINT_CHROMA_SAMPLES_BIT,
-- xChromaOffset and yChromaOffset must not be
-- VK_CHROMA_LOCATION_MIDPOINT
-- - format must represent unsigned normalized values
-- (i.e. the format must be a UNORM format)
-- - If the format has a _422 or _420
-- suffix:
- components.g must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
- components.a
-- must be VK_COMPONENT_SWIZZLE_IDENTITY,
-- VK_COMPONENT_SWIZZLE_ONE, or
-- VK_COMPONENT_SWIZZLE_ZERO
- components.r
-- must be VK_COMPONENT_SWIZZLE_IDENTITY or
-- VK_COMPONENT_SWIZZLE_B
- components.b
-- must be VK_COMPONENT_SWIZZLE_IDENTITY or
-- VK_COMPONENT_SWIZZLE_R
- If either
-- components.r or components.b is
-- VK_COMPONENT_SWIZZLE_IDENTITY, both values must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
-- - If ycbcrModel is not
-- VK_SAMPLER_YCBCR_MODEL_CONVERSION_RGB_IDENTITY, then
-- components.r, components.g, and
-- components.b must correspond to channels of the
-- format; that is, components.r,
-- components.g, and components.b must not be
-- VK_COMPONENT_SWIZZLE_ZERO or
-- VK_COMPONENT_SWIZZLE_ONE, and must not correspond to a
-- channel which contains zero or one as a consequence of conversion
-- to RGBA
-- - If the format does not support
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_CHROMA_RECONSTRUCTION_EXPLICIT_FORCEABLE_BIT,
-- forceExplicitReconstruction must be FALSE
-- - If the format does not support
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_YCBCR_CONVERSION_LINEAR_FILTER_BIT,
-- chromaFilter must be VK_FILTER_NEAREST
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_CREATE_INFO
--
--
--
--
-- If chromaFilter is VK_FILTER_NEAREST, chroma samples
-- are reconstructed to luma channel resolution using nearest-neighbour
-- sampling. Otherwise, chroma samples are reconstructed using
-- interpolation. More details can be found in the description of
-- sampler Y’CBCR conversion in the Image Operations chapter.
--
-- See Also
--
-- VkBool32, VkChromaLocation, VkComponentMapping,
-- VkFilter, VkFormat,
-- VkSamplerYcbcrModelConversion, VkSamplerYcbcrRange,
-- VkStructureType, vkCreateSamplerYcbcrConversion,
-- vkCreateSamplerYcbcrConversionKHR
data VkSamplerYcbcrConversionCreateInfo
VkSamplerYcbcrConversionCreateInfo :: VkStructureType -> Ptr () -> VkFormat -> VkSamplerYcbcrModelConversion -> VkSamplerYcbcrRange -> VkComponentMapping -> VkChromaLocation -> VkChromaLocation -> VkFilter -> VkBool32 -> VkSamplerYcbcrConversionCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> Ptr ()
-- | format is the format of the image from which color
-- information will be retrieved.
[$sel:vkFormat:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkFormat
-- | ycbcrModel describes the color matrix for conversion between
-- color models.
[$sel:vkYcbcrModel:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkSamplerYcbcrModelConversion
-- | ycbcrRange describes whether the encoded values have headroom
-- and foot room, or whether the encoding uses the full numerical range.
[$sel:vkYcbcrRange:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkSamplerYcbcrRange
-- | components applies a swizzle based on
-- VkComponentSwizzle enums prior to range expansion and color
-- model conversion.
[$sel:vkComponents:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkComponentMapping
-- | xChromaOffset describes the sample location associated
-- with downsampled chroma channels in the x dimension.
-- xChromaOffset has no effect for formats in which chroma
-- channels are the same resolution as the luma channel.
[$sel:vkXChromaOffset:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkChromaLocation
-- | yChromaOffset describes the sample location associated
-- with downsampled chroma channels in the y dimension.
-- yChromaOffset has no effect for formats in which the chroma
-- channels are not downsampled vertically.
[$sel:vkYChromaOffset:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkChromaLocation
-- | chromaFilter is the filter for chroma reconstruction.
[$sel:vkChromaFilter:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkFilter
-- | forceExplicitReconstruction can be used to ensure that
-- reconstruction is done explicitly, if supported.
[$sel:vkForceExplicitReconstruction:VkSamplerYcbcrConversionCreateInfo] :: VkSamplerYcbcrConversionCreateInfo -> VkBool32
-- | VkBindImagePlaneMemoryInfo - Structure specifying how to bind an image
-- plane to memory
--
-- Description
--
-- Valid Usage
--
--
-- - planeAspect must be a single valid plane aspect
-- for the image format (that is, planeAspect must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT or
-- VK_IMAGE_ASPECT_PLANE_1_BIT for “_2PLANE” formats
-- and planeAspect must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT for “_3PLANE”
-- formats)
--
--
--
-- - A single call to vkBindImageMemory2 must bind all or
-- none of the planes of an image (i.e. bindings to all planes of an
-- image must be made in a single vkBindImageMemory2 call),
-- as separate bindings
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_IMAGE_PLANE_MEMORY_INFO
--
--
--
--
-- See Also
--
-- VkImageAspectFlagBits, VkStructureType
data VkBindImagePlaneMemoryInfo
VkBindImagePlaneMemoryInfo :: VkStructureType -> Ptr () -> VkImageAspectFlagBits -> VkBindImagePlaneMemoryInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBindImagePlaneMemoryInfo] :: VkBindImagePlaneMemoryInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBindImagePlaneMemoryInfo] :: VkBindImagePlaneMemoryInfo -> Ptr ()
-- | planeAspect is the aspect of the disjoint image plane to
-- bind.
[$sel:vkPlaneAspect:VkBindImagePlaneMemoryInfo] :: VkBindImagePlaneMemoryInfo -> VkImageAspectFlagBits
-- | VkImagePlaneMemoryRequirementsInfo - Structure specifying image plane
-- for memory requirements
--
-- Description
--
-- Valid Usage
--
--
-- - planeAspect must be an aspect that exists in the
-- format; that is, for a two-plane image planeAspect
-- must be VK_IMAGE_ASPECT_PLANE_0_BIT or
-- VK_IMAGE_ASPECT_PLANE_1_BIT, and for a three-plane image
-- planeAspect must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT or
-- VK_IMAGE_ASPECT_PLANE_2_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_PLANE_MEMORY_REQUIREMENTS_INFO
--
--
--
--
-- See Also
--
-- VkImageAspectFlagBits, VkStructureType
data VkImagePlaneMemoryRequirementsInfo
VkImagePlaneMemoryRequirementsInfo :: VkStructureType -> Ptr () -> VkImageAspectFlagBits -> VkImagePlaneMemoryRequirementsInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkImagePlaneMemoryRequirementsInfo] :: VkImagePlaneMemoryRequirementsInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImagePlaneMemoryRequirementsInfo] :: VkImagePlaneMemoryRequirementsInfo -> Ptr ()
-- | planeAspect is the aspect corresponding to the image plane to
-- query.
[$sel:vkPlaneAspect:VkImagePlaneMemoryRequirementsInfo] :: VkImagePlaneMemoryRequirementsInfo -> VkImageAspectFlagBits
-- | VkPhysicalDeviceSamplerYcbcrConversionFeatures - Structure describing
-- Y’CbCr conversion features that can be supported by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceSamplerYcbcrConversionFeatures structure
-- describe the following feature:
--
-- Description
--
--
-- - samplerYcbcrConversion specifies whether the
-- implementation supports sampler Y’CBCR conversion. If
-- samplerYcbcrConversion is VK_FALSE, sampler Y’CBCR
-- conversion is not supported, and samplers using sampler Y’CBCR
-- conversion must not be used.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_SAMPLER_YCBCR_CONVERSION_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceSamplerYcbcrConversionFeatures
VkPhysicalDeviceSamplerYcbcrConversionFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceSamplerYcbcrConversionFeatures
[$sel:vkSType:VkPhysicalDeviceSamplerYcbcrConversionFeatures] :: VkPhysicalDeviceSamplerYcbcrConversionFeatures -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceSamplerYcbcrConversionFeatures] :: VkPhysicalDeviceSamplerYcbcrConversionFeatures -> Ptr ()
[$sel:vkSamplerYcbcrConversion:VkPhysicalDeviceSamplerYcbcrConversionFeatures] :: VkPhysicalDeviceSamplerYcbcrConversionFeatures -> VkBool32
-- | VkSamplerYcbcrConversionImageFormatProperties - Structure specifying
-- combined image sampler descriptor count for multi-planar images
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SAMPLER_YCBCR_CONVERSION_IMAGE_FORMAT_PROPERTIES
--
--
-- See Also
--
-- VkStructureType
data VkSamplerYcbcrConversionImageFormatProperties
VkSamplerYcbcrConversionImageFormatProperties :: VkStructureType -> Ptr () -> Word32 -> VkSamplerYcbcrConversionImageFormatProperties
-- | sType is the type of this structure.
[$sel:vkSType:VkSamplerYcbcrConversionImageFormatProperties] :: VkSamplerYcbcrConversionImageFormatProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSamplerYcbcrConversionImageFormatProperties] :: VkSamplerYcbcrConversionImageFormatProperties -> Ptr ()
-- | combinedImageSamplerDescriptorCount is the number of combined
-- image sampler descriptors that the implementation uses to access the
-- format.
[$sel:vkCombinedImageSamplerDescriptorCount:VkSamplerYcbcrConversionImageFormatProperties] :: VkSamplerYcbcrConversionImageFormatProperties -> Word32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionImageFormatProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionImageFormatProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkPhysicalDeviceSamplerYcbcrConversionFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkPhysicalDeviceSamplerYcbcrConversionFeatures
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkImagePlaneMemoryRequirementsInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkImagePlaneMemoryRequirementsInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkBindImagePlaneMemoryInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkBindImagePlaneMemoryInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkChromaLocation
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkChromaLocation
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkChromaLocation
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrRange
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrRange
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrRange
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrModelConversion
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrModelConversion
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrModelConversion
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionImageFormatProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkPhysicalDeviceSamplerYcbcrConversionFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkImagePlaneMemoryRequirementsInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkBindImagePlaneMemoryInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrConversionInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkChromaLocation
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkChromaLocation
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrRange
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrRange
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrModelConversion
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_sampler_ycbcr_conversion.VkSamplerYcbcrModelConversion
module Graphics.Vulkan.Extensions.VK_KHR_sampler_ycbcr_conversion
vkCreateSamplerYcbcrConversionKHR :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkSamplerYcbcrConversionCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pYcbcrConversion" ::: Ptr VkSamplerYcbcrConversion) -> IO VkResult
vkDestroySamplerYcbcrConversionKHR :: ("device" ::: VkDevice) -> ("ycbcrConversion" ::: VkSamplerYcbcrConversion) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
type VkSamplerYcbcrModelConversionKHR = VkSamplerYcbcrModelConversion
type VkSamplerYcbcrRangeKHR = VkSamplerYcbcrRange
type VkChromaLocationKHR = VkChromaLocation
type VkSamplerYcbcrConversionKHR = VkSamplerYcbcrConversion
type VkSamplerYcbcrConversionInfoKHR = VkSamplerYcbcrConversionInfo
type VkSamplerYcbcrConversionCreateInfoKHR = VkSamplerYcbcrConversionCreateInfo
type VkBindImagePlaneMemoryInfoKHR = VkBindImagePlaneMemoryInfo
type VkImagePlaneMemoryRequirementsInfoKHR = VkImagePlaneMemoryRequirementsInfo
type VkPhysicalDeviceSamplerYcbcrConversionFeaturesKHR = VkPhysicalDeviceSamplerYcbcrConversionFeatures
type VkSamplerYcbcrConversionImageFormatPropertiesKHR = VkSamplerYcbcrConversionImageFormatProperties
module Graphics.Vulkan.Core10.Fence
-- | VkFenceCreateFlagBits - Bitmask specifying initial state and behavior
-- of a fence
--
-- See Also
--
-- VkFenceCreateFlags
newtype VkFenceCreateFlagBits
VkFenceCreateFlagBits :: VkFlags -> VkFenceCreateFlagBits
-- | VK_FENCE_CREATE_SIGNALED_BIT specifies that the fence object
-- is created in the signaled state. Otherwise, it is created in the
-- unsignaled state.
-- | vkCreateFence - Create a new fence object
--
-- Parameters
--
--
-- - device is the logical device that creates the fence.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkFenceCreateInfo structure which contains information about
-- how the fence is to be created.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pFence points to a handle in which the resulting fence
-- object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkFenceCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pFence must be a valid pointer to a
-- VkFence handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkFence,
-- VkFenceCreateInfo
vkCreateFence :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkFenceCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pFence" ::: Ptr VkFence) -> IO VkResult
-- | vkDestroyFence - Destroy a fence object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- fence.
--
--
--
-- - fence is the handle of the fence to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All queue submission commands that refer to fence
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- fence was created, a compatible set of callbacks must
-- be provided here
-- - If no VkAllocationCallbacks were provided when
-- fence was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If fence is not VK_NULL_HANDLE, fence
-- must be a valid VkFence handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If fence is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to fence must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkFence
vkDestroyFence :: ("device" ::: VkDevice) -> ("fence" ::: VkFence) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkResetFences - Resets one or more fence objects
--
-- Parameters
--
--
-- - device is the logical device that owns the fences.
--
--
--
-- - fenceCount is the number of fences to reset.
-- - pFences is a pointer to an array of fence handles to
-- reset.
--
--
-- Description
--
-- If any member of pFences currently has its payload
-- imported with temporary permanence, that fence’s prior permanent
-- payload is first restored. The remaining operations described
-- therefore operate on the restored payload.
--
-- When vkResetFences is executed on the host, it defines a /fence
-- unsignal operation/ for each fence, which resets the fence to the
-- unsignaled state.
--
-- If any member of pFences is already in the unsignaled state
-- when vkResetFences is executed, then vkResetFences has
-- no effect on that fence.
--
-- Valid Usage
--
--
-- - Each element of pFences must not be currently
-- associated with any queue command that has not yet completed execution
-- on that queue
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pFences must be a valid pointer to an array of
-- fenceCount valid VkFence handles
-- - fenceCount must be greater than 0
-- - Each element of pFences must have been created,
-- allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to each member of pFences must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkFence
vkResetFences :: ("device" ::: VkDevice) -> ("fenceCount" ::: Word32) -> ("pFences" ::: Ptr VkFence) -> IO VkResult
-- | vkGetFenceStatus - Return the status of a fence
--
-- Parameters
--
--
-- - device is the logical device that owns the fence.
--
--
--
-- - fence is the handle of the fence to query.
--
--
-- Description
--
-- Upon success, vkGetFenceStatus returns the status of the
-- fence object, with the following return codes:
--
--
-- +-----------------------------------+-----------------------------------+
-- | Status | Meaning |
-- +===================================+===================================+
-- | @VK_SUCCESS@ | The fence specified by @fence@ is |
-- | | signaled. |
-- +-----------------------------------+-----------------------------------+
-- | @VK_NOT_READY@ | The fence specified by @fence@ is |
-- | | unsignaled. |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ERROR_DEVICE_LOST@ | The device has been lost. See |
-- | | <{html_spec_relative}#devsandqueu |
-- | | es-lost-device Lost Device>. |
-- +-----------------------------------+-----------------------------------+
--
-- Fence Object Status Codes
--
--
-- If a queue submission command is pending execution, then the
-- value returned by this command may immediately be out of date.
--
-- If the device has been lost (see Lost Device),
-- vkGetFenceStatus may return any of the above status
-- codes. If the device has been lost and vkGetFenceStatus is
-- called repeatedly, it will eventually return either
-- VK_SUCCESS or VK_ERROR_DEVICE_LOST.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - fence must be a valid VkFence handle
-- - fence must have been created, allocated, or
-- retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkFence
vkGetFenceStatus :: ("device" ::: VkDevice) -> ("fence" ::: VkFence) -> IO VkResult
-- | vkWaitForFences - Wait for one or more fences to become signaled
--
-- Parameters
--
--
-- - device is the logical device that owns the fences.
--
--
--
-- - fenceCount is the number of fences to wait on.
-- - pFences is a pointer to an array of fenceCount
-- fence handles.
-- - waitAll is the condition that must be satisfied to
-- successfully unblock the wait. If waitAll is
-- VK_TRUE, then the condition is that all fences in
-- pFences are signaled. Otherwise, the condition is that at
-- least one fence in pFences is signaled.
-- - timeout is the timeout period in units of nanoseconds.
-- timeout is adjusted to the closest value allowed by the
-- implementation-dependent timeout accuracy, which may be
-- substantially longer than one nanosecond, and may be longer
-- than the requested period.
--
--
-- Description
--
-- If the condition is satisfied when vkWaitForFences is called,
-- then vkWaitForFences returns immediately. If the condition is
-- not satisfied at the time vkWaitForFences is called, then
-- vkWaitForFences will block and wait up to timeout
-- nanoseconds for the condition to become satisfied.
--
-- If timeout is zero, then vkWaitForFences does not
-- wait, but simply returns the current state of the fences.
-- VK_TIMEOUT will be returned in this case if the condition is
-- not satisfied, even though no actual wait was performed.
--
-- If the specified timeout period expires before the condition is
-- satisfied, vkWaitForFences returns VK_TIMEOUT. If
-- the condition is satisfied before timeout nanoseconds has
-- expired, vkWaitForFences returns VK_SUCCESS.
--
-- If device loss occurs (see Lost Device) before the timeout has
-- expired, vkWaitForFences must return in finite time
-- with either VK_SUCCESS or VK_ERROR_DEVICE_LOST.
--
-- Note
--
-- While we guarantee that vkWaitForFences must return in
-- finite time, no guarantees are made that it returns immediately upon
-- device loss. However, the client can reasonably expect that the delay
-- will be on the order of seconds and that calling
-- vkWaitForFences will not result in a permanently (or
-- seemingly permanently) dead process.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pFences must be a valid pointer to an array of
-- fenceCount valid VkFence handles
-- - fenceCount must be greater than 0
-- - Each element of pFences must have been created,
-- allocated, or retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkBool32, VkDevice, VkFence
vkWaitForFences :: ("device" ::: VkDevice) -> ("fenceCount" ::: Word32) -> ("pFences" ::: Ptr VkFence) -> ("waitAll" ::: VkBool32) -> ("timeout" ::: Word64) -> IO VkResult
-- | VkFenceCreateInfo - Structure specifying parameters of a newly created
-- fence
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_FENCE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkFenceCreateFlags, VkStructureType,
-- vkCreateFence
data VkFenceCreateInfo
VkFenceCreateInfo :: VkStructureType -> Ptr () -> VkFenceCreateFlags -> VkFenceCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkFenceCreateInfo] :: VkFenceCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkFenceCreateInfo] :: VkFenceCreateInfo -> Ptr ()
-- | flags is a bitmask of VkFenceCreateFlagBits specifying
-- the initial state and behavior of the fence.
[$sel:vkFlags:VkFenceCreateInfo] :: VkFenceCreateInfo -> VkFenceCreateFlags
-- | VkFenceCreateFlags - Bitmask of VkFenceCreateFlagBits
--
-- Description
--
-- VkFenceCreateFlags is a bitmask type for setting a mask of
-- zero or more VkFenceCreateFlagBits.
--
-- See Also
--
-- VkFenceCreateFlagBits, VkFenceCreateInfo
type VkFenceCreateFlags = VkFenceCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Fence.VkFenceCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Fence.VkFenceCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Fence.VkFenceCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Fence.VkFenceCreateFlagBits
module Graphics.Vulkan.Core10.ExtensionDiscovery
type VK_MAX_EXTENSION_NAME_SIZE = 256
-- | vkEnumerateInstanceExtensionProperties - Returns up to requested
-- number of global extension properties
--
-- Parameters
--
--
-- - pLayerName is either NULL or a pointer to a
-- null-terminated UTF-8 string naming the layer to retrieve extensions
-- from.
--
--
--
-- - pPropertyCount is a pointer to an integer related to the
-- number of extension properties available or queried, as described
-- below.
-- - pProperties is either NULL or a pointer to an
-- array of VkExtensionProperties structures.
--
--
-- Description
--
-- When pLayerName parameter is NULL, only extensions
-- provided by the Vulkan implementation or by implicitly enabled layers
-- are returned. When pLayerName is the name of a layer, the
-- instance extensions provided by that layer are returned.
--
-- If pProperties is NULL, then the number of
-- extensions properties available is returned in
-- pPropertyCount. Otherwise, pPropertyCount
-- must point to a variable set by the user to the number of
-- elements in the pProperties array, and on return the variable
-- is overwritten with the number of structures actually written to
-- pProperties. If pPropertyCount is less than the
-- number of extension properties available, at most
-- pPropertyCount structures will be written. If
-- pPropertyCount is smaller than the number of extensions
-- available, VK_INCOMPLETE will be returned instead of
-- VK_SUCCESS, to indicate that not all the available properties
-- were returned.
--
-- Because the list of available layers may change externally between
-- calls to vkEnumerateInstanceExtensionProperties, two calls
-- may retrieve different results if a pLayerName is available
-- in one call but not in another. The extensions supported by a layer
-- may also change between two calls, e.g. if the layer implementation is
-- replaced by a different version between those calls.
--
-- Valid Usage (Implicit)
--
--
-- - If pLayerName is not NULL, pLayerName
-- must be a null-terminated UTF-8 string
--
--
--
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkExtensionProperties structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkExtensionProperties
vkEnumerateInstanceExtensionProperties :: ("pLayerName" ::: Ptr CChar) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkExtensionProperties) -> IO VkResult
-- | vkEnumerateDeviceExtensionProperties - Returns properties of available
-- physical device extensions
--
-- Parameters
--
--
-- - physicalDevice is the physical device that will be
-- queried.
--
--
--
-- - pLayerName is either NULL or a pointer to a
-- null-terminated UTF-8 string naming the layer to retrieve extensions
-- from.
-- - pPropertyCount is a pointer to an integer related to the
-- number of extension properties available or queried, and is treated in
-- the same fashion as the
-- vkEnumerateInstanceExtensionProperties::pPropertyCount
-- parameter.
-- - pProperties is either NULL or a pointer to an
-- array of VkExtensionProperties structures.
--
--
-- Description
--
-- When pLayerName parameter is NULL, only extensions
-- provided by the Vulkan implementation or by implicitly enabled layers
-- are returned. When pLayerName is the name of a layer, the
-- device extensions provided by that layer are returned.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - If pLayerName is not NULL, pLayerName
-- must be a null-terminated UTF-8 string
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkExtensionProperties structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkExtensionProperties, VkPhysicalDevice
vkEnumerateDeviceExtensionProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pLayerName" ::: Ptr CChar) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkExtensionProperties) -> IO VkResult
-- | VkExtensionProperties - Structure specifying a extension properties
--
-- Description
--
-- See Also
--
-- vkEnumerateDeviceExtensionProperties,
-- vkEnumerateInstanceExtensionProperties
data VkExtensionProperties
VkExtensionProperties :: Vector VK_MAX_EXTENSION_NAME_SIZE CChar -> Word32 -> VkExtensionProperties
-- | extensionName is a null-terminated string specifying the name
-- of the extension.
[$sel:vkExtensionName:VkExtensionProperties] :: VkExtensionProperties -> Vector VK_MAX_EXTENSION_NAME_SIZE CChar
-- | specVersion is the version of this extension. It is an
-- integer, incremented with backward compatible changes.
[$sel:vkSpecVersion:VkExtensionProperties] :: VkExtensionProperties -> Word32
instance GHC.Show.Show Graphics.Vulkan.Core10.ExtensionDiscovery.VkExtensionProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.ExtensionDiscovery.VkExtensionProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.ExtensionDiscovery.VkExtensionProperties
module Graphics.Vulkan.Core10.LayerDiscovery
type VK_MAX_DESCRIPTION_SIZE = 256
-- | vkEnumerateInstanceLayerProperties - Returns up to requested number of
-- global layer properties
--
-- Parameters
--
--
-- - pPropertyCount is a pointer to an integer related to the
-- number of layer properties available or queried, as described
-- below.
--
--
--
-- - pProperties is either NULL or a pointer to an
-- array of VkLayerProperties structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of layer
-- properties available is returned in pPropertyCount.
-- Otherwise, pPropertyCount must point to a variable set
-- by the user to the number of elements in the pProperties
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pProperties. If
-- pPropertyCount is less than the number of layer properties
-- available, at most pPropertyCount structures will be written.
-- If pPropertyCount is smaller than the number of layers
-- available, VK_INCOMPLETE will be returned instead of
-- VK_SUCCESS, to indicate that not all the available layer
-- properties were returned.
--
-- The list of available layers may change at any time due to actions
-- outside of the Vulkan implementation, so two calls to
-- vkEnumerateInstanceLayerProperties with the same parameters
-- may return different results, or retrieve different
-- pPropertyCount values or pProperties contents. Once
-- an instance has been created, the layers enabled for that instance
-- will continue to be enabled and valid for the lifetime of that
-- instance, even if some of them become unavailable for future
-- instances.
--
-- Valid Usage (Implicit)
--
--
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
--
--
--
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkLayerProperties structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkLayerProperties
vkEnumerateInstanceLayerProperties :: ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkLayerProperties) -> IO VkResult
-- | vkEnumerateDeviceLayerProperties - Returns properties of available
-- physical device layers
--
-- Parameters
--
--
-- - pPropertyCount is a pointer to an integer related to the
-- number of layer properties available or queried.
--
--
--
-- - pProperties is either NULL or a pointer to an
-- array of VkLayerProperties structures.
--
--
-- Description
--
-- If pProperties is NULL, then the number of layer
-- properties available is returned in pPropertyCount.
-- Otherwise, pPropertyCount must point to a variable set
-- by the user to the number of elements in the pProperties
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pProperties. If
-- pPropertyCount is less than the number of layer properties
-- available, at most pPropertyCount structures will be written.
-- If pPropertyCount is smaller than the number of layers
-- available, VK_INCOMPLETE will be returned instead of
-- VK_SUCCESS, to indicate that not all the available layer
-- properties were returned.
--
-- The list of layers enumerated by
-- vkEnumerateDeviceLayerProperties must be exactly the
-- sequence of layers enabled for the instance. The members of
-- VkLayerProperties for each enumerated layer must be
-- the same as the properties when the layer was enumerated by
-- vkEnumerateInstanceLayerProperties.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pPropertyCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pPropertyCount is not
-- 0, and pProperties is not NULL,
-- pProperties must be a valid pointer to an array of
-- pPropertyCount VkLayerProperties structures
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkLayerProperties, VkPhysicalDevice
vkEnumerateDeviceLayerProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pPropertyCount" ::: Ptr Word32) -> ("pProperties" ::: Ptr VkLayerProperties) -> IO VkResult
-- | VkLayerProperties - Structure specifying layer properties
--
-- Description
--
-- See Also
--
-- vkEnumerateDeviceLayerProperties,
-- vkEnumerateInstanceLayerProperties
data VkLayerProperties
VkLayerProperties :: Vector VK_MAX_EXTENSION_NAME_SIZE CChar -> Word32 -> Word32 -> Vector VK_MAX_DESCRIPTION_SIZE CChar -> VkLayerProperties
-- | layerName is a null-terminated UTF-8 string specifying the
-- name of the layer. Use this name in the ppEnabledLayerNames
-- array passed in the VkInstanceCreateInfo structure to enable
-- this layer for an instance.
[$sel:vkLayerName:VkLayerProperties] :: VkLayerProperties -> Vector VK_MAX_EXTENSION_NAME_SIZE CChar
-- | specVersion is the Vulkan version the layer was written to,
-- encoded as described in the API Version Numbers and Semantics
-- section.
[$sel:vkSpecVersion:VkLayerProperties] :: VkLayerProperties -> Word32
-- | implementationVersion is the version of this layer. It is an
-- integer, increasing with backward compatible changes.
[$sel:vkImplementationVersion:VkLayerProperties] :: VkLayerProperties -> Word32
-- | description is a null-terminated UTF-8 string providing
-- additional details that can be used by the application to
-- identify the layer.
[$sel:vkDescription:VkLayerProperties] :: VkLayerProperties -> Vector VK_MAX_DESCRIPTION_SIZE CChar
instance GHC.Show.Show Graphics.Vulkan.Core10.LayerDiscovery.VkLayerProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core10.LayerDiscovery.VkLayerProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.LayerDiscovery.VkLayerProperties
module Graphics.Vulkan.Core10.Event
-- | VkEventCreateFlags - Reserved for future use
--
-- Description
--
-- VkEventCreateFlags is a bitmask type for setting a mask, but
-- is currently reserved for future use.
--
-- See Also
--
-- VkEventCreateInfo
newtype VkEventCreateFlags
VkEventCreateFlags :: VkFlags -> VkEventCreateFlags
-- | VkEvent - Opaque handle to a event object
--
-- Description
--
-- See Also
--
-- vkCmdResetEvent, vkCmdSetEvent, vkCmdWaitEvents,
-- vkCreateEvent, vkDestroyEvent, vkGetEventStatus,
-- vkResetEvent, vkSetEvent
type VkEvent = Ptr VkEvent_T
-- | vkCreateEvent - Create a new event object
--
-- Parameters
--
--
-- - device is the logical device that creates the event.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkEventCreateInfo structure which contains information about
-- how the event is to be created.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pEvent points to a handle in which the resulting event
-- object is returned.
--
--
-- Description
--
-- When created, the event object is in the unsignaled state.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkEventCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pEvent must be a valid pointer to a
-- VkEvent handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkEvent,
-- VkEventCreateInfo
vkCreateEvent :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkEventCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pEvent" ::: Ptr VkEvent) -> IO VkResult
-- | vkDestroyEvent - Destroy an event object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- event.
--
--
--
-- - event is the handle of the event to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to event must
-- have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- event was created, a compatible set of callbacks must
-- be provided here
-- - If no VkAllocationCallbacks were provided when
-- event was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If event is not VK_NULL_HANDLE, event
-- must be a valid VkEvent handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If event is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to event must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkEvent
vkDestroyEvent :: ("device" ::: VkDevice) -> ("event" ::: VkEvent) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetEventStatus - Retrieve the status of an event object
--
-- Parameters
--
--
-- - device is the logical device that owns the event.
--
--
--
-- - event is the handle of the event to query.
--
--
-- Description
--
-- Upon success, vkGetEventStatus returns the state of the event
-- object with the following return codes:
--
--
-- +-----------------------------------+-----------------------------------+
-- | Status | Meaning |
-- +===================================+===================================+
-- | @VK_EVENT_SET@ | The event specified by @event@ is |
-- | | signaled. |
-- +-----------------------------------+-----------------------------------+
-- | @VK_EVENT_RESET@ | The event specified by @event@ is |
-- | | unsignaled. |
-- +-----------------------------------+-----------------------------------+
--
-- Event Object Status Codes
--
--
-- If a vkCmdSetEvent or vkCmdResetEvent command is in
-- a command buffer that is in the pending state, then the value
-- returned by this command may immediately be out of date.
--
-- The state of an event can be updated by the host. The state of
-- the event is immediately changed, and subsequent calls to
-- vkGetEventStatus will return the new state. If an event is
-- already in the requested state, then updating it to the same state has
-- no effect.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - event must be a valid VkEvent handle
-- - event must have been created, allocated, or
-- retrieved from device
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkEvent
vkGetEventStatus :: ("device" ::: VkDevice) -> ("event" ::: VkEvent) -> IO VkResult
-- | vkSetEvent - Set an event to signaled state
--
-- Parameters
--
--
-- - device is the logical device that owns the event.
--
--
--
-- - event is the event to set.
--
--
-- Description
--
-- When vkSetEvent is executed on the host, it defines an /event
-- signal operation/ which sets the event to the signaled state.
--
-- If event is already in the signaled state when
-- vkSetEvent is executed, then vkSetEvent has no effect,
-- and no event signal operation occurs.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - event must be a valid VkEvent handle
-- - event must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to event must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkEvent
vkSetEvent :: ("device" ::: VkDevice) -> ("event" ::: VkEvent) -> IO VkResult
-- | vkResetEvent - Reset an event to non-signaled state
--
-- Parameters
--
--
-- - device is the logical device that owns the event.
--
--
--
-- - event is the event to reset.
--
--
-- Description
--
-- When vkResetEvent is executed on the host, it defines an /event
-- unsignal operation/ which resets the event to the unsignaled state.
--
-- If event is already in the unsignaled state when
-- vkResetEvent is executed, then vkResetEvent has no
-- effect, and no event unsignal operation occurs.
--
-- Valid Usage
--
--
-- - event must not be waited on by a
-- vkCmdWaitEvents command that is currently executing
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - event must be a valid VkEvent handle
-- - event must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to event must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkEvent
vkResetEvent :: ("device" ::: VkDevice) -> ("event" ::: VkEvent) -> IO VkResult
-- | VkEventCreateInfo - Structure specifying parameters of a newly created
-- event
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EVENT_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
--
--
-- See Also
--
-- VkEventCreateFlags, VkStructureType,
-- vkCreateEvent
data VkEventCreateInfo
VkEventCreateInfo :: VkStructureType -> Ptr () -> VkEventCreateFlags -> VkEventCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkEventCreateInfo] :: VkEventCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkEventCreateInfo] :: VkEventCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkEventCreateInfo] :: VkEventCreateInfo -> VkEventCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Event.VkEventCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Event.VkEventCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Event.VkEventCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Event.VkEventCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Event.VkEventCreateFlags
module Graphics.Vulkan.Core10.Device
-- | VkDeviceCreateFlags - Reserved for future use
--
-- Description
--
-- VkDeviceCreateFlags is a bitmask type for setting a mask, but
-- is currently reserved for future use.
--
-- See Also
--
-- VkDeviceCreateInfo
newtype VkDeviceCreateFlags
VkDeviceCreateFlags :: VkFlags -> VkDeviceCreateFlags
-- | VkDeviceQueueCreateFlagBits - Bitmask specifying behavior of the queue
--
-- See Also
--
-- VkDeviceQueueCreateFlags
newtype VkDeviceQueueCreateFlagBits
VkDeviceQueueCreateFlagBits :: VkFlags -> VkDeviceQueueCreateFlagBits
-- | vkCreateDevice - Create a new device instance
--
-- Parameters
--
--
-- - physicalDevice must be one of the device handles
-- returned from a call to vkEnumeratePhysicalDevices (see
-- Physical Device Enumeration).
--
--
--
-- - pCreateInfo is a pointer to a VkDeviceCreateInfo
-- structure containing information about how to create the device.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pDevice points to a handle in which the created
-- VkDevice is returned.
--
--
-- Description
--
-- vkCreateDevice verifies that extensions and features
-- requested in the ppEnabledExtensionNames and
-- pEnabledFeatures members of pCreateInfo,
-- respectively, are supported by the implementation. If any requested
-- extension is not supported, vkCreateDevice must return
-- VK_ERROR_EXTENSION_NOT_PRESENT. If any requested feature is
-- not supported, vkCreateDevice must return
-- VK_ERROR_FEATURE_NOT_PRESENT. Support for extensions
-- can be checked before creating a device by querying
-- vkEnumerateDeviceExtensionProperties. Support for features
-- can similarly be checked by querying
-- vkGetPhysicalDeviceFeatures.
--
-- After verifying and enabling the extensions the VkDevice
-- object is created and returned to the application. If a requested
-- extension is only supported by a layer, both the layer and the
-- extension need to be specified at vkCreateInstance time for
-- the creation to succeed.
--
-- Multiple logical devices can be created from the same physical
-- device. Logical device creation may fail due to lack of
-- device-specific resources (in addition to the other errors). If that
-- occurs, vkCreateDevice will return
-- VK_ERROR_TOO_MANY_OBJECTS.
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDeviceCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pDevice must be a valid pointer to a
-- VkDevice handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- 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
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkDeviceCreateInfo, VkPhysicalDevice
vkCreateDevice :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pCreateInfo" ::: Ptr VkDeviceCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pDevice" ::: Ptr VkDevice) -> IO VkResult
-- | vkDestroyDevice - Destroy a logical device
--
-- Parameters
--
--
-- - device is the logical device to destroy.
--
--
--
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- To ensure that no work is active on the device,
-- vkDeviceWaitIdle can be used to gate the destruction of
-- the device. Prior to destroying a device, an application is
-- responsible for destroying/freeing any Vulkan objects that were
-- created using that device as the first parameter of the corresponding
-- vkCreate* or vkAllocate* command.
--
-- Note
--
-- The lifetime of each of these objects is bound by the lifetime of the
-- VkDevice object. Therefore, to avoid resource leaks, it is
-- critical that an application explicitly free all of these resources
-- prior to calling vkDestroyDevice.
--
-- Valid Usage
--
--
-- - All child objects created on device must have been
-- destroyed prior to destroying device
--
--
--
-- - If VkAllocationCallbacks were provided when
-- device was created, a compatible set of callbacks must
-- be provided here
-- - If no VkAllocationCallbacks were provided when
-- device was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - If device is not NULL, device
-- must be a valid VkDevice handle
--
--
--
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
--
--
-- Host Synchronization
--
--
-- - Host access to device must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice
vkDestroyDevice :: ("device" ::: VkDevice) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkDeviceQueueCreateInfo - Structure specifying parameters of a newly
-- created device queue
--
-- Description
--
-- Valid Usage
--
--
-- - queueFamilyIndex must be less than
-- pQueueFamilyPropertyCount returned by
-- vkGetPhysicalDeviceQueueFamilyProperties
--
--
--
-- - queueCount must be less than or equal to the
-- queueCount member of the VkQueueFamilyProperties
-- structure, as returned by
-- vkGetPhysicalDeviceQueueFamilyProperties in the
-- pQueueFamilyProperties[queueFamilyIndex]
-- - Each element of pQueuePriorities must be between
-- 0.0 and 1.0 inclusive
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkDeviceCreateInfo, VkDeviceQueueCreateFlags,
-- VkStructureType
data VkDeviceQueueCreateInfo
VkDeviceQueueCreateInfo :: VkStructureType -> Ptr () -> VkDeviceQueueCreateFlags -> Word32 -> Word32 -> Ptr CFloat -> VkDeviceQueueCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> VkDeviceQueueCreateFlags
-- | queueFamilyIndex is an unsigned integer indicating the index
-- of the queue family to create on this device. This index corresponds
-- to the index of an element of the pQueueFamilyProperties
-- array that was returned by
-- vkGetPhysicalDeviceQueueFamilyProperties.
[$sel:vkQueueFamilyIndex:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> Word32
-- | queueCount is an unsigned integer specifying the number of
-- queues to create in the queue family indicated by
-- queueFamilyIndex.
[$sel:vkQueueCount:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> Word32
-- | pQueuePriorities is an array of queueCount
-- normalized floating point values, specifying priorities of work that
-- will be submitted to each created queue. See Queue Priority for
-- more information.
[$sel:vkPQueuePriorities:VkDeviceQueueCreateInfo] :: VkDeviceQueueCreateInfo -> Ptr CFloat
-- | VkDeviceCreateInfo - Structure specifying parameters of a newly
-- created device
--
-- Description
--
-- Valid Usage
--
--
-- - The queueFamilyIndex member of each element of
-- pQueueCreateInfos must be unique within
-- pQueueCreateInfos
--
--
--
-- - If the pNext chain includes a
-- VkPhysicalDeviceFeatures2 structure, then
-- pEnabledFeatures must be NULL
-- - ppEnabledExtensionNames must not contain both
-- {html_spec_relative}#VK_KHR_maintenance1 and
-- {html_spec_relative}#VK_AMD_negative_viewport_height
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of VkDeviceGroupDeviceCreateInfo,
-- VkPhysicalDevice16BitStorageFeatures,
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT,
-- VkPhysicalDeviceFeatures2,
-- VkPhysicalDeviceMultiviewFeatures,
-- VkPhysicalDeviceProtectedMemoryFeatures,
-- VkPhysicalDeviceSamplerYcbcrConversionFeatures, or
-- VkPhysicalDeviceVariablePointerFeatures
-- - Each sType member in the pNext chain must
-- be unique
-- - flags must be 0
-- - pQueueCreateInfos must be a valid pointer to an
-- array of queueCreateInfoCount valid
-- VkDeviceQueueCreateInfo structures
-- - If enabledLayerCount is not 0,
-- ppEnabledLayerNames must be a valid pointer to an
-- array of enabledLayerCount null-terminated UTF-8 strings
-- - If enabledExtensionCount is not 0,
-- ppEnabledExtensionNames must be a valid pointer to an
-- array of enabledExtensionCount null-terminated UTF-8
-- strings
-- - If pEnabledFeatures is not NULL,
-- pEnabledFeatures must be a valid pointer to a valid
-- VkPhysicalDeviceFeatures structure
-- - queueCreateInfoCount must be greater than
-- 0
--
--
-- See Also
--
-- VkDeviceCreateFlags, VkDeviceQueueCreateInfo,
-- VkPhysicalDeviceFeatures, VkStructureType,
-- vkCreateDevice
data VkDeviceCreateInfo
VkDeviceCreateInfo :: VkStructureType -> Ptr () -> VkDeviceCreateFlags -> Word32 -> Ptr VkDeviceQueueCreateInfo -> Word32 -> Ptr (Ptr CChar) -> Word32 -> Ptr (Ptr CChar) -> Ptr VkPhysicalDeviceFeatures -> VkDeviceCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> VkDeviceCreateFlags
-- | queueCreateInfoCount is the unsigned integer size of the
-- pQueueCreateInfos array. Refer to the Queue Creation
-- section below for further details.
[$sel:vkQueueCreateInfoCount:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Word32
-- | pQueueCreateInfos is a pointer to an array of
-- VkDeviceQueueCreateInfo structures describing the queues that
-- are requested to be created along with the logical device. Refer to
-- the Queue Creation section below for further details.
[$sel:vkPQueueCreateInfos:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Ptr VkDeviceQueueCreateInfo
-- | enabledLayerCount is deprecated and ignored.
[$sel:vkEnabledLayerCount:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Word32
-- | ppEnabledLayerNames is deprecated and ignored. See Device
-- Layer Deprecation.
[$sel:vkPPEnabledLayerNames:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Ptr (Ptr CChar)
-- | enabledExtensionCount is the number of device extensions to
-- enable.
[$sel:vkEnabledExtensionCount:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Word32
-- | ppEnabledExtensionNames is a pointer to an array of
-- enabledExtensionCount null-terminated UTF-8 strings
-- containing the names of extensions to enable for the created device.
-- See the Extensions section for further details.
[$sel:vkPPEnabledExtensionNames:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Ptr (Ptr CChar)
-- | pEnabledFeatures is NULL or a pointer to a
-- VkPhysicalDeviceFeatures structure that contains boolean
-- indicators of all the features to be enabled. Refer to the
-- Features section for further details.
[$sel:vkPEnabledFeatures:VkDeviceCreateInfo] :: VkDeviceCreateInfo -> Ptr VkPhysicalDeviceFeatures
-- | VkDeviceQueueCreateFlags - Bitmask of VkDeviceQueueCreateFlagBits
--
-- Description
--
-- VkDeviceQueueCreateFlags is a bitmask type for setting a mask
-- of zero or more VkDeviceQueueCreateFlagBits.
--
-- See Also
--
-- VkDeviceQueueCreateFlagBits, VkDeviceQueueCreateInfo,
-- VkDeviceQueueInfo2
type VkDeviceQueueCreateFlags = VkDeviceQueueCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Device.VkDeviceCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Device.VkDeviceCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Device.VkDeviceCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Device.VkDeviceQueueCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Device.VkDeviceCreateFlags
module Graphics.Vulkan.Core10.CommandPool
-- | VkCommandPoolCreateFlagBits - Bitmask specifying usage behavior for a
-- command pool
--
-- See Also
--
-- VkCommandPoolCreateFlags
newtype VkCommandPoolCreateFlagBits
VkCommandPoolCreateFlagBits :: VkFlags -> VkCommandPoolCreateFlagBits
-- | VK_COMMAND_POOL_CREATE_TRANSIENT_BIT specifies that command
-- buffers allocated from the pool will be short-lived, meaning that they
-- will be reset or freed in a relatively short timeframe. This flag
-- may be used by the implementation to control memory allocation
-- behavior within the pool.
-- | VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT allows any
-- command buffer allocated from a pool to be individually reset to the
-- initial state; either by calling vkResetCommandBuffer,
-- or via the implicit reset when calling vkBeginCommandBuffer. If
-- this flag is not set on a pool, then vkResetCommandBuffer
-- must not be called for any command buffer allocated from that
-- pool.
-- | VkCommandPoolResetFlagBits - Bitmask controlling behavior of a command
-- pool reset
--
-- See Also
--
-- VkCommandPoolResetFlags
newtype VkCommandPoolResetFlagBits
VkCommandPoolResetFlagBits :: VkFlags -> VkCommandPoolResetFlagBits
-- | VK_COMMAND_POOL_RESET_RELEASE_RESOURCES_BIT specifies that
-- resetting a command pool recycles all of the resources from the
-- command pool back to the system.
-- | VkCommandPool - Opaque handle to a command pool object
--
-- Description
--
-- See Also
--
-- VkCommandBufferAllocateInfo, vkCreateCommandPool,
-- vkDestroyCommandPool, vkFreeCommandBuffers,
-- vkResetCommandPool, vkTrimCommandPool,
-- vkTrimCommandPoolKHR
type VkCommandPool = Ptr VkCommandPool_T
-- | vkCreateCommandPool - Create a new command pool object
--
-- Parameters
--
--
-- - device is the logical device that creates the command
-- pool.
--
--
--
-- - pCreateInfo contains information used to create the
-- command pool.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pCommandPool points to a VkCommandPool handle in
-- which the created pool is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkCommandPoolCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pCommandPool must be a valid pointer to a
-- VkCommandPool handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkCommandPool,
-- VkCommandPoolCreateInfo, VkDevice
vkCreateCommandPool :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkCommandPoolCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pCommandPool" ::: Ptr VkCommandPool) -> IO VkResult
-- | vkDestroyCommandPool - Destroy a command pool object
--
-- Parameters
--
--
-- - device is the logical device that destroys the command
-- pool.
--
--
--
-- - commandPool is the handle of the command pool to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- When a pool is destroyed, all command buffers allocated from the pool
-- are freed.
--
-- Any primary command buffer allocated from another VkCommandPool
-- that is in the recording or executable state and has a
-- secondary command buffer allocated from commandPool recorded
-- into it, becomes invalid.
--
-- Valid Usage
--
--
-- - All VkCommandBuffer objects allocated from
-- commandPool must not be in the pending
-- state.
--
--
--
-- - If VkAllocationCallbacks were provided when
-- commandPool was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- commandPool was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If commandPool is not VK_NULL_HANDLE,
-- commandPool must be a valid VkCommandPool
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If commandPool is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to commandPool must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkCommandPool, VkDevice
vkDestroyCommandPool :: ("device" ::: VkDevice) -> ("commandPool" ::: VkCommandPool) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkResetCommandPool - Reset a command pool
--
-- Parameters
--
--
-- - device is the logical device that owns the command
-- pool.
--
--
--
-- - commandPool is the command pool to reset.
-- - flags is a bitmask of VkCommandPoolResetFlagBits
-- controlling the reset operation.
--
--
-- Description
--
-- Resetting a command pool recycles all of the resources from all of the
-- command buffers allocated from the command pool back to the command
-- pool. All command buffers that have been allocated from the command
-- pool are put in the initial state.
--
-- Any primary command buffer allocated from another VkCommandPool
-- that is in the recording or executable state and has a
-- secondary command buffer allocated from commandPool recorded
-- into it, becomes invalid.
--
-- Valid Usage
--
--
-- - All VkCommandBuffer objects allocated from
-- commandPool must not be in the pending
-- state
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - commandPool must be a valid VkCommandPool
-- handle
-- - flags must be a valid combination of
-- VkCommandPoolResetFlagBits values
-- - commandPool must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to commandPool must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkCommandPool, VkCommandPoolResetFlags, VkDevice
vkResetCommandPool :: ("device" ::: VkDevice) -> ("commandPool" ::: VkCommandPool) -> ("flags" ::: VkCommandPoolResetFlags) -> IO VkResult
-- | VkCommandPoolCreateInfo - Structure specifying parameters of a newly
-- created command pool
--
-- Description
--
-- Valid Usage
--
--
-- - queueFamilyIndex must be the index of a queue
-- family available in the calling command’s device
-- parameter
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkCommandPoolCreateFlags, VkStructureType,
-- vkCreateCommandPool
data VkCommandPoolCreateInfo
VkCommandPoolCreateInfo :: VkStructureType -> Ptr () -> VkCommandPoolCreateFlags -> Word32 -> VkCommandPoolCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkCommandPoolCreateInfo] :: VkCommandPoolCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCommandPoolCreateInfo] :: VkCommandPoolCreateInfo -> Ptr ()
-- | flags is a bitmask of VkCommandPoolCreateFlagBits
-- indicating usage behavior for the pool and command buffers allocated
-- from it.
[$sel:vkFlags:VkCommandPoolCreateInfo] :: VkCommandPoolCreateInfo -> VkCommandPoolCreateFlags
-- | queueFamilyIndex designates a queue family as described in
-- section Queue Family Properties. All command buffers allocated
-- from this command pool must be submitted on queues from the
-- same queue family.
[$sel:vkQueueFamilyIndex:VkCommandPoolCreateInfo] :: VkCommandPoolCreateInfo -> Word32
-- | VkCommandPoolCreateFlags - Bitmask of VkCommandPoolCreateFlagBits
--
-- Description
--
-- VkCommandPoolCreateFlags is a bitmask type for setting a mask
-- of zero or more VkCommandPoolCreateFlagBits.
--
-- See Also
--
-- VkCommandPoolCreateFlagBits, VkCommandPoolCreateInfo
type VkCommandPoolCreateFlags = VkCommandPoolCreateFlagBits
-- | VkCommandPoolResetFlags - Bitmask of VkCommandPoolResetFlagBits
--
-- Description
--
-- VkCommandPoolResetFlags is a bitmask type for setting a mask
-- of zero or more VkCommandPoolResetFlagBits.
--
-- See Also
--
-- VkCommandPoolResetFlagBits, vkResetCommandPool
type VkCommandPoolResetFlags = VkCommandPoolResetFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandPool.VkCommandPoolResetFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandPool.VkCommandPoolCreateFlagBits
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1
-- | VkCommandPoolTrimFlags - Reserved for future use
--
-- Description
--
-- VkCommandPoolTrimFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- vkTrimCommandPool, vkTrimCommandPoolKHR
newtype VkCommandPoolTrimFlags
VkCommandPoolTrimFlags :: VkFlags -> VkCommandPoolTrimFlags
-- | vkTrimCommandPool - Trim a command pool
--
-- Parameters
--
--
-- - device is the logical device that owns the command
-- pool.
--
--
--
-- - commandPool is the command pool to trim.
-- - flags is reserved for future use.
--
--
-- Description
--
-- Trimming a command pool recycles unused memory from the command pool
-- back to the system. Command buffers allocated from the pool are not
-- affected by the command.
--
-- Note
--
-- This command provides applications with some control over the internal
-- memory allocations used by command pools.
--
-- Unused memory normally arises from command buffers that have been
-- recorded and later reset, such that they are no longer using the
-- memory. On reset, a command buffer can return memory to its command
-- pool, but the only way to release memory from a command pool to the
-- system requires calling vkResetCommandPool, which cannot be
-- executed while any command buffers from that pool are still in use.
-- Subsequent recording operations into command buffers will re-use this
-- memory but since total memory requirements fluctuate over time, unused
-- memory can accumulate.
--
-- In this situation, trimming a command pool may be useful to
-- return unused memory back to the system, returning the total
-- outstanding memory allocated by the pool back to a more “average”
-- value.
--
-- Implementations utilize many internal allocation strategies that make
-- it impossible to guarantee that all unused memory is released back to
-- the system. For instance, an implementation of a command pool
-- may involve allocating memory in bulk from the system and
-- sub-allocating from that memory. In such an implementation any live
-- command buffer that holds a reference to a bulk allocation would
-- prevent that allocation from being freed, even if only a small
-- proportion of the bulk allocation is in use.
--
-- In most cases trimming will result in a reduction in allocated but
-- unused memory, but it does not guarantee the “ideal” behaviour.
--
-- Trimming may be an expensive operation, and should not
-- be called frequently. Trimming should be treated as a way to
-- relieve memory pressure after application-known points when there
-- exists enough unused memory that the cost of trimming is “worth” it.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - commandPool must be a valid VkCommandPool
-- handle
-- - flags must be 0
-- - commandPool must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to commandPool must be externally
-- synchronized
--
--
-- See Also
--
-- VkCommandPool, VkCommandPoolTrimFlags, VkDevice
vkTrimCommandPool :: ("device" ::: VkDevice) -> ("commandPool" ::: VkCommandPool) -> ("flags" ::: VkCommandPoolTrimFlags) -> IO ()
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance1.VkCommandPoolTrimFlags
module Graphics.Vulkan.Extensions.VK_KHR_maintenance1
vkTrimCommandPoolKHR :: ("device" ::: VkDevice) -> ("commandPool" ::: VkCommandPool) -> ("flags" ::: VkCommandPoolTrimFlags) -> IO ()
type VkCommandPoolTrimFlagsKHR = VkCommandPoolTrimFlags
module Graphics.Vulkan.Core10.BufferView
-- | VkBufferViewCreateFlags - Reserved for future use
--
-- Description
--
-- VkBufferViewCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkBufferViewCreateInfo
newtype VkBufferViewCreateFlags
VkBufferViewCreateFlags :: VkFlags -> VkBufferViewCreateFlags
-- | VkBufferView - Opaque handle to a buffer view object
--
-- Description
--
-- See Also
--
-- VkWriteDescriptorSet, vkCreateBufferView,
-- vkDestroyBufferView
type VkBufferView = Ptr VkBufferView_T
-- | vkCreateBufferView - Create a new buffer view object
--
-- Parameters
--
--
-- - device is the logical device that creates the buffer
-- view.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkBufferViewCreateInfo structure containing parameters to be
-- used to create the buffer.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pView points to a VkBufferView handle in which
-- the resulting buffer view object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkBufferViewCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pView must be a valid pointer to a
-- VkBufferView handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkBufferView,
-- VkBufferViewCreateInfo, VkDevice
vkCreateBufferView :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkBufferViewCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pView" ::: Ptr VkBufferView) -> IO VkResult
-- | vkDestroyBufferView - Destroy a buffer view object
--
-- Parameters
--
--
-- - device is the logical device that destroys the buffer
-- view.
--
--
--
-- - bufferView is the buffer view to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to bufferView
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- bufferView was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- bufferView was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If bufferView is not VK_NULL_HANDLE,
-- bufferView must be a valid VkBufferView
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If bufferView is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to bufferView must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkBufferView, VkDevice
vkDestroyBufferView :: ("device" ::: VkDevice) -> ("bufferView" ::: VkBufferView) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkBufferViewCreateInfo - Structure specifying parameters of a newly
-- created buffer view
--
-- Description
--
-- Valid Usage
--
--
-- - offset must be less than the size of
-- buffer
--
--
--
-- - offset must be a multiple of
-- VkPhysicalDeviceLimits::minTexelBufferOffsetAlignment
-- - If range is not equal to VK_WHOLE_SIZE,
-- range must be greater than 0
-- - If range is not equal to VK_WHOLE_SIZE,
-- range must be a multiple of the element size of
-- format
-- - If range is not equal to VK_WHOLE_SIZE,
-- range divided by the element size of format
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxTexelBufferElements
-- - If range is not equal to VK_WHOLE_SIZE, the sum
-- of offset and range must be less than or
-- equal to the size of buffer
-- - buffer must have been created with a
-- usage value containing at least one of
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT or
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT
-- - If buffer was created with usage containing
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT, format
-- must be supported for uniform texel buffers, as specified by
-- the VK_FORMAT_FEATURE_UNIFORM_TEXEL_BUFFER_BIT flag in
-- VkFormatProperties::bufferFeatures returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If buffer was created with usage containing
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT, format
-- must be supported for storage texel buffers, as specified by
-- the VK_FORMAT_FEATURE_STORAGE_TEXEL_BUFFER_BIT flag in
-- VkFormatProperties::bufferFeatures returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - buffer must be a valid VkBuffer
-- handle
-- - format must be a valid VkFormat value
--
--
-- See Also
--
-- VkBuffer, VkBufferViewCreateFlags,
-- VkDeviceSize, VkFormat, VkStructureType,
-- vkCreateBufferView
data VkBufferViewCreateInfo
VkBufferViewCreateInfo :: VkStructureType -> Ptr () -> VkBufferViewCreateFlags -> VkBuffer -> VkFormat -> VkDeviceSize -> VkDeviceSize -> VkBufferViewCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkBufferViewCreateFlags
-- | buffer is a VkBuffer on which the view will be
-- created.
[$sel:vkBuffer:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkBuffer
-- | format is a VkFormat describing the format of the data
-- elements in the buffer.
[$sel:vkFormat:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkFormat
-- | offset is an offset in bytes from the base address of the
-- buffer. Accesses to the buffer view from shaders use addressing that
-- is relative to this starting offset.
[$sel:vkOffset:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkDeviceSize
-- | range is a size in bytes of the buffer view. If
-- range is equal to VK_WHOLE_SIZE, the range from
-- offset to the end of the buffer is used. If
-- VK_WHOLE_SIZE is used and the remaining size of the buffer is
-- not a multiple of the element size of format, then the
-- nearest smaller multiple is used.
[$sel:vkRange:VkBufferViewCreateInfo] :: VkBufferViewCreateInfo -> VkDeviceSize
instance GHC.Show.Show Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.BufferView.VkBufferViewCreateFlags
module Graphics.Vulkan.Core10.Buffer
-- | VkSharingMode - Buffer and image sharing modes
--
-- Description
--
--
-- - VK_SHARING_MODE_EXCLUSIVE specifies that access to any
-- range or image subresource of the object will be exclusive to a single
-- queue family at a time.
--
--
--
-- - VK_SHARING_MODE_CONCURRENT specifies that concurrent
-- access to any range or image subresource of the object from multiple
-- queue families is supported.
--
--
-- Note
--
-- VK_SHARING_MODE_CONCURRENT may result in lower
-- performance access to the buffer or image than
-- VK_SHARING_MODE_EXCLUSIVE.
--
-- Ranges of buffers and image subresources of image objects created
-- using VK_SHARING_MODE_EXCLUSIVE must only be accessed
-- by queues in the queue family that has ownership of the
-- resource. Upon creation, such resources are not owned by any queue
-- family; ownership is implicitly acquired upon first use within a
-- queue. Once a resource using VK_SHARING_MODE_EXCLUSIVE is
-- owned by some queue family, the application must perform a
-- queue family ownership transfer to make the memory contents of
-- a range or image subresource accessible to a different queue family.
--
-- Note
--
-- Images still require a layout transition from
-- VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED before being used on the first
-- queue.
--
-- A queue family can take ownership of an image subresource or
-- buffer range of a resource created with
-- VK_SHARING_MODE_EXCLUSIVE, without an ownership transfer, in
-- the same way as for a resource that was just created; however, taking
-- ownership in this way has the effect that the contents of the image
-- subresource or buffer range are undefined.
--
-- Ranges of buffers and image subresources of image objects created
-- using VK_SHARING_MODE_CONCURRENT must only be accessed
-- by queues from the queue families specified through the
-- queueFamilyIndexCount and pQueueFamilyIndices
-- members of the corresponding create info structures.
--
-- See Also
--
-- VkBufferCreateInfo, VkImageCreateInfo,
-- VkSwapchainCreateInfoKHR
newtype VkSharingMode
VkSharingMode :: Int32 -> VkSharingMode
-- | VkBufferUsageFlagBits - Bitmask specifying allowed usage of a buffer
--
-- See Also
--
-- VkBufferUsageFlags
newtype VkBufferUsageFlagBits
VkBufferUsageFlagBits :: VkFlags -> VkBufferUsageFlagBits
-- | VK_BUFFER_USAGE_TRANSFER_SRC_BIT specifies that the buffer
-- can be used as the source of a transfer command (see the
-- definition of VK_PIPELINE_STAGE_TRANSFER_BIT).
-- | VK_BUFFER_USAGE_TRANSFER_DST_BIT specifies that the buffer
-- can be used as the destination of a transfer command.
-- | VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT specifies that the
-- buffer can be used to create a VkBufferView suitable
-- for occupying a VkDescriptorSet slot of type
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER.
-- | VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT specifies that the
-- buffer can be used to create a VkBufferView suitable
-- for occupying a VkDescriptorSet slot of type
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER.
-- | VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT specifies that the buffer
-- can be used in a VkDescriptorBufferInfo suitable for
-- occupying a VkDescriptorSet slot either of type
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC.
-- | VK_BUFFER_USAGE_STORAGE_BUFFER_BIT specifies that the buffer
-- can be used in a VkDescriptorBufferInfo suitable for
-- occupying a VkDescriptorSet slot either of type
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC.
-- | VK_BUFFER_USAGE_INDEX_BUFFER_BIT specifies that the buffer is
-- suitable for passing as the buffer parameter to
-- vkCmdBindIndexBuffer.
-- | VK_BUFFER_USAGE_VERTEX_BUFFER_BIT specifies that the buffer
-- is suitable for passing as an element of the pBuffers array
-- to vkCmdBindVertexBuffers.
-- | VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT specifies that the buffer
-- is suitable for passing as the buffer parameter to
-- vkCmdDrawIndirect, vkCmdDrawIndexedIndirect, or
-- vkCmdDispatchIndirect. It is also suitable for passing as the
-- buffer member of VkIndirectCommandsTokenNVX, or
-- sequencesCountBuffer or sequencesIndexBuffer member
-- of VkCmdProcessCommandsInfoNVX
-- | VkBufferCreateFlagBits - Bitmask specifying additional parameters of a
-- buffer
--
-- Description
--
--
-- - VK_BUFFER_CREATE_SPARSE_BINDING_BIT specifies that the
-- buffer will be backed using sparse memory binding.
--
--
--
-- - VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT specifies that the
-- buffer can be partially backed using sparse memory binding.
-- Buffers created with this flag must also be created with the
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT flag.
-- - VK_BUFFER_CREATE_SPARSE_ALIASED_BIT specifies that the
-- buffer will be backed using sparse memory binding with memory ranges
-- that might also simultaneously be backing another buffer (or another
-- portion of the same buffer). Buffers created with this flag
-- must also be created with the
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT flag.
--
--
-- See Sparse Resource Features and Physical Device
-- Features for details of the sparse memory features supported on a
-- device.
--
-- See Also
--
-- VkBufferCreateFlags
newtype VkBufferCreateFlagBits
VkBufferCreateFlagBits :: VkFlags -> VkBufferCreateFlagBits
-- | vkCreateBuffer - Create a new buffer object
--
-- Parameters
--
--
-- - device is the logical device that creates the buffer
-- object.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkBufferCreateInfo structure containing parameters affecting
-- creation of the buffer.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pBuffer points to a VkBuffer handle in which the
-- resulting buffer object is returned.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If the flags member of pCreateInfo includes
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT, creating this
-- VkBuffer must not cause the total required sparse
-- memory for all currently valid sparse resources on the device to
-- exceed
-- VkPhysicalDeviceLimits::sparseAddressSpaceSize
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkBufferCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pBuffer must be a valid pointer to a
-- VkBuffer handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkBuffer,
-- VkBufferCreateInfo, VkDevice
vkCreateBuffer :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkBufferCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pBuffer" ::: Ptr VkBuffer) -> IO VkResult
-- | vkDestroyBuffer - Destroy a buffer object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- buffer.
--
--
--
-- - buffer is the buffer to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to buffer, either
-- directly or via a VkBufferView, must have completed
-- execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- buffer was created, a compatible set of callbacks must
-- be provided here
-- - If no VkAllocationCallbacks were provided when
-- buffer was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If buffer is not VK_NULL_HANDLE, buffer
-- must be a valid VkBuffer handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If buffer is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to buffer must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkBuffer, VkDevice
vkDestroyBuffer :: ("device" ::: VkDevice) -> ("buffer" ::: VkBuffer) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | VkBufferCreateInfo - Structure specifying the parameters of a newly
-- created buffer object
--
-- Description
--
-- Valid Usage
--
--
-- - size must be greater than 0
--
--
--
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- pQueueFamilyIndices must be a valid pointer to an
-- array of queueFamilyIndexCount uint32_t values
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- queueFamilyIndexCount must be greater than
-- 1
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- each element of pQueueFamilyIndices must be unique and
-- must be less than pQueueFamilyPropertyCount returned
-- by either vkGetPhysicalDeviceQueueFamilyProperties or
-- vkGetPhysicalDeviceQueueFamilyProperties2 for the
-- physicalDevice that was used to create device
-- - If the sparse bindings feature is not enabled,
-- flags must not contain
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT
-- - If the sparse buffer residency feature is not enabled,
-- flags must not contain
-- VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse aliased residency feature is not enabled,
-- flags must not contain
-- VK_BUFFER_CREATE_SPARSE_ALIASED_BIT
-- - If flags contains
-- VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT or
-- VK_BUFFER_CREATE_SPARSE_ALIASED_BIT, it must also
-- contain VK_BUFFER_CREATE_SPARSE_BINDING_BIT
-- - If the pNext chain contains an instance of
-- VkExternalMemoryBufferCreateInfo, its handleTypes
-- member must only contain bits that are also in
-- VkExternalBufferProperties::externalMemoryProperties.pname:compatibleHandleTypes,
-- as returned by vkGetPhysicalDeviceExternalBufferProperties with
-- pExternalBufferInfo->handleType equal to any one
-- of the handle types specified in
-- VkExternalMemoryBufferCreateInfo::handleTypes
-- - If the pNext chain contains an instance of
-- VkDedicatedAllocationBufferCreateInfoNV, and the
-- dedicatedAllocation member of the chained structure is
-- VK_TRUE, then flags must not include
-- VK_BUFFER_CREATE_SPARSE_BINDING_BIT,
-- VK_BUFFER_CREATE_SPARSE_RESIDENCY_BIT, or
-- VK_BUFFER_CREATE_SPARSE_ALIASED_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkBufferCreateFlags, VkBufferUsageFlags,
-- VkDeviceSize, VkSharingMode, VkStructureType,
-- vkCreateBuffer
data VkBufferCreateInfo
VkBufferCreateInfo :: VkStructureType -> Ptr () -> VkBufferCreateFlags -> VkDeviceSize -> VkBufferUsageFlags -> VkSharingMode -> Word32 -> Ptr Word32 -> VkBufferCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkBufferCreateInfo] :: VkBufferCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBufferCreateInfo] :: VkBufferCreateInfo -> Ptr ()
-- | flags is a bitmask of VkBufferCreateFlagBits
-- specifying additional parameters of the buffer.
[$sel:vkFlags:VkBufferCreateInfo] :: VkBufferCreateInfo -> VkBufferCreateFlags
-- | size is the size in bytes of the buffer to be created.
[$sel:vkSize:VkBufferCreateInfo] :: VkBufferCreateInfo -> VkDeviceSize
-- | usage is a bitmask of VkBufferUsageFlagBits specifying
-- allowed usages of the buffer.
[$sel:vkUsage:VkBufferCreateInfo] :: VkBufferCreateInfo -> VkBufferUsageFlags
-- | sharingMode is a VkSharingMode value specifying the
-- sharing mode of the buffer when it will be accessed by multiple queue
-- families.
[$sel:vkSharingMode:VkBufferCreateInfo] :: VkBufferCreateInfo -> VkSharingMode
-- | queueFamilyIndexCount is the number of entries in the
-- pQueueFamilyIndices array.
[$sel:vkQueueFamilyIndexCount:VkBufferCreateInfo] :: VkBufferCreateInfo -> Word32
-- | pQueueFamilyIndices is a list of queue families that will
-- access this buffer (ignored if sharingMode is not
-- VK_SHARING_MODE_CONCURRENT).
[$sel:vkPQueueFamilyIndices:VkBufferCreateInfo] :: VkBufferCreateInfo -> Ptr Word32
-- | VkBufferUsageFlags - Bitmask of VkBufferUsageFlagBits
--
-- Description
--
-- VkBufferUsageFlags is a bitmask type for setting a mask of
-- zero or more VkBufferUsageFlagBits.
--
-- See Also
--
-- VkBufferCreateInfo, VkBufferUsageFlagBits,
-- VkPhysicalDeviceExternalBufferInfo
type VkBufferUsageFlags = VkBufferUsageFlagBits
-- | VkBufferCreateFlags - Bitmask of VkBufferCreateFlagBits
--
-- Description
--
-- VkBufferCreateFlags is a bitmask type for setting a mask of
-- zero or more VkBufferCreateFlagBits.
--
-- See Also
--
-- VkBufferCreateFlagBits, VkBufferCreateInfo,
-- VkPhysicalDeviceExternalBufferInfo
type VkBufferCreateFlags = VkBufferCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Buffer.VkBufferCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Buffer.VkBufferCreateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Buffer.VkSharingMode
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Buffer.VkSharingMode
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Buffer.VkSharingMode
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Buffer.VkBufferCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Buffer.VkBufferCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Buffer.VkBufferUsageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Buffer.VkSharingMode
instance GHC.Read.Read Graphics.Vulkan.Core10.Buffer.VkSharingMode
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities
-- | VkExternalMemoryHandleTypeFlagBits - Bit specifying external memory
-- handle types
--
-- Description
--
--
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT specifies a
-- POSIX file descriptor handle that has only limited valid usage outside
-- of Vulkan and other compatible APIs. It must be compatible with
-- the POSIX system calls dup, dup2, close,
-- and the non-standard system call dup3. Additionally, it
-- must be transportable over a socket using an
-- SCM_RIGHTS control message. It owns a reference to the
-- underlying memory resource represented by its Vulkan memory
-- object.
--
--
--
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_BIT specifies
-- an NT handle that has only limited valid usage outside of Vulkan and
-- other compatible APIs. It must be compatible with the functions
-- DuplicateHandle, CloseHandle,
-- CompareObjectHandles, GetHandleInformation, and
-- SetHandleInformation. It owns a reference to the underlying
-- memory resource represented by its Vulkan memory object.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_WIN32_KMT_BIT
-- specifies a global share handle that has only limited valid usage
-- outside of Vulkan and other compatible APIs. It is not compatible with
-- any native APIs. It does not own a reference to the underlying memory
-- resource represented its Vulkan memory object, and will therefore
-- become invalid when all Vulkan memory objects associated with it are
-- destroyed.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT
-- specifies an NT handle returned by
-- IDXGIResource1::CreateSharedHandle referring to a
-- Direct3D 10 or 11 texture resource. It owns a reference to the memory
-- used by the Direct3D resource.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT
-- specifies a global share handle returned by
-- IDXGIResource::GetSharedHandle referring to a
-- Direct3D 10 or 11 texture resource. It does not own a reference to the
-- underlying Direct3D resource, and will therefore become invalid when
-- all Vulkan memory objects and Direct3D resources associated with it
-- are destroyed.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_HEAP_BIT specifies
-- an NT handle returned by
-- ID3D12Device::CreateSharedHandle referring to a
-- Direct3D 12 heap resource. It owns a reference to the resources used
-- by the Direct3D heap.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT
-- specifies an NT handle returned by
-- ID3D12Device::CreateSharedHandle referring to a
-- Direct3D 12 committed resource. It owns a reference to the memory used
-- by the Direct3D resource.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT
-- specifies a host pointer returned by a host memory allocation command.
-- It does not own a reference to the underlying memory resource, and
-- will therefore become invalid if the host memory is freed.
--
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
-- specifies a host pointer to host mapped foreign memory. It does
-- not own a reference to the underlying memory resource, and will
-- therefore become invalid if the foreign memory is unmapped or
-- otherwise becomes no longer available.
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT is a file
-- descriptor for a Linux dma_buf. It owns a reference to the underlying
-- memory resource represented by its Vulkan memory object.
--
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID
-- specifies an AHardwareBuffer object defined by the Android
-- NDK. See Android Hardware Buffers for more details of this
-- handle type.
--
--
-- Some external memory handle types can only be shared within the same
-- underlying physical device and/or the same driver version, as defined
-- in the following table:
--
--
-- +----------------------+----------------------+-----------------------+
-- | Handle type | @VkPhysicalDeviceIDP | @VkPhysicalDeviceIDPr |
-- | | roperties@::@driverU | operties@::@deviceUUI |
-- | | UID@ | D@ |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_OPAQUE_F | | |
-- | D_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_OPAQUE_W | | |
-- | IN32_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_OPAQUE_W | | |
-- | IN32_KMT_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_D3D11_TE | | |
-- | XTURE_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_D3D11_TE | | |
-- | XTURE_KMT_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_D3D12_HE | | |
-- | AP_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | Must match | Must match |
-- | HANDLE_TYPE_D3D12_RE | | |
-- | SOURCE_BIT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | No restriction | No restriction |
-- | HANDLE_TYPE_HOST_ALL | | |
-- | OCATION_BIT_EXT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | No restriction | No restriction |
-- | HANDLE_TYPE_HOST_MAP | | |
-- | PED_FOREIGN_MEMORY_B | | |
-- | IT_EXT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | No restriction | No restriction |
-- | HANDLE_TYPE_DMA_BUF_ | | |
-- | BIT_EXT@ | | |
-- +----------------------+----------------------+-----------------------+
-- | @VK_EXTERNAL_MEMORY_ | No restriction | No restriction |
-- | HANDLE_TYPE_ANDROID_ | | |
-- | HARDWARE_BUFFER_BIT_ | | |
-- | ANDROID@ | | |
-- +----------------------+----------------------+-----------------------+
--
-- External memory handle types compatibility
--
--
-- Note
--
-- The above table does not restrict the drivers and devices with which
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT and
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
-- may be shared, as these handle types inherently mean memory
-- that does not come from the same device, as they import memory from
-- the host or a foreign device, respectively.
--
-- Note
--
-- Even though the above table does not restrict the drivers and devices
-- with which VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT
-- may be shared, query mechanisms exist in the Vulkan API that
-- prevent the import of incompatible dma-bufs (such as
-- vkGetMemoryFdPropertiesKHR) and that prevent incompatible usage
-- of dma-bufs (such as VkPhysicalDeviceExternalBufferInfoKHR and
-- VkPhysicalDeviceExternalImageFormatInfoKHR).
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlags,
-- VkImportMemoryFdInfoKHR,
-- VkImportMemoryHostPointerInfoEXT,
-- VkImportMemoryWin32HandleInfoKHR, VkMemoryGetFdInfoKHR,
-- VkMemoryGetWin32HandleInfoKHR,
-- VkPhysicalDeviceExternalBufferInfo,
-- VkPhysicalDeviceExternalImageFormatInfo,
-- vkGetMemoryFdPropertiesKHR,
-- vkGetMemoryHostPointerPropertiesEXT,
-- vkGetMemoryWin32HandlePropertiesKHR
newtype VkExternalMemoryHandleTypeFlagBits
VkExternalMemoryHandleTypeFlagBits :: VkFlags -> VkExternalMemoryHandleTypeFlagBits
-- | VkExternalMemoryFeatureFlagBits - Bitmask specifying features of an
-- external memory handle type
--
-- Description
--
--
-- - VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT specifies
-- that images or buffers created with the specified parameters and
-- handle type must use the mechanisms defined in the
-- {html_spec_relative}#VK_NV_dedicated_allocation extension to
-- create (or import) a dedicated allocation for the image or
-- buffer.
--
--
--
-- - VK_EXTERNAL_MEMORY_FEATURE_EXPORTABLE_BIT specifies that
-- handles of this type can be exported from Vulkan memory
-- objects.
-- - VK_INTERNAL_MEMORY_FEATURE_IMPORTABLE_BIT specifies that
-- handles of this type can be imported as Vulkan memory
-- objects.
--
--
-- Because their semantics in external APIs roughly align with that of an
-- image or buffer with a dedicated allocation in Vulkan, implementations
-- are required to report
-- VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT for the
-- following external handle types:
--
--
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_BIT
--
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D11_TEXTURE_KMT_BIT
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_D3D12_RESOURCE_BIT
--
-- - VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID
-- for images only
--
--
-- Implementations must not report
-- VK_EXTERNAL_MEMORY_FEATURE_DEDICATED_ONLY_BIT for buffers
-- with external handle type
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID.
--
-- See Also
--
-- VkExternalMemoryFeatureFlags
newtype VkExternalMemoryFeatureFlagBits
VkExternalMemoryFeatureFlagBits :: VkFlags -> VkExternalMemoryFeatureFlagBits
type VK_LUID_SIZE = 8
-- | vkGetPhysicalDeviceExternalBufferProperties - Query external handle
-- types supported by buffers
--
-- Parameters
--
--
-- - physicalDevice is the physical device from which to query
-- the buffer capabilities.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pExternalBufferInfo must be a valid pointer to a
-- valid VkPhysicalDeviceExternalBufferInfo structure
-- - pExternalBufferProperties must be a valid pointer
-- to a VkExternalBufferProperties structure
--
--
-- See Also
--
-- VkExternalBufferProperties, VkPhysicalDevice,
-- VkPhysicalDeviceExternalBufferInfo
vkGetPhysicalDeviceExternalBufferProperties :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalBufferInfo" ::: Ptr VkPhysicalDeviceExternalBufferInfo) -> ("pExternalBufferProperties" ::: Ptr VkExternalBufferProperties) -> IO ()
-- | VkExternalMemoryProperties - Structure specifying external memory
-- handle type capabilities
--
-- Description
--
-- compatibleHandleTypes must include at least
-- handleType. Inclusion of a handle type in
-- compatibleHandleTypes does not imply the values returned in
-- VkImageFormatProperties2 will be the same when
-- VkPhysicalDeviceExternalImageFormatInfo::handleType is
-- set to that type. The application is responsible for querying the
-- capabilities of all handle types intended for concurrent use in a
-- single image and intersecting them to obtain the compatible set of
-- capabilities.
--
-- See Also
--
-- VkExternalBufferProperties,
-- VkExternalImageFormatProperties,
-- VkExternalMemoryFeatureFlags,
-- VkExternalMemoryHandleTypeFlags
data VkExternalMemoryProperties
VkExternalMemoryProperties :: VkExternalMemoryFeatureFlags -> VkExternalMemoryHandleTypeFlags -> VkExternalMemoryHandleTypeFlags -> VkExternalMemoryProperties
-- | externalMemoryFeatures is a bitmask of
-- VkExternalMemoryFeatureFlagBits specifying the features of
-- handleType.
[$sel:vkExternalMemoryFeatures:VkExternalMemoryProperties] :: VkExternalMemoryProperties -> VkExternalMemoryFeatureFlags
-- | exportFromImportedHandleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBits specifying which types of
-- imported handle handleType can be exported from.
[$sel:vkExportFromImportedHandleTypes:VkExternalMemoryProperties] :: VkExternalMemoryProperties -> VkExternalMemoryHandleTypeFlags
-- | compatibleHandleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBits specifying handle types
-- which can be specified at the same time as handleType
-- when creating an image compatible with external memory.
[$sel:vkCompatibleHandleTypes:VkExternalMemoryProperties] :: VkExternalMemoryProperties -> VkExternalMemoryHandleTypeFlags
-- | VkPhysicalDeviceExternalImageFormatInfo - Structure specifying
-- external image creation parameters
--
-- Description
--
-- If handleType is 0,
-- vkGetPhysicalDeviceImageFormatProperties2 will behave as if
-- VkPhysicalDeviceExternalImageFormatInfo was not present, and
-- VkExternalImageFormatProperties will be ignored.
--
-- If handleType is not compatible with the format,
-- type, tiling, usage, and flags
-- specified in VkPhysicalDeviceImageFormatInfo2, then
-- vkGetPhysicalDeviceImageFormatProperties2 returns
-- VK_ERROR_FORMAT_NOT_SUPPORTED.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_IMAGE_FORMAT_INFO
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagBits, VkStructureType
data VkPhysicalDeviceExternalImageFormatInfo
VkPhysicalDeviceExternalImageFormatInfo :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlagBits -> VkPhysicalDeviceExternalImageFormatInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceExternalImageFormatInfo] :: VkPhysicalDeviceExternalImageFormatInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceExternalImageFormatInfo] :: VkPhysicalDeviceExternalImageFormatInfo -> Ptr ()
-- | handleType is a VkExternalMemoryHandleTypeFlagBits
-- value specifying the memory handle type that will be used with the
-- memory associated with the image.
[$sel:vkHandleType:VkPhysicalDeviceExternalImageFormatInfo] :: VkPhysicalDeviceExternalImageFormatInfo -> VkExternalMemoryHandleTypeFlagBits
-- | VkExternalImageFormatProperties - Structure specifying supported
-- external handle properties
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_IMAGE_FORMAT_PROPERTIES
--
--
-- See Also
--
-- VkExternalMemoryProperties, VkStructureType
data VkExternalImageFormatProperties
VkExternalImageFormatProperties :: VkStructureType -> Ptr () -> VkExternalMemoryProperties -> VkExternalImageFormatProperties
-- | sType is the type of this structure.
[$sel:vkSType:VkExternalImageFormatProperties] :: VkExternalImageFormatProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExternalImageFormatProperties] :: VkExternalImageFormatProperties -> Ptr ()
-- | externalMemoryProperties is an instance of the
-- VkExternalMemoryProperties structure specifying various
-- capabilities of the external handle type when used with the specified
-- image creation parameters.
[$sel:vkExternalMemoryProperties:VkExternalImageFormatProperties] :: VkExternalImageFormatProperties -> VkExternalMemoryProperties
-- | VkPhysicalDeviceExternalBufferInfo - Structure specifying buffer
-- creation parameters
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_BUFFER_INFO
--
--
--
--
-- See Also
--
-- VkBufferCreateFlags, VkBufferUsageFlags,
-- VkExternalMemoryHandleTypeFlagBits, VkStructureType,
-- vkGetPhysicalDeviceExternalBufferProperties,
-- vkGetPhysicalDeviceExternalBufferPropertiesKHR
data VkPhysicalDeviceExternalBufferInfo
VkPhysicalDeviceExternalBufferInfo :: VkStructureType -> Ptr () -> VkBufferCreateFlags -> VkBufferUsageFlags -> VkExternalMemoryHandleTypeFlagBits -> VkPhysicalDeviceExternalBufferInfo
-- | sType is the type of this structure
[$sel:vkSType:VkPhysicalDeviceExternalBufferInfo] :: VkPhysicalDeviceExternalBufferInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceExternalBufferInfo] :: VkPhysicalDeviceExternalBufferInfo -> Ptr ()
-- | flags is a bitmask of VkBufferCreateFlagBits
-- describing additional parameters of the buffer, corresponding to
-- VkBufferCreateInfo::flags.
[$sel:vkFlags:VkPhysicalDeviceExternalBufferInfo] :: VkPhysicalDeviceExternalBufferInfo -> VkBufferCreateFlags
-- | usage is a bitmask of VkBufferUsageFlagBits describing
-- the intended usage of the buffer, corresponding to
-- VkBufferCreateInfo::usage.
[$sel:vkUsage:VkPhysicalDeviceExternalBufferInfo] :: VkPhysicalDeviceExternalBufferInfo -> VkBufferUsageFlags
-- | handleType is a VkExternalMemoryHandleTypeFlagBits
-- value specifying the memory handle type that will be used with the
-- memory associated with the buffer.
[$sel:vkHandleType:VkPhysicalDeviceExternalBufferInfo] :: VkPhysicalDeviceExternalBufferInfo -> VkExternalMemoryHandleTypeFlagBits
-- | VkExternalBufferProperties - Structure specifying supported external
-- handle capabilities
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_BUFFER_PROPERTIES
--
--
--
--
-- See Also
--
-- VkExternalMemoryProperties, VkStructureType,
-- vkGetPhysicalDeviceExternalBufferProperties,
-- vkGetPhysicalDeviceExternalBufferPropertiesKHR
data VkExternalBufferProperties
VkExternalBufferProperties :: VkStructureType -> Ptr () -> VkExternalMemoryProperties -> VkExternalBufferProperties
-- | sType is the type of this structure
[$sel:vkSType:VkExternalBufferProperties] :: VkExternalBufferProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExternalBufferProperties] :: VkExternalBufferProperties -> Ptr ()
-- | externalMemoryProperties is an instance of the
-- VkExternalMemoryProperties structure specifying various
-- capabilities of the external handle type when used with the specified
-- buffer creation parameters.
[$sel:vkExternalMemoryProperties:VkExternalBufferProperties] :: VkExternalBufferProperties -> VkExternalMemoryProperties
-- | VkPhysicalDeviceIDProperties - Structure specifying IDs related to the
-- physical device
--
-- Description
--
-- deviceUUID must be immutable for a given device across
-- instances, processes, driver APIs, driver versions, and system
-- reboots.
--
-- Applications can compare the driverUUID value across
-- instance and process boundaries, and can make similar queries
-- in external APIs to determine whether they are capable of sharing
-- memory objects and resources using them with the device.
--
-- deviceUUID and/or driverUUID must be used to
-- determine whether a particular external object can be shared between
-- driver components, where such a restriction exists as defined in the
-- compatibility table for the particular object type:
--
--
--
-- If deviceLUIDValid is VK_FALSE, the contents of
-- deviceLUID and deviceNodeMask are undefined. If
-- deviceLUIDValid is VK_TRUE and Vulkan is running on
-- the Windows operating system, the contents of deviceLUID
-- can be cast to an LUID object and must be equal
-- to the locally unique identifier of a IDXGIAdapter1 object
-- that corresponds to physicalDevice. If
-- deviceLUIDValid is VK_TRUE, deviceNodeMask
-- must contain exactly one bit. If Vulkan is running on an
-- operating system that supports the Direct3D 12 API and
-- physicalDevice corresponds to an individual device in a
-- linked device adapter, deviceNodeMask identifies the Direct3D
-- 12 node corresponding to physicalDevice. Otherwise,
-- deviceNodeMask must be 1.
--
-- Note
--
-- Although they have identical descriptions,
-- VkPhysicalDeviceIDProperties::deviceUUID may differ
-- from VkPhysicalDeviceProperties2::pipelineCacheUUID.
-- The former is intended to identify and correlate devices across API
-- and driver boundaries, while the latter is used to identify a
-- compatible device and driver combination to use when serializing and
-- de-serializing pipeline state.
--
-- Note
--
-- While VkPhysicalDeviceIDProperties::deviceUUID is
-- specified to remain consistent across driver versions and system
-- reboots, it is not intended to be usable as a serializable persistent
-- identifier for a device. It may change when a device is physically
-- added to, removed from, or moved to a different connector in a system
-- while that system is powered down. Further, there is no reasonable way
-- to verify with conformance testing that a given device retains the
-- same UUID in a given system across all driver versions supported in
-- that system. While implementations should make every effort to report
-- consistent device UUIDs across driver versions, applications should
-- avoid relying on the persistence of this value for uses other than
-- identifying compatible devices for external object sharing purposes.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_ID_PROPERTIES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceIDProperties
VkPhysicalDeviceIDProperties :: VkStructureType -> Ptr () -> Vector VK_UUID_SIZE Word8 -> Vector VK_UUID_SIZE Word8 -> Vector VK_LUID_SIZE Word8 -> Word32 -> VkBool32 -> VkPhysicalDeviceIDProperties
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> Ptr ()
-- | deviceUUID is an array of size VK_UUID_SIZE,
-- containing 8-bit values that represent a universally unique identifier
-- for the device.
[$sel:vkDeviceUUID:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> Vector VK_UUID_SIZE Word8
-- | driverUUID is an array of size VK_UUID_SIZE,
-- containing 8-bit values that represent a universally unique identifier
-- for the driver build in use by the device.
[$sel:vkDriverUUID:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> Vector VK_UUID_SIZE Word8
-- | deviceLUID is an array of size VK_LUID_SIZE,
-- containing 8-bit values that represent a locally unique identifier for
-- the device.
[$sel:vkDeviceLUID:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> Vector VK_LUID_SIZE Word8
-- | deviceNodeMask is a bitfield identifying the node within a
-- linked device adapter corresponding to the device.
[$sel:vkDeviceNodeMask:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> Word32
-- | deviceLUIDValid is a boolean value that will be
-- VK_TRUE if deviceLUID contains a valid LUID and
-- deviceNodeMask contains a valid node mask, and
-- VK_FALSE if they do not.
[$sel:vkDeviceLUIDValid:VkPhysicalDeviceIDProperties] :: VkPhysicalDeviceIDProperties -> VkBool32
-- | VkExternalMemoryHandleTypeFlags - Bitmask of
-- VkExternalMemoryHandleTypeFlagBits
--
-- Description
--
-- VkExternalMemoryHandleTypeFlags is a bitmask type for setting
-- a mask of zero or more VkExternalMemoryHandleTypeFlagBits.
--
-- See Also
--
-- VkExportMemoryAllocateInfo,
-- VkExternalMemoryBufferCreateInfo,
-- VkExternalMemoryHandleTypeFlagBits,
-- VkExternalMemoryImageCreateInfo,
-- VkExternalMemoryProperties
type VkExternalMemoryHandleTypeFlags = VkExternalMemoryHandleTypeFlagBits
-- | VkExternalMemoryFeatureFlags - Bitmask of
-- VkExternalMemoryFeatureFlagBits
--
-- Description
--
-- VkExternalMemoryFeatureFlags is a bitmask type for setting a
-- mask of zero or more VkExternalMemoryFeatureFlagBits.
--
-- See Also
--
-- VkExternalMemoryFeatureFlagBits,
-- VkExternalMemoryProperties
type VkExternalMemoryFeatureFlags = VkExternalMemoryFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalImageFormatProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalImageFormatProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalBufferProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalBufferProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceIDProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceIDProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalBufferInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalBufferInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalImageFormatInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalImageFormatInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalImageFormatProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalBufferProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceIDProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalBufferInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkPhysicalDeviceExternalImageFormatInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryFeatureFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory_capabilities.VkExternalMemoryHandleTypeFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd
-- | vkGetMemoryFdKHR - Get a POSIX file descriptor for a memory object
--
-- Parameters
--
--
-- - device is the logical device that created the device
-- memory being exported.
--
--
--
-- - pGetFdInfo is a pointer to an instance of the
-- VkMemoryGetFdInfoKHR structure containing parameters of the
-- export operation.
-- - pFd will return a file descriptor representing the
-- underlying resources of the device memory object.
--
--
-- Description
--
-- Each call to vkGetMemoryFdKHR must create a new file
-- descriptor and transfer ownership of it to the application. To avoid
-- leaking resources, the application must release ownership of
-- the file descriptor using the close system call when it is no
-- longer needed, or by importing a Vulkan memory object from it. Where
-- supported by the operating system, the implementation must set
-- the file descriptor to be closed automatically when an execve
-- system call is made.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pGetFdInfo must be a valid pointer to a valid
-- VkMemoryGetFdInfoKHR structure
-- - pFd must be a valid pointer to a int
-- value
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_TOO_MANY_OBJECTS
--
--
-- See Also
--
-- VkDevice, VkMemoryGetFdInfoKHR
vkGetMemoryFdKHR :: ("device" ::: VkDevice) -> ("pGetFdInfo" ::: Ptr VkMemoryGetFdInfoKHR) -> ("pFd" ::: Ptr CInt) -> IO VkResult
-- | vkGetMemoryFdPropertiesKHR - Get Properties of External Memory File
-- Descriptors
--
-- Parameters
--
--
-- - device is the logical device that will be importing
-- fd.
--
--
--
-- - handleType is the type of the handle fd.
-- - fd is the handle which will be imported.
-- - pMemoryFdProperties will return properties of the handle
-- fd.
--
--
-- Description
--
-- Valid Usage
--
--
-- - fd must be an external memory handle created
-- outside of the Vulkan API.
--
--
--
-- - handleType must not be
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_OPAQUE_FD_BIT_KHR.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_INVALID_EXTERNAL_HANDLE
--
--
-- See Also
--
-- VkDevice, VkExternalMemoryHandleTypeFlagBits,
-- VkMemoryFdPropertiesKHR
vkGetMemoryFdPropertiesKHR :: ("device" ::: VkDevice) -> ("handleType" ::: VkExternalMemoryHandleTypeFlagBits) -> ("fd" ::: CInt) -> ("pMemoryFdProperties" ::: Ptr VkMemoryFdPropertiesKHR) -> IO VkResult
-- | VkImportMemoryFdInfoKHR - import memory created on the same physical
-- device from a file descriptor
--
-- Description
--
-- Importing memory from a file descriptor transfers ownership of the
-- file descriptor from the application to the Vulkan implementation. The
-- application must not perform any operations on the file
-- descriptor after a successful import.
--
-- Applications can import the same underlying memory into
-- multiple instances of Vulkan, into the same instance from which it was
-- exported, and multiple times into a given Vulkan instance. In all
-- cases, each import operation must create a distinct
-- VkDeviceMemory object.
--
-- Valid Usage
--
--
--
--
-- - The memory from which fd was exported must have
-- been created on the same underlying physical device as
-- device.
-- - If handleType is not 0, it must be
-- defined as a POSIX file descriptor handle.
-- - If handleType is not 0, fd must
-- be a valid handle of the type specified by handleType.
-- - The memory represented by fd must have been
-- created from a physical device and driver that is compatible with
-- device and handleType, as described in
-- {html_spec_relative}#external-memory-handle-types-compatibility.
-- - fd must obey any requirements listed for
-- handleType in external memory handle types
-- compatibility.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMPORT_MEMORY_FD_INFO_KHR
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagBits, VkStructureType
data VkImportMemoryFdInfoKHR
VkImportMemoryFdInfoKHR :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlagBits -> CInt -> VkImportMemoryFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkImportMemoryFdInfoKHR] :: VkImportMemoryFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImportMemoryFdInfoKHR] :: VkImportMemoryFdInfoKHR -> Ptr ()
-- | handleType specifies the handle type of fd.
[$sel:vkHandleType:VkImportMemoryFdInfoKHR] :: VkImportMemoryFdInfoKHR -> VkExternalMemoryHandleTypeFlagBits
-- | fd is the external handle to import.
[$sel:vkFd:VkImportMemoryFdInfoKHR] :: VkImportMemoryFdInfoKHR -> CInt
-- | VkMemoryFdPropertiesKHR - Properties of External Memory File
-- Descriptors
--
-- Description
--
-- See Also
--
-- VkStructureType, vkGetMemoryFdPropertiesKHR
data VkMemoryFdPropertiesKHR
VkMemoryFdPropertiesKHR :: VkStructureType -> Ptr () -> Word32 -> VkMemoryFdPropertiesKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryFdPropertiesKHR] :: VkMemoryFdPropertiesKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryFdPropertiesKHR] :: VkMemoryFdPropertiesKHR -> Ptr ()
-- | memoryTypeBits is a bitmask containing one bit set for every
-- memory type which the specified file descriptor can be imported
-- as.
[$sel:vkMemoryTypeBits:VkMemoryFdPropertiesKHR] :: VkMemoryFdPropertiesKHR -> Word32
-- | VkMemoryGetFdInfoKHR - Structure describing a POSIX FD semaphore
-- export operation
--
-- Description
--
-- The properties of the file descriptor exported depend on the value of
-- handleType. See VkExternalMemoryHandleTypeFlagBits for
-- a description of the properties of the defined external memory handle
-- types.
--
-- Note
--
-- The size of the exported file may be larger than the size
-- requested by VkMemoryAllocateInfo::allocationSize. If
-- handleType is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_DMA_BUF_BIT_EXT, then the
-- application can query the file’s actual size with
-- lseek(2).
--
-- Valid Usage
--
--
--
--
-- - handleType must be defined as a POSIX file
-- descriptor handle.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_GET_FD_INFO_KHR
--
--
--
--
-- See Also
--
-- VkDeviceMemory, VkExternalMemoryHandleTypeFlagBits,
-- VkStructureType, vkGetMemoryFdKHR
data VkMemoryGetFdInfoKHR
VkMemoryGetFdInfoKHR :: VkStructureType -> Ptr () -> VkDeviceMemory -> VkExternalMemoryHandleTypeFlagBits -> VkMemoryGetFdInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryGetFdInfoKHR] :: VkMemoryGetFdInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryGetFdInfoKHR] :: VkMemoryGetFdInfoKHR -> Ptr ()
-- | memory is the memory object from which the handle will be
-- exported.
[$sel:vkMemory:VkMemoryGetFdInfoKHR] :: VkMemoryGetFdInfoKHR -> VkDeviceMemory
-- | handleType is the type of handle requested.
[$sel:vkHandleType:VkMemoryGetFdInfoKHR] :: VkMemoryGetFdInfoKHR -> VkExternalMemoryHandleTypeFlagBits
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryGetFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryGetFdInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryFdPropertiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryFdPropertiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkImportMemoryFdInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkImportMemoryFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryGetFdInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkMemoryFdPropertiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_external_memory_fd.VkImportMemoryFdInfoKHR
module Graphics.Vulkan.Extensions.VK_KHR_external_memory_capabilities
vkGetPhysicalDeviceExternalBufferPropertiesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pExternalBufferInfo" ::: Ptr VkPhysicalDeviceExternalBufferInfo) -> ("pExternalBufferProperties" ::: Ptr VkExternalBufferProperties) -> IO ()
type VkExternalMemoryHandleTypeFlagBitsKHR = VkExternalMemoryHandleTypeFlagBits
type VkExternalMemoryFeatureFlagBitsKHR = VkExternalMemoryFeatureFlagBits
type VkExternalMemoryHandleTypeFlagsKHR = VkExternalMemoryHandleTypeFlags
type VkExternalMemoryFeatureFlagsKHR = VkExternalMemoryFeatureFlags
type VkExternalMemoryPropertiesKHR = VkExternalMemoryProperties
type VkPhysicalDeviceExternalImageFormatInfoKHR = VkPhysicalDeviceExternalImageFormatInfo
type VkExternalImageFormatPropertiesKHR = VkExternalImageFormatProperties
type VkPhysicalDeviceExternalBufferInfoKHR = VkPhysicalDeviceExternalBufferInfo
type VkExternalBufferPropertiesKHR = VkExternalBufferProperties
type VkPhysicalDeviceIDPropertiesKHR = VkPhysicalDeviceIDProperties
type VK_LUID_SIZE_KHR = VK_LUID_SIZE
module Graphics.Vulkan.Extensions.VK_EXT_external_memory_host
-- | vkGetMemoryHostPointerPropertiesEXT - Get properties of external
-- memory host pointer
--
-- Parameters
--
--
-- - device is the logical device that will be importing
-- pHostPointer.
--
--
--
-- - handleType is the type of the handle
-- pHostPointer.
-- - pHostPointer is the host pointer to import from.
--
--
-- Description
--
-- Valid Usage
--
--
-- - handleType must be
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
--
--
--
-- - pHostPointer must be a pointer aligned to an
-- integer multiple of
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT::minImportedHostPointerAlignment
-- - If handleType is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT,
-- pHostPointer must be a pointer to host memory
-- - If handleType is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT,
-- pHostPointer must be a pointer to host mapped foreign
-- memory
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - handleType must be a valid
-- VkExternalMemoryHandleTypeFlagBits value
-- - pMemoryHostPointerProperties must be a valid
-- pointer to a VkMemoryHostPointerPropertiesEXT structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_INVALID_EXTERNAL_HANDLE
--
--
-- See Also
--
-- VkDevice, VkExternalMemoryHandleTypeFlagBits,
-- VkMemoryHostPointerPropertiesEXT
vkGetMemoryHostPointerPropertiesEXT :: ("device" ::: VkDevice) -> ("handleType" ::: VkExternalMemoryHandleTypeFlagBits) -> ("pHostPointer" ::: Ptr ()) -> ("pMemoryHostPointerProperties" ::: Ptr VkMemoryHostPointerPropertiesEXT) -> IO VkResult
-- | VkImportMemoryHostPointerInfoEXT - import memory from a host pointer
--
-- Description
--
-- Importing memory from a host pointer shares ownership of the memory
-- between the host and the Vulkan implementation. The application
-- can continue to access the memory through the host pointer but
-- it is the application’s responsibility to synchronize device and
-- non-device access to the underlying memory as defined in Host
-- Access to Device Memory Objects.
--
-- Applications can import the same underlying memory into
-- multiple instances of Vulkan and multiple times into a given Vulkan
-- instance. However, implementations may fail to import the same
-- underlying memory multiple times into a given physical device due to
-- platform constraints.
--
-- Importing memory from a particular host pointer may not be
-- possible due to additional platform-specific restrictions beyond the
-- scope of this specification in which case the implementation
-- must fail the memory import operation with the error code
-- VK_ERROR_INVALID_EXTERNAL_HANDLE_KHR.
--
-- The application must ensure that the imported memory range
-- remains valid and accessible for the lifetime of the imported memory
-- object.
--
-- Valid Usage
--
--
--
--
-- - If handleType is not 0, it must be
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT or
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
-- - pHostPointer must be a pointer aligned to an
-- integer multiple of
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT::minImportedHostPointerAlignment
-- - If handleType is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT,
-- pHostPointer must be a pointer to
-- allocationSize number of bytes of host memory, where
-- allocationSize is the member of the
-- VkMemoryAllocateInfo structure this structure is chained
-- to
-- - If handleType is
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT,
-- pHostPointer must be a pointer to
-- allocationSize number of bytes of host mapped foreign memory,
-- where allocationSize is the member of the
-- VkMemoryAllocateInfo structure this structure is chained
-- to
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlagBits, VkStructureType
data VkImportMemoryHostPointerInfoEXT
VkImportMemoryHostPointerInfoEXT :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlagBits -> Ptr () -> VkImportMemoryHostPointerInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkImportMemoryHostPointerInfoEXT] :: VkImportMemoryHostPointerInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImportMemoryHostPointerInfoEXT] :: VkImportMemoryHostPointerInfoEXT -> Ptr ()
-- | handleType specifies the handle type.
[$sel:vkHandleType:VkImportMemoryHostPointerInfoEXT] :: VkImportMemoryHostPointerInfoEXT -> VkExternalMemoryHandleTypeFlagBits
-- | pHostPointer is the host pointer to import from.
[$sel:vkPHostPointer:VkImportMemoryHostPointerInfoEXT] :: VkImportMemoryHostPointerInfoEXT -> Ptr ()
data VkMemoryHostPointerPropertiesEXT
VkMemoryHostPointerPropertiesEXT :: VkStructureType -> Ptr () -> Word32 -> VkMemoryHostPointerPropertiesEXT
[$sel:vkSType:VkMemoryHostPointerPropertiesEXT] :: VkMemoryHostPointerPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkMemoryHostPointerPropertiesEXT] :: VkMemoryHostPointerPropertiesEXT -> Ptr ()
[$sel:vkMemoryTypeBits:VkMemoryHostPointerPropertiesEXT] :: VkMemoryHostPointerPropertiesEXT -> Word32
-- | VkPhysicalDeviceExternalMemoryHostPropertiesEXT - Structure describing
-- external memory host pointer limits that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceExternalMemoryHostPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - minImportedHostPointerAlignment is the minimum
-- required alignment, in bytes, for the base address and size of
-- host pointers that can be imported to a Vulkan memory
-- object.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT
--
--
-- If the VkPhysicalDeviceExternalMemoryHostPropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2KHR, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkDeviceSize, VkStructureType
data VkPhysicalDeviceExternalMemoryHostPropertiesEXT
VkPhysicalDeviceExternalMemoryHostPropertiesEXT :: VkStructureType -> Ptr () -> VkDeviceSize -> VkPhysicalDeviceExternalMemoryHostPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceExternalMemoryHostPropertiesEXT] :: VkPhysicalDeviceExternalMemoryHostPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceExternalMemoryHostPropertiesEXT] :: VkPhysicalDeviceExternalMemoryHostPropertiesEXT -> Ptr ()
[$sel:vkMinImportedHostPointerAlignment:VkPhysicalDeviceExternalMemoryHostPropertiesEXT] :: VkPhysicalDeviceExternalMemoryHostPropertiesEXT -> VkDeviceSize
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkPhysicalDeviceExternalMemoryHostPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkPhysicalDeviceExternalMemoryHostPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkMemoryHostPointerPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkMemoryHostPointerPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkImportMemoryHostPointerInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkImportMemoryHostPointerInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkPhysicalDeviceExternalMemoryHostPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkMemoryHostPointerPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_external_memory_host.VkImportMemoryHostPointerInfoEXT
module Graphics.Vulkan.Extensions.VK_EXT_external_memory_dma_buf
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory
-- | VkExternalMemoryImageCreateInfo - Specify that an image may be backed
-- by external memory
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_IMAGE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlags, VkStructureType
data VkExternalMemoryImageCreateInfo
VkExternalMemoryImageCreateInfo :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlags -> VkExternalMemoryImageCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkExternalMemoryImageCreateInfo] :: VkExternalMemoryImageCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExternalMemoryImageCreateInfo] :: VkExternalMemoryImageCreateInfo -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBits specifying one or more
-- external memory handle types.
[$sel:vkHandleTypes:VkExternalMemoryImageCreateInfo] :: VkExternalMemoryImageCreateInfo -> VkExternalMemoryHandleTypeFlags
-- | VkExternalMemoryBufferCreateInfo - Specify that a buffer may be backed
-- by external memory
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXTERNAL_MEMORY_BUFFER_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlags, VkStructureType
data VkExternalMemoryBufferCreateInfo
VkExternalMemoryBufferCreateInfo :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlags -> VkExternalMemoryBufferCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkExternalMemoryBufferCreateInfo] :: VkExternalMemoryBufferCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExternalMemoryBufferCreateInfo] :: VkExternalMemoryBufferCreateInfo -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBits specifying one or more
-- external memory handle types.
[$sel:vkHandleTypes:VkExternalMemoryBufferCreateInfo] :: VkExternalMemoryBufferCreateInfo -> VkExternalMemoryHandleTypeFlags
-- | VkExportMemoryAllocateInfo - Specify exportable handle types for a
-- device memory object
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_EXPORT_MEMORY_ALLOCATE_INFO
--
--
--
--
-- See Also
--
-- VkExternalMemoryHandleTypeFlags, VkStructureType
data VkExportMemoryAllocateInfo
VkExportMemoryAllocateInfo :: VkStructureType -> Ptr () -> VkExternalMemoryHandleTypeFlags -> VkExportMemoryAllocateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkExportMemoryAllocateInfo] :: VkExportMemoryAllocateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkExportMemoryAllocateInfo] :: VkExportMemoryAllocateInfo -> Ptr ()
-- | handleTypes is a bitmask of
-- VkExternalMemoryHandleTypeFlagBits specifying one or more
-- memory handle types the application can export from the
-- resulting allocation. The application can request multiple
-- handle types for the same allocation.
[$sel:vkHandleTypes:VkExportMemoryAllocateInfo] :: VkExportMemoryAllocateInfo -> VkExternalMemoryHandleTypeFlags
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExportMemoryAllocateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExportMemoryAllocateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryBufferCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryBufferCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryImageCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryImageCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExportMemoryAllocateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryBufferCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_external_memory.VkExternalMemoryImageCreateInfo
module Graphics.Vulkan.Extensions.VK_KHR_external_memory
type VkExternalMemoryImageCreateInfoKHR = VkExternalMemoryImageCreateInfo
type VkExternalMemoryBufferCreateInfoKHR = VkExternalMemoryBufferCreateInfo
type VkExportMemoryAllocateInfoKHR = VkExportMemoryAllocateInfo
module Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory
-- | VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT specifies that the
-- device queue is a protected-capable queue. If the protected memory
-- feature is not enabled, the
-- VK_DEVICE_QUEUE_CREATE_PROTECTED_BIT bit of flags
-- must not be set.
-- | vkGetDeviceQueue2 - Get a queue handle from a device
--
-- Parameters
--
--
-- - device is the logical device that owns the queue.
--
--
--
-- - pQueueInfo points to an instance of the
-- VkDeviceQueueInfo2 structure, describing the parameters used to
-- create the device queue.
-- - pQueue is a pointer to a VkQueue object that
-- will be filled with the handle for the requested queue.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pQueueInfo must be a valid pointer to a valid
-- VkDeviceQueueInfo2 structure
-- - pQueue must be a valid pointer to a
-- VkQueue handle
--
--
-- See Also
--
-- VkDevice, VkDeviceQueueInfo2, VkQueue
vkGetDeviceQueue2 :: ("device" ::: VkDevice) -> ("pQueueInfo" ::: Ptr VkDeviceQueueInfo2) -> ("pQueue" ::: Ptr VkQueue) -> IO ()
-- | VkProtectedSubmitInfo - Structure indicating whether the submission is
-- protected
--
-- Description
--
-- Valid Usage
--
--
-- - If the protected memory feature is not enabled,
-- protectedSubmit must not be VK_TRUE.
--
--
--
-- - If protectedSubmit is VK_TRUE, then each element
-- of the pCommandBuffers array must be a protected
-- command buffer.
-- - If protectedSubmit is VK_FALSE, then each
-- element of the pCommandBuffers array must be an
-- unprotected command buffer.
-- - If the VkSubmitInfo::pNext chain does not
-- include a VkProtectedSubmitInfo structure, then each element
-- of the command buffer of the pCommandBuffers array
-- must be an unprotected command buffer.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PROTECTED_SUBMIT_INFO
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkProtectedSubmitInfo
VkProtectedSubmitInfo :: VkStructureType -> Ptr () -> VkBool32 -> VkProtectedSubmitInfo
[$sel:vkSType:VkProtectedSubmitInfo] :: VkProtectedSubmitInfo -> VkStructureType
[$sel:vkPNext:VkProtectedSubmitInfo] :: VkProtectedSubmitInfo -> Ptr ()
-- | protectedSubmit specifies whether the batch is protected. If
-- protectedSubmit is VK_TRUE, the batch is protected.
-- If protectedSubmit is VK_FALSE, the batch is
-- unprotected. If the VkSubmitInfo::pNext chain does
-- not contain this structure, the batch is unprotected.
[$sel:vkProtectedSubmit:VkProtectedSubmitInfo] :: VkProtectedSubmitInfo -> VkBool32
-- | VkPhysicalDeviceProtectedMemoryFeatures - Structure describing
-- protected memory features that can be supported by an implementation
--
-- Description
--
-- If the VkPhysicalDeviceProtectedMemoryFeatures structure is
-- included in the pNext chain of
-- VkPhysicalDeviceFeatures2, it is filled with a value indicating
-- whether the feature is supported.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceProtectedMemoryFeatures
VkPhysicalDeviceProtectedMemoryFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceProtectedMemoryFeatures
[$sel:vkSType:VkPhysicalDeviceProtectedMemoryFeatures] :: VkPhysicalDeviceProtectedMemoryFeatures -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceProtectedMemoryFeatures] :: VkPhysicalDeviceProtectedMemoryFeatures -> Ptr ()
-- | protectedMemory specifies whether protected memory is
-- supported.
[$sel:vkProtectedMemory:VkPhysicalDeviceProtectedMemoryFeatures] :: VkPhysicalDeviceProtectedMemoryFeatures -> VkBool32
-- | VkPhysicalDeviceProtectedMemoryProperties - Structure describing
-- protected memory properties that can be supported by an implementation
--
-- Description
--
-- If the VkPhysicalDeviceProtectedMemoryProperties structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with a value
-- indicating the implementation-dependent behavior.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROTECTED_MEMORY_PROPERTIES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceProtectedMemoryProperties
VkPhysicalDeviceProtectedMemoryProperties :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceProtectedMemoryProperties
-- | sType is the type of this structure.
[$sel:vkSType:VkPhysicalDeviceProtectedMemoryProperties] :: VkPhysicalDeviceProtectedMemoryProperties -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPhysicalDeviceProtectedMemoryProperties] :: VkPhysicalDeviceProtectedMemoryProperties -> Ptr ()
-- | protectedNoFault specifies whether the undefined behavior
-- will not include process termination or device loss. If
-- protectedNoFault is VK_FALSE, undefined behavior
-- may include process termination or device loss. If
-- protectedNoFault is VK_TRUE, undefined behavior will
-- not include process termination or device loss.
[$sel:vkProtectedNoFault:VkPhysicalDeviceProtectedMemoryProperties] :: VkPhysicalDeviceProtectedMemoryProperties -> VkBool32
-- | VkDeviceQueueInfo2 - Structure specifying the parameters used for
-- device queue creation
--
-- Description
--
-- The queue returned by vkGetDeviceQueue2 must have the
-- same flags value from this structure as that used at device
-- creation time in a VkDeviceQueueCreateInfo instance. If no
-- matching flags were specified at device creation time then
-- pQueue will return VK_NULL_HANDLE.
--
-- Valid Usage
--
--
-- - queueFamilyIndex must be one of the queue family
-- indices specified when device was created, via the
-- VkDeviceQueueCreateInfo structure
--
--
--
-- - queueIndex must be less than the number of queues
-- created for the specified queue family index and
-- VkDeviceQueueCreateFlags member flags equal to this
-- flags value when device was created, via the
-- queueCount member of the VkDeviceQueueCreateInfo
-- structure
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_QUEUE_INFO_2
--
--
--
--
-- See Also
--
-- VkDeviceQueueCreateFlags, VkStructureType,
-- vkGetDeviceQueue2
data VkDeviceQueueInfo2
VkDeviceQueueInfo2 :: VkStructureType -> Ptr () -> VkDeviceQueueCreateFlags -> Word32 -> Word32 -> VkDeviceQueueInfo2
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceQueueInfo2] :: VkDeviceQueueInfo2 -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure. The pNext chain of VkDeviceQueueInfo2 is
-- used to provide additional image parameters to
-- vkGetDeviceQueue2.
[$sel:vkPNext:VkDeviceQueueInfo2] :: VkDeviceQueueInfo2 -> Ptr ()
-- | flags is a VkDeviceQueueCreateFlags value indicating
-- the flags used to create the device queue.
[$sel:vkFlags:VkDeviceQueueInfo2] :: VkDeviceQueueInfo2 -> VkDeviceQueueCreateFlags
-- | queueFamilyIndex is the index of the queue family to which
-- the queue belongs.
[$sel:vkQueueFamilyIndex:VkDeviceQueueInfo2] :: VkDeviceQueueInfo2 -> Word32
-- | queueIndex is the index within this queue family of the queue
-- to retrieve.
[$sel:vkQueueIndex:VkDeviceQueueInfo2] :: VkDeviceQueueInfo2 -> Word32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkDeviceQueueInfo2
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkDeviceQueueInfo2
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryFeatures
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkProtectedSubmitInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkProtectedSubmitInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkDeviceQueueInfo2
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkPhysicalDeviceProtectedMemoryFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_From_VK_KHR_protected_memory.VkProtectedSubmitInfo
module Graphics.Vulkan.Core10.Image
-- | VkImageLayout - Layout of image and image subresources
--
-- Description
--
-- The type(s) of device access supported by each layout are:
--
--
-- - VK_IMAGE_LAYOUT_UNDEFINED does not support device access.
-- This layout must only be used as the initialLayout
-- member of VkImageCreateInfo or
-- VkAttachmentDescription, or as the oldLayout in an
-- image transition. When transitioning out of this layout, the contents
-- of the memory are not guaranteed to be preserved.
-- - VK_IMAGE_LAYOUT_PREINITIALIZED does not support device
-- access. This layout must only be used as the
-- initialLayout member of VkImageCreateInfo or
-- VkAttachmentDescription, or as the oldLayout in an
-- image transition. When transitioning out of this layout, the contents
-- of the memory are preserved. This layout is intended to be used as the
-- initial layout for an image whose contents are written by the host,
-- and hence the data can be written to memory immediately,
-- without first executing a layout transition. Currently,
-- VK_IMAGE_LAYOUT_PREINITIALIZED is only useful with
-- VK_IMAGE_TILING_LINEAR images because there is not a standard
-- layout defined for VK_IMAGE_TILING_OPTIMAL images.
-- - VK_IMAGE_LAYOUT_GENERAL supports all types of device
-- access.
-- - VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL must only
-- be used as a color or resolve attachment in a VkFramebuffer.
-- This layout is valid only for image subresources of images created
-- with the VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT usage bit
-- enabled.
-- - VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL
-- must only be used as a depth/stencil attachment in a
-- VkFramebuffer. This layout is valid only for image
-- subresources of images created with the
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT usage bit
-- enabled.
-- - VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL
-- must only be used as a read-only depth/stencil attachment in a
-- VkFramebuffer and/or as a read-only image in a shader (which
-- can be read as a sampled image, combined image/sampler and/or
-- input attachment). This layout is valid only for image subresources of
-- images created with the
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT usage bit
-- enabled. Only image subresources of images created with
-- VK_IMAGE_USAGE_SAMPLED_BIT can be used as a sampled
-- image or combined image/sampler in a shader. Similarly, only image
-- subresources of images created with
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT can be used as
-- input attachments.
--
-- - VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL:
-- must only be used as a depth/stencil attachment in a
-- VkFramebuffer, where the depth aspect is read-only, and/or as
-- a read-only image in a shader (which can be read as a sampled
-- image, combined image/sampler and/or input attachment) where only the
-- depth aspect is accessed. This layout is valid only for image
-- subresources of images created with the
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT usage bit
-- enabled. Only image subresources of images created with
-- VK_IMAGE_USAGE_SAMPLED_BIT can be used as a sampled
-- image or combined image/sampler in a shader. Similarly, only image
-- subresources of images created with
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT can be used as
-- input attachments.
--
-- - VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL:
-- must only be used as a depth/stencil attachment in a
-- VkFramebuffer, where the stencil aspect is read-only, and/or
-- as a read-only image in a shader (which can be read as a
-- sampled image, combined image/sampler and/or input attachment) where
-- only the stencil aspect is accessed. This layout is valid only for
-- image subresources of images created with the
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT usage bit
-- enabled. Only image subresources of images created with
-- VK_IMAGE_USAGE_SAMPLED_BIT can be used as a sampled
-- image or combined image/sampler in a shader. Similarly, only image
-- subresources of images created with
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT can be used as
-- input attachments.
-- - VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL must only
-- be used as a read-only image in a shader (which can be read as
-- a sampled image, combined image/sampler and/or input attachment). This
-- layout is valid only for image subresources of images created with the
-- VK_IMAGE_USAGE_SAMPLED_BIT or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT usage bit enabled.
-- - VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL must only be
-- used as a source image of a transfer command (see the definition of
-- VK_PIPELINE_STAGE_TRANSFER_BIT). This layout is valid only for
-- image subresources of images created with the
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT usage bit enabled.
-- - VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL must only be
-- used as a destination image of a transfer command. This layout is
-- valid only for image subresources of images created with the
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage bit enabled.
-- - VK_IMAGE_LAYOUT_PRESENT_SRC_KHR must only be used
-- for presenting a presentable image for display. A swapchain’s image
-- must be transitioned to this layout before calling
-- vkQueuePresentKHR, and must be transitioned away from
-- this layout after calling vkAcquireNextImageKHR.
-- - VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR is valid only for
-- shared presentable images, and must be used for any usage the
-- image supports.
--
--
-- The layout of each image subresource is not a state of the image
-- subresource itself, but is rather a property of how the data in memory
-- is organized, and thus for each mechanism of accessing an image in the
-- API the application must specify a parameter or structure
-- member that indicates which image layout the image subresource(s) are
-- considered to be in when the image will be accessed. For transfer
-- commands, this is a parameter to the command (see
-- {html_spec_relative}#clears and
-- {html_spec_relative}#copies). For use as a framebuffer
-- attachment, this is a member in the substructures of the
-- VkRenderPassCreateInfo (see Render Pass). For use in a
-- descriptor set, this is a member in the VkDescriptorImageInfo
-- structure (see {html_spec_relative}#descriptorsets-updates). At
-- the time that any command buffer command accessing an image executes
-- on any queue, the layouts of the image subresources that are accessed
-- must all match the layout specified via the API controlling
-- those accesses.
--
-- When performing a layout transition on an image subresource, the old
-- layout value must either equal the current layout of the image
-- subresource (at the time the transition executes), or else be
-- VK_IMAGE_LAYOUT_UNDEFINED (implying that the contents of the
-- image subresource need not be preserved). The new layout used in a
-- transition must not be VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED.
--
-- The image layout of each image subresource of a depth/stencil image
-- created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT is
-- dependent on the last sample locations used to render to the image
-- subresource as a depth/stencil attachment, thus applications
-- must provide the same sample locations that were last used to
-- render to the given image subresource whenever a layout transition of
-- the image subresource happens, otherwise the contents of the depth
-- aspect of the image subresource become undefined.
--
-- In addition, depth reads from a depth/stencil attachment referring to
-- an image subresource range of a depth/stencil image created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- using different sample locations than what have been last used to
-- perform depth writes to the image subresources of the same image
-- subresource range produce undefined results.
--
-- Similarly, depth writes to a depth/stencil attachment referring to an
-- image subresource range of a depth/stencil image created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- using different sample locations than what have been last used to
-- perform depth writes to the image subresources of the same image
-- subresource range make the contents of the depth aspect of those image
-- subresources undefined.
--
-- See Also
--
-- VkAttachmentDescription, VkAttachmentReference,
-- VkDescriptorImageInfo, VkImageCreateInfo,
-- VkImageMemoryBarrier, vkCmdBlitImage,
-- vkCmdClearColorImage, vkCmdClearDepthStencilImage,
-- vkCmdCopyBufferToImage, vkCmdCopyImage,
-- vkCmdCopyImageToBuffer, vkCmdResolveImage
newtype VkImageLayout
VkImageLayout :: Int32 -> VkImageLayout
-- | vkCreateImage - Create a new image object
--
-- Parameters
--
--
-- - device is the logical device that creates the image.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkImageCreateInfo structure containing parameters to be used
-- to create the image.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pImage points to a VkImage handle in which the
-- resulting image object is returned.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If the flags member of pCreateInfo includes
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT, creating this
-- VkImage must not cause the total required sparse
-- memory for all currently valid sparse resources on the device to
-- exceed
-- VkPhysicalDeviceLimits::sparseAddressSpaceSize
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkImageCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pImage must be a valid pointer to a
-- VkImage handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkImage,
-- VkImageCreateInfo
vkCreateImage :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkImageCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pImage" ::: Ptr VkImage) -> IO VkResult
-- | vkDestroyImage - Destroy an image object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- image.
--
--
--
-- - image is the image to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to image, either
-- directly or via a VkImageView, must have completed
-- execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- image was created, a compatible set of callbacks must
-- be provided here
-- - If no VkAllocationCallbacks were provided when
-- image was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If image is not VK_NULL_HANDLE, image
-- must be a valid VkImage handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If image is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to image must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkImage
vkDestroyImage :: ("device" ::: VkDevice) -> ("image" ::: VkImage) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetImageSubresourceLayout - Retrieve information about an image
-- subresource
--
-- Parameters
--
--
-- - device is the logical device that owns the image.
--
--
--
-- - image is the image whose layout is being queried.
-- - pSubresource is a pointer to a VkImageSubresource
-- structure selecting a specific image for the image subresource.
-- - pLayout points to a VkSubresourceLayout structure
-- in which the layout is returned.
--
--
-- Description
--
-- If the VkFormat of image is a multi-planar
-- format, vkGetImageSubresourceLayout describes one plane
-- of the image.
--
-- vkGetImageSubresourceLayout is invariant for the lifetime of a
-- single image. However, the subresource layout of images in Android
-- hardware buffer external memory isn’t known until the image has been
-- bound to memory, so calling vkGetImageSubresourceLayout for
-- such an image before it has been bound will result in undefined
-- behavior.
--
-- Valid Usage
--
--
-- - image must have been created with tiling
-- equal to VK_IMAGE_TILING_LINEAR
--
--
--
-- - The aspectMask member of pSubresource
-- must only have a single bit set
-- - The mipLevel member of pSubresource must
-- be less than the mipLevels specified in
-- VkImageCreateInfo when image was created
-- - The arrayLayer member of pSubresource
-- must be less than the arrayLayers specified in
-- VkImageCreateInfo when image was created
-- - If the format of image is a multi-planar
-- format with two planes, the aspectMask member of
-- pSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT or
-- VK_IMAGE_ASPECT_PLANE_1_BIT
-- - If the format of image is a multi-planar
-- format with three planes, the aspectMask member of
-- pSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT or
-- VK_IMAGE_ASPECT_PLANE_2_BIT
-- - If image was created with the
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID
-- external memory handle type, then image must be bound
-- to memory.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - image must be a valid VkImage handle
-- - pSubresource must be a valid pointer to a valid
-- VkImageSubresource structure
-- - pLayout must be a valid pointer to a
-- VkSubresourceLayout structure
-- - image must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkDevice, VkImage, VkImageSubresource,
-- VkSubresourceLayout
vkGetImageSubresourceLayout :: ("device" ::: VkDevice) -> ("image" ::: VkImage) -> ("pSubresource" ::: Ptr VkImageSubresource) -> ("pLayout" ::: Ptr VkSubresourceLayout) -> IO ()
-- | VkImageCreateInfo - Structure specifying the parameters of a newly
-- created image object
--
-- Description
--
-- Images created with tiling equal to
-- VK_IMAGE_TILING_LINEAR have further restrictions on their
-- limits and capabilities compared to images created with
-- tiling equal to VK_IMAGE_TILING_OPTIMAL. Creation of
-- images with tiling VK_IMAGE_TILING_LINEAR may not be
-- supported unless other parameters meet all of the constraints:
--
--
-- - imageType is VK_IMAGE_TYPE_2D
-- - format is not a depth/stencil format
-- - mipLevels is 1
-- - arrayLayers is 1
-- - samples is VK_SAMPLE_COUNT_1_BIT
-- - usage only includes
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT and/or
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT
--
--
-- Implementations may support additional limits and capabilities
-- beyond those listed above.
--
-- To query an implementation’s specific capabilities for a given
-- combination of format, imageType, tiling,
-- usage,
-- VkExternalMemoryImageCreateInfo::handleTypes and
-- flags, call vkGetPhysicalDeviceImageFormatProperties2.
-- The return value specifies whether that combination of image settings
-- is supported. On success, the VkImageFormatProperties output
-- parameter specifies the set of valid samples bits and the
-- limits for extent, mipLevels, arrayLayers,
-- and maxResourceSize. Even if
-- vkGetPhysicalDeviceImageFormatProperties2. returns success and
-- the parameters to vkCreateImage are all within the returned limits,
-- vkCreateImage must fail and return
-- VK_ERROR_OUT_OF_DEVICE_MEMORY if the resulting size of the
-- image would be larger than maxResourceSize.
--
-- To determine the set of valid usage bits for a given format,
-- call vkGetPhysicalDeviceFormatProperties.
--
-- Note
--
-- For images created without VK_IMAGE_CREATE_EXTENDED_USAGE_BIT
-- a usage bit is valid if it is supported for the format the
-- image is created with.
--
-- For images created with VK_IMAGE_CREATE_EXTENDED_USAGE_BIT a
-- usage bit is valid if it is supported for at least one of the
-- formats a VkImageView created from the image can have
-- (see Image Views for more detail).
--
-- Valid Usage
--
--
-- - If the pNext chain doesn’t contain an instance of
-- VkExternalFormatANDROID, or if format is not
-- VK_FORMAT_UNDEFINED, the combination of format,
-- imageType, tiling, usage, and
-- flags must be supported, as indicated by a
-- VK_SUCCESS return value from
-- vkGetPhysicalDeviceImageFormatProperties invoked with the
-- same values passed to the corresponding parameters.
--
--
--
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- pQueueFamilyIndices must be a valid pointer to an
-- array of queueFamilyIndexCount uint32_t values
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- queueFamilyIndexCount must be greater than
-- 1
-- - If sharingMode is VK_SHARING_MODE_CONCURRENT,
-- each element of pQueueFamilyIndices must be unique and
-- must be less than pQueueFamilyPropertyCount returned
-- by either vkGetPhysicalDeviceQueueFamilyProperties or
-- vkGetPhysicalDeviceQueueFamilyProperties2 for the
-- physicalDevice that was used to create device
-- - format must not be
-- VK_FORMAT_UNDEFINED
-- - extent::width must be greater than
-- 0.
-- - extent::height must be greater than
-- 0.
-- - extent::depth must be greater than
-- 0.
-- - mipLevels must be greater than 0
-- - arrayLayers must be greater than 0
-- - If flags contains
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT, imageType
-- must be VK_IMAGE_TYPE_2D
-- - If flags contains
-- VK_IMAGE_CREATE_2D_ARRAY_COMPATIBLE_BIT, imageType
-- must be VK_IMAGE_TYPE_3D
-- - If imageType is VK_IMAGE_TYPE_1D,
-- extent.width must be less than or equal to
-- VkPhysicalDeviceLimits::maxImageDimension1D, or
-- VkImageFormatProperties::maxExtent.width (as
-- returned by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure) - whichever is
-- higher
-- - If imageType is VK_IMAGE_TYPE_2D and
-- flags does not contain
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT, extent.width
-- and extent.height must be less than or equal to
-- VkPhysicalDeviceLimits::maxImageDimension2D, or
-- VkImageFormatProperties::maxExtent.width/height
-- (as returned by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure) - whichever is
-- higher
-- - If imageType is VK_IMAGE_TYPE_2D and
-- flags contains VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT,
-- extent.width and extent.height must be less
-- than or equal to
-- VkPhysicalDeviceLimits::maxImageDimensionCube, or
-- VkImageFormatProperties::maxExtent.width/height
-- (as returned by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure) - whichever is
-- higher
-- - If imageType is VK_IMAGE_TYPE_2D and
-- flags contains VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT,
-- extent.width and extent.height must be equal
-- and arrayLayers must be greater than or equal to
-- 6
-- - If imageType is VK_IMAGE_TYPE_3D,
-- extent.width, extent.height and
-- extent.depth must be less than or equal to
-- VkPhysicalDeviceLimits::maxImageDimension3D, or
-- VkImageFormatProperties::maxExtent.width/height/depth
-- (as returned by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure) - whichever is
-- higher
-- - If imageType is VK_IMAGE_TYPE_1D, both
-- extent.height and extent.depth must be
-- 1
-- - If imageType is VK_IMAGE_TYPE_2D,
-- extent.depth must be 1
-- - mipLevels must be less than or equal to
-- ⌊log2(max(extent.width, extent.height,
-- extent.depth))⌋ + 1.
-- - mipLevels must be less than or equal to
-- VkImageFormatProperties::maxMipLevels (as returned
-- by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure)
-- - arrayLayers must be less than or equal to
-- VkImageFormatProperties::maxArrayLayers (as returned
-- by vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure)
-- - If imageType is VK_IMAGE_TYPE_3D,
-- arrayLayers must be 1.
-- - If samples is not VK_SAMPLE_COUNT_1_BIT,
-- imageType must be VK_IMAGE_TYPE_2D,
-- flags must not contain
-- VK_IMAGE_CREATE_CUBE_COMPATIBLE_BIT, tiling
-- must be VK_IMAGE_TILING_OPTIMAL, and
-- mipLevels must be equal to 1
-- - If usage includes
-- VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT, then bits other than
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, and
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT must not be
-- set
-- - If usage includes
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT, or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, extent.width
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxFramebufferWidth
-- - If usage includes
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT, or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT, extent.height
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxFramebufferHeight
-- - If usage includes
-- VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT, usage
-- must also contain at least one of
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT, or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT.
-- - samples must be a bit value that is set in
-- VkImageFormatProperties::sampleCounts returned by
-- vkGetPhysicalDeviceImageFormatProperties with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure
-- - If the multisampled storage images feature is not enabled,
-- and usage contains VK_IMAGE_USAGE_STORAGE_BIT,
-- samples must be VK_SAMPLE_COUNT_1_BIT
-- - If the sparse bindings feature is not enabled,
-- flags must not contain
-- VK_IMAGE_CREATE_SPARSE_BINDING_BIT
-- - If the sparse aliased residency feature is not enabled,
-- flags must not contain
-- VK_IMAGE_CREATE_SPARSE_ALIASED_BIT
-- - If imageType is VK_IMAGE_TYPE_1D, flags
-- must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for 2D images feature is not
-- enabled, and imageType is VK_IMAGE_TYPE_2D,
-- flags must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for 3D images feature is not
-- enabled, and imageType is VK_IMAGE_TYPE_3D,
-- flags must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for images with 2 samples feature
-- is not enabled, imageType is VK_IMAGE_TYPE_2D, and
-- samples is VK_SAMPLE_COUNT_2_BIT, flags
-- must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for images with 4 samples feature
-- is not enabled, imageType is VK_IMAGE_TYPE_2D, and
-- samples is VK_SAMPLE_COUNT_4_BIT, flags
-- must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for images with 8 samples feature
-- is not enabled, imageType is VK_IMAGE_TYPE_2D, and
-- samples is VK_SAMPLE_COUNT_8_BIT, flags
-- must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If the sparse residency for images with 16 samples feature
-- is not enabled, imageType is VK_IMAGE_TYPE_2D, and
-- samples is VK_SAMPLE_COUNT_16_BIT, flags
-- must not contain
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT
-- - If tiling is VK_IMAGE_TILING_LINEAR,
-- format must be a format that has at least one
-- supported feature bit present in the value of
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If tiling is VK_IMAGE_TILING_LINEAR, and
-- VkFormatProperties::linearTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT, usage
-- must not contain VK_IMAGE_USAGE_SAMPLED_BIT
-- - If tiling is VK_IMAGE_TILING_LINEAR, and
-- VkFormatProperties::linearTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT, usage
-- must not contain VK_IMAGE_USAGE_STORAGE_BIT
-- - If tiling is VK_IMAGE_TILING_LINEAR, and
-- VkFormatProperties::linearTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT, usage
-- must not contain
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT
-- - If tiling is VK_IMAGE_TILING_LINEAR, and
-- VkFormatProperties::linearTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT,
-- usage must not contain
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT
-- - If tiling is VK_IMAGE_TILING_OPTIMAL,
-- format must be a format that has at least one
-- supported feature bit present in the value of
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties with the same value of
-- format
-- - If tiling is VK_IMAGE_TILING_OPTIMAL, and
-- VkFormatProperties::optimalTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT, usage
-- must not contain VK_IMAGE_USAGE_SAMPLED_BIT
-- - If tiling is VK_IMAGE_TILING_OPTIMAL, and
-- VkFormatProperties::optimalTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_STORAGE_IMAGE_BIT, usage
-- must not contain VK_IMAGE_USAGE_STORAGE_BIT
-- - If tiling is VK_IMAGE_TILING_OPTIMAL, and
-- VkFormatProperties::optimalTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT, usage
-- must not contain
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT
-- - If tiling is VK_IMAGE_TILING_OPTIMAL, and
-- VkFormatProperties::optimalTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_DEPTH_STENCIL_ATTACHMENT_BIT,
-- usage must not contain
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT
-- - If flags contains
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT or
-- VK_IMAGE_CREATE_SPARSE_ALIASED_BIT, it must also
-- contain VK_IMAGE_CREATE_SPARSE_BINDING_BIT
-- - If any of the bits VK_IMAGE_CREATE_SPARSE_BINDING_BIT,
-- VK_IMAGE_CREATE_SPARSE_RESIDENCY_BIT, or
-- VK_IMAGE_CREATE_SPARSE_ALIASED_BIT are set,
-- VK_IMAGE_USAGE_TRANSIENT_ATTACHMENT_BIT must not also
-- be set
-- - If the pNext chain contains an instance of
-- VkExternalMemoryImageCreateInfoNV, it must not contain
-- an instance of VkExternalMemoryImageCreateInfo.
-- - If the pNext chain contains an instance of
-- VkExternalMemoryImageCreateInfo, its handleTypes
-- member must only contain bits that are also in
-- VkExternalImageFormatProperties::externalMemoryProperties::compatibleHandleTypes,
-- as returned by vkGetPhysicalDeviceImageFormatProperties2 with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure, and with an
-- instance of VkPhysicalDeviceExternalImageFormatInfo in the
-- pNext chain, with a handleType equal to any one of
-- the handle types specified in
-- VkExternalMemoryImageCreateInfo::handleTypes
-- - If the pNext chain contains an instance of
-- VkExternalMemoryImageCreateInfoNV, its handleTypes
-- member must only contain bits that are also in
-- VkExternalImageFormatPropertiesNV::externalMemoryProperties::compatibleHandleTypes,
-- as returned by
-- vkGetPhysicalDeviceExternalImageFormatPropertiesNV with
-- format, imageType, tiling, usage,
-- and flags equal to those in this structure, and with
-- externalHandleType equal to any one of the handle types
-- specified in
-- VkExternalMemoryImageCreateInfoNV::handleTypes
-- - If the logical device was created with
-- VkDeviceGroupDeviceCreateInfo::physicalDeviceCount
-- equal to 1, flags must not contain
-- VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT
-- - If flags contains
-- VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT, then
-- mipLevels must be one, arrayLayers
-- must be one, imageType must be
-- VK_IMAGE_TYPE_2D, and tiling must be
-- VK_IMAGE_TILING_OPTIMAL
-- - If flags contains
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT, then
-- format must be a block-compressed image format,
-- an ETC compressed image format, or an ASTC compressed image
-- format.
-- - If flags contains
-- VK_IMAGE_CREATE_BLOCK_TEXEL_VIEW_COMPATIBLE_BIT, then
-- flags must also contain
-- VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT.
-- - initialLayout must be
-- VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED.
-- - If the pNext chain includes a
-- VkExternalMemoryImageCreateInfo or
-- VkExternalMemoryImageCreateInfoNV structure whose
-- handleTypes member is not 0, initialLayout
-- must be VK_IMAGE_LAYOUT_UNDEFINED
-- - If the image format is one of those listed in
-- {html_spec_relative}#features-formats-requiring-sampler-ycbcr-conversion:
- mipLevels
-- must be 1
- samples must be
-- VK_SAMPLE_COUNT_1_BIT
- imageType must
-- be VK_IMAGE_TYPE_2D
- arrayLayers must
-- be 1
-- - If tiling is VK_IMAGE_TILING_OPTIMAL,
-- format is a multi-planar format, and
-- VkFormatProperties::optimalTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_DISJOINT_BIT, flags must
-- not contain VK_IMAGE_CREATE_DISJOINT_BIT
-- - If tiling is VK_IMAGE_TILING_LINEAR,
-- format is a multi-planar format, and
-- VkFormatProperties::linearTilingFeatures (as
-- returned by vkGetPhysicalDeviceFormatProperties with the same
-- value of format) does not include
-- VK_FORMAT_FEATURE_DISJOINT_BIT, flags must
-- not contain VK_IMAGE_CREATE_DISJOINT_BIT
-- - If format is not a multi-planar format, and
-- flags does not include VK_IMAGE_CREATE_ALIAS_BIT,
-- flags must not contain
-- VK_IMAGE_CREATE_DISJOINT_BIT
-- - If flags contains
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- format must be a depth or depth/stencil format
-- - If the pNext chain includes a
-- VkExternalMemoryImageCreateInfo structure whose
-- handleTypes member includes
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID:
- imageType
-- must be VK_IMAGE_TYPE_2D
- mipLevels
-- must either be 1 or equal to
-- ⌊log2(max(extent.width, extent.height,
-- extent.depth))⌋ + 1.
- If format is not
-- VK_FORMAT_UNDEFINED, then format,
-- imageType, tiling, usage, flags,
-- mipLevels, and samples must be supported with
-- VK_EXTERNAL_MEMORY_HANDLE_TYPE_ANDROID_HARDWARE_BUFFER_BIT_ANDROID
-- external memory handle types according to
-- vkGetPhysicalDeviceImageFormatProperties2
- If
-- format is VK_FORMAT_UNDEFINED, then the
-- pNext chain must include a
-- VkExternalFormatANDROID structure whose externalFormat
-- member is not 0
-- - If the pNext chain includes a
-- VkExternalFormatANDROID structure whose externalFormat
-- member is not 0:
- format must be
-- VK_FORMAT_UNDEFINED
- flags must not
-- include VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT
- usage
-- must not include any usages except
-- VK_IMAGE_USAGE_SAMPLED_BIT
- tiling
-- must be VK_IMAGE_TILING_OPTIMAL
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkExtent3D, VkFormat, VkImageCreateFlags,
-- VkImageLayout, VkImageTiling, VkImageType,
-- VkImageUsageFlags, VkSampleCountFlagBits,
-- VkSharingMode, VkStructureType, vkCreateImage
data VkImageCreateInfo
VkImageCreateInfo :: VkStructureType -> Ptr () -> VkImageCreateFlags -> VkImageType -> VkFormat -> VkExtent3D -> Word32 -> Word32 -> VkSampleCountFlagBits -> VkImageTiling -> VkImageUsageFlags -> VkSharingMode -> Word32 -> Ptr Word32 -> VkImageLayout -> VkImageCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkImageCreateInfo] :: VkImageCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageCreateInfo] :: VkImageCreateInfo -> Ptr ()
-- | flags is a bitmask of VkImageCreateFlagBits describing
-- additional parameters of the image.
[$sel:vkFlags:VkImageCreateInfo] :: VkImageCreateInfo -> VkImageCreateFlags
-- | imageType is a VkImageType value specifying the basic
-- dimensionality of the image. Layers in array textures do not count as
-- a dimension for the purposes of the image type.
[$sel:vkImageType:VkImageCreateInfo] :: VkImageCreateInfo -> VkImageType
-- | format is a VkFormat describing the format and type of
-- the data elements that will be contained in the image.
[$sel:vkFormat:VkImageCreateInfo] :: VkImageCreateInfo -> VkFormat
-- | extent is a VkExtent3D describing the number of data
-- elements in each dimension of the base level.
[$sel:vkExtent:VkImageCreateInfo] :: VkImageCreateInfo -> VkExtent3D
-- | mipLevels describes the number of levels of detail available
-- for minified sampling of the image.
[$sel:vkMipLevels:VkImageCreateInfo] :: VkImageCreateInfo -> Word32
-- | arrayLayers is the number of layers in the image.
[$sel:vkArrayLayers:VkImageCreateInfo] :: VkImageCreateInfo -> Word32
-- | samples is the number of sub-data element samples in the
-- image as defined in VkSampleCountFlagBits. See
-- Multisampling.
[$sel:vkSamples:VkImageCreateInfo] :: VkImageCreateInfo -> VkSampleCountFlagBits
-- | tiling is a VkImageTiling value specifying the tiling
-- arrangement of the data elements in memory.
[$sel:vkTiling:VkImageCreateInfo] :: VkImageCreateInfo -> VkImageTiling
-- | usage is a bitmask of VkImageUsageFlagBits describing
-- the intended usage of the image.
[$sel:vkUsage:VkImageCreateInfo] :: VkImageCreateInfo -> VkImageUsageFlags
-- | sharingMode is a VkSharingMode value specifying the
-- sharing mode of the image when it will be accessed by multiple queue
-- families.
[$sel:vkSharingMode:VkImageCreateInfo] :: VkImageCreateInfo -> VkSharingMode
-- | queueFamilyIndexCount is the number of entries in the
-- pQueueFamilyIndices array.
[$sel:vkQueueFamilyIndexCount:VkImageCreateInfo] :: VkImageCreateInfo -> Word32
-- | pQueueFamilyIndices is a list of queue families that will
-- access this image (ignored if sharingMode is not
-- VK_SHARING_MODE_CONCURRENT).
[$sel:vkPQueueFamilyIndices:VkImageCreateInfo] :: VkImageCreateInfo -> Ptr Word32
-- | initialLayout is a VkImageLayout value specifying the
-- initial VkImageLayout of all image subresources of the image.
-- See Image Layouts.
[$sel:vkInitialLayout:VkImageCreateInfo] :: VkImageCreateInfo -> VkImageLayout
-- | VkSubresourceLayout - Structure specifying subresource layout
--
-- Description
--
-- For images created with linear tiling, rowPitch,
-- arrayPitch and depthPitch describe the layout of the
-- image subresource in linear memory. For uncompressed formats,
-- rowPitch is the number of bytes between texels with the same
-- x coordinate in adjacent rows (y coordinates differ by one).
-- arrayPitch is the number of bytes between texels with the
-- same x and y coordinate in adjacent array layers of the image (array
-- layer values differ by one). depthPitch is the number of
-- bytes between texels with the same x and y coordinate in adjacent
-- slices of a 3D image (z coordinates differ by one). Expressed as an
-- addressing formula, the starting byte of a texel in the image
-- subresource has address:
--
--
-- // (x,y,z,layer) are in texel coordinates
-- address(x,y,z,layer) = layer*arrayPitch + z*depthPitch + y*rowPitch + x*elementSize + offset
--
--
-- For compressed formats, the rowPitch is the number of bytes
-- between compressed texel blocks in adjacent rows. arrayPitch
-- is the number of bytes between compressed texel blocks in adjacent
-- array layers. depthPitch is the number of bytes between
-- compressed texel blocks in adjacent slices of a 3D image.
--
--
-- // (x,y,z,layer) are in compressed texel block coordinates
-- address(x,y,z,layer) = layer*arrayPitch + z*depthPitch + y*rowPitch + x*compressedTexelBlockByteSize + offset;
--
--
-- arrayPitch is undefined for images that were not created as
-- arrays. depthPitch is defined only for 3D images.
--
-- For single-plane color formats, the aspectMask member
-- of VkImageSubresource must be
-- VK_IMAGE_ASPECT_COLOR_BIT. For depth/stencil formats,
-- aspectMask must be either
-- VK_IMAGE_ASPECT_DEPTH_BIT or
-- VK_IMAGE_ASPECT_STENCIL_BIT. On implementations that store
-- depth and stencil aspects separately, querying each of these image
-- subresource layouts will return a different offset and
-- size representing the region of memory used for that aspect.
-- On implementations that store depth and stencil aspects interleaved,
-- the same offset and size are returned and represent
-- the interleaved memory allocation.
--
-- For multi-planar formats, the aspectMask member of
-- VkImageSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or (for 3-plane formats only)
-- VK_IMAGE_ASPECT_PLANE_2_BIT. Querying each of these image
-- subresource layouts will return a different offset and
-- size representing the region of memory used for that plane.
--
-- See Also
--
-- VkDeviceSize, vkGetImageSubresourceLayout
data VkSubresourceLayout
VkSubresourceLayout :: VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkSubresourceLayout
-- | offset is the byte offset from the start of the image where
-- the image subresource begins.
[$sel:vkOffset:VkSubresourceLayout] :: VkSubresourceLayout -> VkDeviceSize
-- | size is the size in bytes of the image subresource.
-- size includes any extra memory that is required based on
-- rowPitch.
[$sel:vkSize:VkSubresourceLayout] :: VkSubresourceLayout -> VkDeviceSize
-- | rowPitch describes the number of bytes between each row of
-- texels in an image.
[$sel:vkRowPitch:VkSubresourceLayout] :: VkSubresourceLayout -> VkDeviceSize
-- | arrayPitch describes the number of bytes between each array
-- layer of an image.
[$sel:vkArrayPitch:VkSubresourceLayout] :: VkSubresourceLayout -> VkDeviceSize
-- | depthPitch describes the number of bytes between each slice
-- of 3D image.
[$sel:vkDepthPitch:VkSubresourceLayout] :: VkSubresourceLayout -> VkDeviceSize
instance GHC.Show.Show Graphics.Vulkan.Core10.Image.VkSubresourceLayout
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Image.VkSubresourceLayout
instance GHC.Show.Show Graphics.Vulkan.Core10.Image.VkImageCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Image.VkImageCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Image.VkImageLayout
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Image.VkImageLayout
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Image.VkImageLayout
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Image.VkSubresourceLayout
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Image.VkImageCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Image.VkImageLayout
instance GHC.Read.Read Graphics.Vulkan.Core10.Image.VkImageLayout
module Graphics.Vulkan.Extensions.VK_KHR_swapchain
-- | VkSwapchainCreateFlagBitsKHR - Bitmask controlling swapchain creation
--
-- See Also
--
-- VkSwapchainCreateFlagsKHR
newtype VkSwapchainCreateFlagBitsKHR
VkSwapchainCreateFlagBitsKHR :: VkFlags -> VkSwapchainCreateFlagBitsKHR
-- | VkDeviceGroupPresentModeFlagBitsKHR - Bitmask specifying supported
-- device group present modes
--
-- See Also
--
-- VkDeviceGroupPresentInfoKHR,
-- VkDeviceGroupPresentModeFlagsKHR
newtype VkDeviceGroupPresentModeFlagBitsKHR
VkDeviceGroupPresentModeFlagBitsKHR :: VkFlags -> VkDeviceGroupPresentModeFlagBitsKHR
-- | VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR specifies that any
-- physical device with a presentation engine can present its own
-- swapchain images.
-- | VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR specifies that
-- any physical device with a presentation engine can present
-- swapchain images from any physical device in its presentMask.
-- | VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR specifies that any
-- physical device with a presentation engine can present the sum
-- of swapchain images from any physical devices in its
-- presentMask.
-- | VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR
-- specifies that multiple physical devices with a presentation engine
-- can each present their own swapchain images.
-- | VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR
-- specifies that images created from the swapchain (i.e. with the
-- swapchain member of VkImageSwapchainCreateInfoKHR set
-- to this swapchain’s handle) must use
-- VK_IMAGE_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT.
-- | VkSwapchainKHR - Opaque handle to a swapchain object
--
-- Description
--
-- A swapchain is an abstraction for an array of presentable images that
-- are associated with a surface. The presentable images are represented
-- by VkImage objects created by the platform. One image (which
-- can be an array image for multiview/stereoscopic-3D surfaces)
-- is displayed at a time, but multiple images can be queued for
-- presentation. An application renders to the image, and then queues the
-- image for presentation to the surface.
--
-- A native window cannot be associated with more than one
-- swapchain at a time. Further, swapchains cannot be created for
-- native windows that have a non-Vulkan graphics API surface associated
-- with them.
--
-- Note
--
-- The presentation engine is an abstraction for the platform’s
-- compositor or display engine.
--
-- The presentation engine may be synchronous or asynchronous with
-- respect to the application and/or logical device.
--
-- Some implementations may use the device’s graphics queue or
-- dedicated presentation hardware to perform presentation.
--
-- The presentable images of a swapchain are owned by the presentation
-- engine. An application can acquire use of a presentable image
-- from the presentation engine. Use of a presentable image must
-- occur only after the image is returned by
-- vkAcquireNextImageKHR, and before it is presented by
-- vkQueuePresentKHR. This includes transitioning the image
-- layout and rendering commands.
--
-- An application can acquire use of a presentable image with
-- vkAcquireNextImageKHR. After acquiring a presentable image
-- and before modifying it, the application must use a
-- synchronization primitive to ensure that the presentation engine has
-- finished reading from the image. The application can then
-- transition the image’s layout, queue rendering commands to it, etc.
-- Finally, the application presents the image with
-- vkQueuePresentKHR, which releases the acquisition of the
-- image.
--
-- The presentation engine controls the order in which presentable images
-- are acquired for use by the application.
--
-- Note
--
-- This allows the platform to handle situations which require
-- out-of-order return of images after presentation. At the same time, it
-- allows the application to generate command buffers referencing all of
-- the images in the swapchain at initialization time, rather than in its
-- main loop.
--
-- See Also
--
-- VkAcquireNextImageInfoKHR,
-- VkBindImageMemorySwapchainInfoKHR,
-- VkImageSwapchainCreateInfoKHR, VkPresentInfoKHR,
-- VkSwapchainCreateInfoKHR, vkAcquireNextImageKHR,
-- vkCreateSharedSwapchainsKHR, vkCreateSwapchainKHR,
-- vkDestroySwapchainKHR,
-- vkGetPastPresentationTimingGOOGLE,
-- vkGetRefreshCycleDurationGOOGLE,
-- vkGetSwapchainCounterEXT, vkGetSwapchainImagesKHR,
-- vkGetSwapchainStatusKHR, vkSetHdrMetadataEXT
type VkSwapchainKHR = Ptr VkSwapchainKHR_T
-- | vkCreateSwapchainKHR - Create a swapchain
--
-- Parameters
--
--
-- - device is the device to create the swapchain for.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkSwapchainCreateInfoKHR structure specifying the parameters of
-- the created swapchain.
-- - pAllocator is the allocator used for host memory
-- allocated for the swapchain object when there is no more specific
-- allocator available (see Memory Allocation).
-- - pSwapchain is a pointer to a VkSwapchainKHR
-- handle in which the created swapchain object will be returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkSwapchainCreateInfoKHR structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSwapchain must be a valid pointer to a
-- VkSwapchainKHR handle
--
--
-- Host Synchronization
--
--
-- - Host access to pCreateInfo.surface must be
-- externally synchronized
--
--
--
-- - Host access to pCreateInfo.oldSwapchain must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- 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
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkSwapchainCreateInfoKHR, VkSwapchainKHR
vkCreateSwapchainKHR :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkSwapchainCreateInfoKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSwapchain" ::: Ptr VkSwapchainKHR) -> IO VkResult
-- | vkDestroySwapchainKHR - Destroy a swapchain object
--
-- Parameters
--
--
-- - device is the VkDevice associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain to destroy.
-- - pAllocator is the allocator used for host memory
-- allocated for the swapchain object when there is no more specific
-- allocator available (see Memory Allocation).
--
--
-- Description
--
-- The application must not destroy a swapchain until after
-- completion of all outstanding operations on images that were acquired
-- from the swapchain. swapchain and all associated
-- VkImage handles are destroyed, and must not be
-- acquired or used any more by the application. The memory of each
-- VkImage will only be freed after that image is no longer used
-- by the presentation engine. For example, if one image of the swapchain
-- is being displayed in a window, the memory for that image may
-- not be freed until the window is destroyed, or another swapchain is
-- created for the window. Destroying the swapchain does not invalidate
-- the parent VkSurfaceKHR, and a new swapchain can be
-- created with it.
--
-- When a swapchain associated with a display surface is destroyed, if
-- the image most recently presented to the display surface is from the
-- swapchain being destroyed, then either any display resources modified
-- by presenting images from any swapchain associated with the display
-- surface must be reverted by the implementation to their state
-- prior to the first present performed on one of these swapchains, or
-- such resources must be left in their current state.
--
-- Valid Usage
--
--
-- - All uses of presentable images acquired from swapchain
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- swapchain was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- swapchain was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If swapchain is not VK_NULL_HANDLE,
-- swapchain must be a valid VkSwapchainKHR
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - Both of device, and swapchain that are valid
-- handles must have been created, allocated, or retrieved from
-- the same VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkSwapchainKHR
vkDestroySwapchainKHR :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetSwapchainImagesKHR - Obtain the array of presentable images
-- associated with a swapchain
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain to query.
-- - pSwapchainImageCount is a pointer to an integer related
-- to the number of presentable images available or queried, as described
-- below.
-- - pSwapchainImages is either NULL or a pointer to
-- an array of VkImage handles.
--
--
-- Description
--
-- If pSwapchainImages is NULL, then the number of
-- presentable images for swapchain is returned in
-- pSwapchainImageCount. Otherwise,
-- pSwapchainImageCount must point to a variable set by
-- the user to the number of elements in the pSwapchainImages
-- array, and on return the variable is overwritten with the number of
-- structures actually written to pSwapchainImages. If the value
-- of pSwapchainImageCount is less than the number of
-- presentable images for swapchain, at most
-- pSwapchainImageCount structures will be written. If
-- pSwapchainImageCount is smaller than the number of
-- presentable images for swapchain, VK_INCOMPLETE will
-- be returned instead of VK_SUCCESS to indicate that not all
-- the available values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - pSwapchainImageCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pSwapchainImageCount is not
-- 0, and pSwapchainImages is not NULL,
-- pSwapchainImages must be a valid pointer to an array
-- of pSwapchainImageCount VkImage handles
-- - Both of device, and swapchain must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkImage, VkSwapchainKHR
vkGetSwapchainImagesKHR :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("pSwapchainImageCount" ::: Ptr Word32) -> ("pSwapchainImages" ::: Ptr VkImage) -> IO VkResult
-- | vkAcquireNextImageKHR - Retrieve the index of the next available
-- presentable image
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - swapchain is the non-retired swapchain from which an
-- image is being acquired.
-- - timeout specifies how long the function waits, in
-- nanoseconds, if no image is available.
-- - semaphore is VK_NULL_HANDLE or a semaphore to
-- signal.
-- - fence is VK_NULL_HANDLE or a fence to signal.
-- - pImageIndex is a pointer to a uint32_t that is
-- set to the index of the next image to use (i.e. an index into the
-- array of images returned by vkGetSwapchainImagesKHR).
--
--
-- Description
--
-- Valid Usage
--
--
-- - swapchain must not be in the retired state
--
--
--
-- - If semaphore is not VK_NULL_HANDLE it must
-- be unsignaled
-- - If semaphore is not VK_NULL_HANDLE it must
-- not have any uncompleted signal or wait operations pending
-- - If fence is not VK_NULL_HANDLE it must be
-- unsignaled and must not be associated with any other queue
-- command that has not yet completed execution on that queue
-- - semaphore and fence must not both be
-- equal to VK_NULL_HANDLE
-- - If the number of currently acquired images is greater than the
-- difference between the number of images in swapchain and the
-- value of VkSurfaceCapabilitiesKHR::minImageCount as
-- returned by a call to
-- vkGetPhysicalDeviceSurfaceCapabilities2KHR with the
-- surface used to create swapchain, timeout
-- must not be UINT64_MAX
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - If semaphore is not VK_NULL_HANDLE,
-- semaphore must be a valid VkSemaphore
-- handle
-- - If fence is not VK_NULL_HANDLE, fence
-- must be a valid VkFence handle
-- - pImageIndex must be a valid pointer to a
-- uint32_t value
-- - If semaphore is a valid handle, it must have been
-- created, allocated, or retrieved from device
-- - If fence is a valid handle, it must have been
-- created, allocated, or retrieved from device
-- - Both of device, and swapchain that are valid
-- handles must have been created, allocated, or retrieved from
-- the same VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
--
-- - Host access to semaphore must be externally
-- synchronized
-- - Host access to fence must be externally
-- synchronized
--
--
-- Return Codes
--
--
-- - Success -
-- VK_SUCCESS
VK_TIMEOUT
VK_NOT_READY
VK_SUBOPTIMAL_KHR
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkFence, VkSemaphore,
-- VkSwapchainKHR
vkAcquireNextImageKHR :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("timeout" ::: Word64) -> ("semaphore" ::: VkSemaphore) -> ("fence" ::: VkFence) -> ("pImageIndex" ::: Ptr Word32) -> IO VkResult
-- | vkQueuePresentKHR - Queue an image for presentation
--
-- Parameters
--
--
-- - queue is a queue that is capable of presentation to the
-- target surface’s platform on the same device as the image’s
-- swapchain.
--
--
--
-- - pPresentInfo is a pointer to an instance of the
-- VkPresentInfoKHR structure specifying the parameters of the
-- presentation.
--
--
-- Description
--
-- Note
--
-- There is no requirement for an application to present images in the
-- same order that they were acquired - applications can arbitrarily
-- present any image that is currently acquired.
--
-- Valid Usage
--
--
-- - Each element of pSwapchains member of
-- pPresentInfo must be a swapchain that is created for a
-- surface for which presentation is supported from queue as
-- determined using a call to
-- vkGetPhysicalDeviceSurfaceSupportKHR
--
--
--
-- - If more than one member of pSwapchains was created from a
-- display surface, all display surfaces referenced that refer to the
-- same display must use the same display mode
-- - When a semaphore unsignal operation defined by the elements of the
-- pWaitSemaphores member of pPresentInfo executes on
-- queue, no other queue must be waiting on the same
-- semaphore.
-- - All elements of the pWaitSemaphores member of
-- pPresentInfo must be semaphores that are signaled, or
-- have semaphore signal operations previously submitted for
-- execution.
--
--
-- Any writes to memory backing the images referenced by the
-- pImageIndices and pSwapchains members of
-- pPresentInfo, that are available before
-- vkQueuePresentKHR is executed, are automatically made visible
-- to the read access performed by the presentation engine. This
-- automatic visibility operation for an image happens-after the
-- semaphore signal operation, and happens-before the presentation engine
-- accesses the image.
--
-- Queueing an image for presentation defines a set of queue
-- operations, including waiting on the semaphores and submitting a
-- presentation request to the presentation engine. However, the scope of
-- this set of queue operations does not include the actual processing of
-- the image by the presentation engine.
--
-- If vkQueuePresentKHR fails to enqueue the corresponding set
-- of queue operations, it may return
-- VK_ERROR_OUT_OF_HOST_MEMORY or
-- VK_ERROR_OUT_OF_DEVICE_MEMORY. If it does, the implementation
-- must ensure that the state and contents of any resources or
-- synchronization primitives referenced is unaffected by the call or its
-- failure.
--
-- If vkQueuePresentKHR fails in such a way that the
-- implementation is unable to make that guarantee, the implementation
-- must return VK_ERROR_DEVICE_LOST.
--
-- However, if the presentation request is rejected by the presentation
-- engine with an error VK_ERROR_OUT_OF_DATE_KHR or
-- VK_ERROR_SURFACE_LOST_KHR, the set of queue operations are
-- still considered to be enqueued and thus any semaphore to be waited on
-- gets unsignaled when the corresponding queue operation is complete.
--
-- Valid Usage (Implicit)
--
--
-- - queue must be a valid VkQueue handle
--
--
--
-- - pPresentInfo must be a valid pointer to a valid
-- VkPresentInfoKHR structure
--
--
-- Host Synchronization
--
--
-- - Host access to queue must be externally
-- synchronized
--
--
--
-- - Host access to pPresentInfo.pWaitSemaphores[] must
-- be externally synchronized
-- - Host access to pPresentInfo.pSwapchains[] must be
-- externally synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | - | - | Any | - |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPresentInfoKHR, VkQueue
vkQueuePresentKHR :: ("queue" ::: VkQueue) -> ("pPresentInfo" ::: Ptr VkPresentInfoKHR) -> IO VkResult
-- | vkGetDeviceGroupPresentCapabilitiesKHR - Query present capabilities
-- from other physical devices
--
-- Parameters
--
--
-- - device is the logical device.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pDeviceGroupPresentCapabilities must be a valid
-- pointer to a VkDeviceGroupPresentCapabilitiesKHR
-- structure
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkDeviceGroupPresentCapabilitiesKHR
vkGetDeviceGroupPresentCapabilitiesKHR :: ("device" ::: VkDevice) -> ("pDeviceGroupPresentCapabilities" ::: Ptr VkDeviceGroupPresentCapabilitiesKHR) -> IO VkResult
-- | vkGetDeviceGroupSurfacePresentModesKHR - Query present capabilities
-- for a surface
--
-- Parameters
--
--
-- - device is the logical device.
--
--
--
-- - surface is the surface.
-- - pModes is a pointer to a value of type
-- VkDeviceGroupPresentModeFlagsKHR that is filled with the
-- supported device group present modes for the surface.
--
--
-- Description
--
-- The modes returned by this command are not invariant, and may
-- change in response to the surface being moved, resized, or occluded.
-- These modes must be a subset of the modes returned by
-- vkGetDeviceGroupPresentCapabilitiesKHR.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pModes must be a valid pointer to a
-- VkDeviceGroupPresentModeFlagsKHR value
-- - Both of device, and surface must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to surface must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkDeviceGroupPresentModeFlagsKHR,
-- VkSurfaceKHR
vkGetDeviceGroupSurfacePresentModesKHR :: ("device" ::: VkDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pModes" ::: Ptr VkDeviceGroupPresentModeFlagsKHR) -> IO VkResult
-- | vkAcquireNextImage2KHR - Retrieve the index of the next available
-- presentable image
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - pAcquireInfo is a pointer to a structure of type
-- VkAcquireNextImageInfoKHR containing parameters of the
-- acquire.
-- - pImageIndex is a pointer to a uint32_t that is
-- set to the index of the next image to use.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If the number of currently acquired images is greater than the
-- difference between the number of images in the swapchain
-- member of pAcquireInfo and the value of
-- VkSurfaceCapabilitiesKHR::minImageCount as returned by
-- a call to vkGetPhysicalDeviceSurfaceCapabilities2KHR with the
-- surface used to create swapchain, the
-- timeout member of pAcquireInfo must not be
-- UINT64_MAX
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pAcquireInfo must be a valid pointer to a valid
-- VkAcquireNextImageInfoKHR structure
-- - pImageIndex must be a valid pointer to a
-- uint32_t value
--
--
-- Return Codes
--
--
-- - Success -
-- VK_SUCCESS
VK_TIMEOUT
VK_NOT_READY
VK_SUBOPTIMAL_KHR
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAcquireNextImageInfoKHR, VkDevice
vkAcquireNextImage2KHR :: ("device" ::: VkDevice) -> ("pAcquireInfo" ::: Ptr VkAcquireNextImageInfoKHR) -> ("pImageIndex" ::: Ptr Word32) -> IO VkResult
-- | vkGetPhysicalDevicePresentRectanglesKHR - Query present rectangles for
-- a surface on a physical device
--
-- Parameters
--
--
-- - physicalDevice is the physical device.
--
--
--
-- - surface is the surface.
-- - pRectCount is a pointer to an integer related to the
-- number of rectangles available or queried, as described below.
-- - pRects is either NULL or a pointer to an array
-- of VkRect2D structures.
--
--
-- Description
--
-- If pRects is NULL, then the number of rectangles
-- used when presenting the given surface is returned in
-- pRectCount. Otherwise, pRectCount must point
-- to a variable set by the user to the number of elements in the
-- pRects array, and on return the variable is overwritten with
-- the number of structures actually written to pRects. If the
-- value of pRectCount is less than the number of rectangles, at
-- most pRectCount structures will be written. If
-- pRectCount is smaller than the number of rectangles used for
-- the given surface, VK_INCOMPLETE will be returned
-- instead of VK_SUCCESS to indicate that not all the available
-- values were returned.
--
-- The values returned by this command are not invariant, and may
-- change in response to the surface being moved, resized, or occluded.
--
-- The rectangles returned by this command must not overlap.
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - pRectCount must be a valid pointer to a
-- uint32_t value
-- - If the value referenced by pRectCount is not 0,
-- and pRects is not NULL, pRects must
-- be a valid pointer to an array of pRectCount
-- VkRect2D structures
-- - Both of physicalDevice, and surface must
-- have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to surface must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkPhysicalDevice, VkRect2D, VkSurfaceKHR
vkGetPhysicalDevicePresentRectanglesKHR :: ("physicalDevice" ::: VkPhysicalDevice) -> ("surface" ::: VkSurfaceKHR) -> ("pRectCount" ::: Ptr Word32) -> ("pRects" ::: Ptr VkRect2D) -> IO VkResult
-- | VkSwapchainCreateInfoKHR - Structure specifying parameters of a newly
-- created swapchain object
--
-- Description
--
-- Note
--
-- On some platforms, it is normal that maxImageExtent
-- may become (0, 0), for example when the window is
-- minimized. In such a case, it is not possible to create a swapchain
-- due to the Valid Usage requirements.
--
--
-- - imageArrayLayers is the number of views in a
-- multiview/stereo surface. For non-stereoscopic-3D applications, this
-- value is 1.
-- - imageUsage is a bitmask of VkImageUsageFlagBits
-- describing the intended usage of the (acquired) swapchain images.
-- - imageSharingMode is the sharing mode used for the
-- image(s) of the swapchain.
-- - queueFamilyIndexCount is the number of queue families
-- having access to the image(s) of the swapchain when
-- imageSharingMode is VK_SHARING_MODE_CONCURRENT.
-- - pQueueFamilyIndices is an array of queue family indices
-- having access to the images(s) of the swapchain when
-- imageSharingMode is VK_SHARING_MODE_CONCURRENT.
-- - preTransform is a VkSurfaceTransformFlagBitsKHR
-- value describing the transform, relative to the presentation engine’s
-- natural orientation, applied to the image content prior to
-- presentation. If it does not match the currentTransform value
-- returned by vkGetPhysicalDeviceSurfaceCapabilitiesKHR, the
-- presentation engine will transform the image content as part of the
-- presentation operation.
-- - compositeAlpha is a VkCompositeAlphaFlagBitsKHR
-- value indicating the alpha compositing mode to use when this surface
-- is composited together with other surfaces on certain window
-- systems.
-- - presentMode is the presentation mode the swapchain will
-- use. A swapchain’s present mode determines how incoming present
-- requests will be processed and queued internally.
-- - clipped specifies whether the Vulkan implementation is
-- allowed to discard rendering operations that affect regions of the
-- surface that are not visible.
- If set to VK_TRUE, the
-- presentable images associated with the swapchain may not own
-- all of their pixels. Pixels in the presentable images that correspond
-- to regions of the target surface obscured by another window on the
-- desktop, or subject to some other clipping mechanism will have
-- undefined content when read back. Pixel shaders may not execute
-- for these pixels, and thus any side effects they would have had will
-- not occur. VK_TRUE value does not guarantee any clipping will
-- occur, but allows more optimal presentation methods to be used on some
-- platforms.
- If set to VK_FALSE, presentable images
-- associated with the swapchain will own all of the pixels they
-- contain.
--
--
-- Note
--
-- Applications should set this value to VK_TRUE if they
-- do not expect to read back the content of presentable images before
-- presenting them or after reacquiring them, and if their pixel shaders
-- do not have any side effects that require them to run for all pixels
-- in the presentable image.
--
--
-- - oldSwapchain is VK_NULL_HANDLE, or the existing
-- non-retired swapchain currently associated with surface.
-- Providing a valid oldSwapchain may aid in the resource
-- reuse, and also allows the application to still present any images
-- that are already acquired from it.
--
--
-- Upon calling vkCreateSwapchainKHR with an
-- oldSwapchain that is not VK_NULL_HANDLE,
-- oldSwapchain is retired — even if creation of the new
-- swapchain fails. The new swapchain is created in the non-retired state
-- whether or not oldSwapchain is VK_NULL_HANDLE.
--
-- Upon calling vkCreateSwapchainKHR with an
-- oldSwapchain that is not VK_NULL_HANDLE, any images
-- from oldSwapchain that are not acquired by the application
-- may be freed by the implementation, which may occur even
-- if creation of the new swapchain fails. The application can
-- destroy oldSwapchain to free all memory associated with
-- oldSwapchain.
--
-- Note
--
-- Multiple retired swapchains can be associated with the same
-- VkSurfaceKHR through multiple uses of oldSwapchain
-- that outnumber calls to vkDestroySwapchainKHR.
--
-- After oldSwapchain is retired, the application can
-- pass to vkQueuePresentKHR any images it had already acquired
-- from oldSwapchain. E.g., an application may present an image
-- from the old swapchain before an image from the new swapchain is ready
-- to be presented. As usual, vkQueuePresentKHR may fail if
-- oldSwapchain has entered a state that causes
-- VK_ERROR_OUT_OF_DATE_KHR to be returned.
--
-- The application can continue to use a shared presentable image
-- obtained from oldSwapchain until a presentable image is
-- acquired from the new swapchain, as long as it has not entered a state
-- that causes it to return VK_ERROR_OUT_OF_DATE_KHR.
--
-- Valid Usage
--
--
-- - surface must be a surface that is supported by the
-- device as determined using
-- vkGetPhysicalDeviceSurfaceSupportKHR
--
--
--
-- - minImageCount must be greater than or equal to the
-- value returned in the minImageCount member of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the
-- surface
-- - minImageCount must be less than or equal to the
-- value returned in the maxImageCount member of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the surface if
-- the returned maxImageCount is not zero
-- - minImageCount must be 1 if
-- presentMode is either
-- VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR or
-- VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR
-- - imageFormat and imageColorSpace must
-- match the format and colorSpace members,
-- respectively, of one of the VkSurfaceFormatKHR structures
-- returned by vkGetPhysicalDeviceSurfaceFormatsKHR for the
-- surface
-- - imageExtent must be between
-- minImageExtent and maxImageExtent, inclusive, where
-- minImageExtent and maxImageExtent are members of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the
-- surface
-- - imageExtent members width and height
-- must both be non-zero
-- - imageArrayLayers must be greater than 0
-- and less than or equal to the maxImageArrayLayers member of
-- the VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the
-- surface
-- - If presentMode is VK_PRESENT_MODE_IMMEDIATE_KHR,
-- VK_PRESENT_MODE_MAILBOX_KHR,
-- VK_PRESENT_MODE_FIFO_KHR or
-- VK_PRESENT_MODE_FIFO_RELAXED_KHR, imageUsage
-- must be a subset of the supported usage flags present in the
-- supportedUsageFlags member of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for
-- surface
-- - If presentMode is
-- VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR or
-- VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR,
-- imageUsage must be a subset of the supported usage
-- flags present in the sharedPresentSupportedUsageFlags member
-- of the VkSharedPresentSurfaceCapabilitiesKHR structure returned
-- by vkGetPhysicalDeviceSurfaceCapabilities2KHR for
-- surface
-- - If imageSharingMode is
-- VK_SHARING_MODE_CONCURRENT, pQueueFamilyIndices
-- must be a valid pointer to an array of
-- queueFamilyIndexCount uint32_t values
-- - If imageSharingMode is
-- VK_SHARING_MODE_CONCURRENT, queueFamilyIndexCount
-- must be greater than 1
-- - If imageSharingMode is
-- VK_SHARING_MODE_CONCURRENT, each element of
-- pQueueFamilyIndices must be unique and must be
-- less than pQueueFamilyPropertyCount returned by either
-- vkGetPhysicalDeviceQueueFamilyProperties or
-- vkGetPhysicalDeviceQueueFamilyProperties2 for the
-- physicalDevice that was used to create device
-- - preTransform must be one of the bits present in
-- the supportedTransforms member of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the
-- surface
-- - compositeAlpha must be one of the bits present in
-- the supportedCompositeAlpha member of the
-- VkSurfaceCapabilitiesKHR structure returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR for the
-- surface
-- - presentMode must be one of the
-- VkPresentModeKHR values returned by
-- vkGetPhysicalDeviceSurfacePresentModesKHR for the
-- surface
-- - If the logical device was created with
-- VkDeviceGroupDeviceCreateInfo::physicalDeviceCount
-- equal to 1, flags must not contain
-- VK_SWAPCHAIN_CREATE_SPLIT_INSTANCE_BIND_REGIONS_BIT_KHR
-- - oldSwapchain must not be in the retired state
-- - imageFormat, imageUsage, imageExtent,
-- and imageArrayLayers must be supported for
-- VK_IMAGE_TYPE_2D VK_IMAGE_TILING_OPTIMAL images as
-- reported by vkGetPhysicalDeviceImageFormatProperties.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkDeviceGroupSwapchainCreateInfoKHR or
-- VkSwapchainCounterCreateInfoEXT
-- - Each sType member in the pNext chain must
-- be unique
-- - flags must be a valid combination of
-- VkSwapchainCreateFlagBitsKHR values
-- - surface must be a valid VkSurfaceKHR
-- handle
-- - imageFormat must be a valid VkFormat
-- value
-- - imageColorSpace must be a valid
-- VkColorSpaceKHR value
-- - imageUsage must be a valid combination of
-- VkImageUsageFlagBits values
-- - imageUsage must not be 0
-- - imageSharingMode must be a valid
-- VkSharingMode value
-- - preTransform must be a valid
-- VkSurfaceTransformFlagBitsKHR value
-- - compositeAlpha must be a valid
-- VkCompositeAlphaFlagBitsKHR value
-- - presentMode must be a valid
-- VkPresentModeKHR value
-- - If oldSwapchain is not VK_NULL_HANDLE,
-- oldSwapchain must be a valid VkSwapchainKHR
-- handle
-- - If oldSwapchain is a valid handle, it must have
-- been created, allocated, or retrieved from surface
-- - Both of oldSwapchain, and surface that are valid
-- handles must have been created, allocated, or retrieved from
-- the same VkInstance
--
--
-- See Also
--
-- VkBool32, VkColorSpaceKHR,
-- VkCompositeAlphaFlagBitsKHR, VkExtent2D,
-- VkFormat, VkImageUsageFlags, VkPresentModeKHR,
-- VkSharingMode, VkStructureType, VkSurfaceKHR,
-- VkSurfaceTransformFlagBitsKHR,
-- VkSwapchainCreateFlagsKHR, VkSwapchainKHR,
-- vkCreateSharedSwapchainsKHR, vkCreateSwapchainKHR
data VkSwapchainCreateInfoKHR
VkSwapchainCreateInfoKHR :: VkStructureType -> Ptr () -> VkSwapchainCreateFlagsKHR -> VkSurfaceKHR -> Word32 -> VkFormat -> VkColorSpaceKHR -> VkExtent2D -> Word32 -> VkImageUsageFlags -> VkSharingMode -> Word32 -> Ptr Word32 -> VkSurfaceTransformFlagBitsKHR -> VkCompositeAlphaFlagBitsKHR -> VkPresentModeKHR -> VkBool32 -> VkSwapchainKHR -> VkSwapchainCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> Ptr ()
-- | flags is a bitmask of VkSwapchainCreateFlagBitsKHR
-- indicating parameters of the swapchain creation.
[$sel:vkFlags:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkSwapchainCreateFlagsKHR
-- | surface is the surface onto which the swapchain will present
-- images. If the creation succeeds, the swapchain becomes associated
-- with surface.
[$sel:vkSurface:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkSurfaceKHR
-- | minImageCount is the minimum number of presentable images
-- that the application needs. The implementation will either create the
-- swapchain with at least that many images, or it will fail to create
-- the swapchain.
[$sel:vkMinImageCount:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> Word32
-- | imageFormat is a VkFormat value specifying the format
-- the swapchain image(s) will be created with.
[$sel:vkImageFormat:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkFormat
-- | imageColorSpace is a VkColorSpaceKHR value specifying
-- the way the swapchain interprets image data.
[$sel:vkImageColorSpace:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkColorSpaceKHR
-- | imageExtent is the size (in pixels) of the swapchain
-- image(s). The behavior is platform-dependent if the image extent does
-- not match the surface’s currentExtent as returned by
-- vkGetPhysicalDeviceSurfaceCapabilitiesKHR.
[$sel:vkImageExtent:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkExtent2D
[$sel:vkImageArrayLayers:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> Word32
[$sel:vkImageUsage:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkImageUsageFlags
[$sel:vkImageSharingMode:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkSharingMode
[$sel:vkQueueFamilyIndexCount:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> Word32
[$sel:vkPQueueFamilyIndices:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> Ptr Word32
[$sel:vkPreTransform:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkSurfaceTransformFlagBitsKHR
[$sel:vkCompositeAlpha:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkCompositeAlphaFlagBitsKHR
[$sel:vkPresentMode:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkPresentModeKHR
[$sel:vkClipped:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkBool32
[$sel:vkOldSwapchain:VkSwapchainCreateInfoKHR] :: VkSwapchainCreateInfoKHR -> VkSwapchainKHR
-- | VkPresentInfoKHR - Structure describing parameters of a queue
-- presentation
--
-- Description
--
-- Before an application can present an image, the image’s layout
-- must be transitioned to the
-- VK_IMAGE_LAYOUT_PRESENT_SRC_KHR layout, or for a shared
-- presentable image the VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR
-- layout.
--
-- Note
--
-- When transitioning the image to
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR or
-- VK_IMAGE_LAYOUT_PRESENT_SRC_KHR, there is no need to delay
-- subsequent processing, or perform any visibility operations (as
-- vkQueuePresentKHR performs automatic visibility operations). To
-- achieve this, the dstAccessMask member of the
-- VkImageMemoryBarrier should be set to 0, and
-- the dstStageMask parameter should be set to
-- VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT.
--
-- Valid Usage
--
--
-- - Each element of pImageIndices must be the index of
-- a presentable image acquired from the swapchain specified by the
-- corresponding element of the pSwapchains array, and the
-- presented image subresource must be in the
-- VK_IMAGE_LAYOUT_PRESENT_SRC_KHR or
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR layout at the time the
-- operation is executed on a VkDevice
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PRESENT_INFO_KHR
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of VkDeviceGroupPresentInfoKHR,
-- VkDisplayPresentInfoKHR, VkPresentRegionsKHR, or
-- VkPresentTimesInfoGOOGLE
-- - Each sType member in the pNext chain must
-- be unique
-- - If waitSemaphoreCount is not 0,
-- pWaitSemaphores must be a valid pointer to an array of
-- waitSemaphoreCount valid VkSemaphore handles
-- - pSwapchains must be a valid pointer to an array of
-- swapchainCount valid VkSwapchainKHR handles
-- - pImageIndices must be a valid pointer to an array
-- of swapchainCount uint32_t values
-- - If pResults is not NULL, pResults
-- must be a valid pointer to an array of swapchainCount
-- VkResult values
-- - swapchainCount must be greater than
-- 0
-- - Both of the elements of pSwapchains, and the elements of
-- pWaitSemaphores that are valid handles must have been
-- created, allocated, or retrieved from the same
-- VkInstance
--
--
-- See Also
--
-- VkResult, VkSemaphore, VkStructureType,
-- VkSwapchainKHR, vkQueuePresentKHR
data VkPresentInfoKHR
VkPresentInfoKHR :: VkStructureType -> Ptr () -> Word32 -> Ptr VkSemaphore -> Word32 -> Ptr VkSwapchainKHR -> Ptr Word32 -> Ptr VkResult -> VkPresentInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkPresentInfoKHR] :: VkPresentInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPresentInfoKHR] :: VkPresentInfoKHR -> Ptr ()
-- | waitSemaphoreCount is the number of semaphores to wait for
-- before issuing the present request. The number may be zero.
[$sel:vkWaitSemaphoreCount:VkPresentInfoKHR] :: VkPresentInfoKHR -> Word32
-- | pWaitSemaphores, if not NULL, is an array of
-- VkSemaphore objects with waitSemaphoreCount entries,
-- and specifies the semaphores to wait for before issuing the present
-- request.
[$sel:vkPWaitSemaphores:VkPresentInfoKHR] :: VkPresentInfoKHR -> Ptr VkSemaphore
-- | swapchainCount is the number of swapchains being presented to
-- by this command.
[$sel:vkSwapchainCount:VkPresentInfoKHR] :: VkPresentInfoKHR -> Word32
-- | pSwapchains is an array of VkSwapchainKHR objects
-- with swapchainCount entries. A given swapchain must
-- not appear in this list more than once.
[$sel:vkPSwapchains:VkPresentInfoKHR] :: VkPresentInfoKHR -> Ptr VkSwapchainKHR
-- | pImageIndices is an array of indices into the array of each
-- swapchain’s presentable images, with swapchainCount entries.
-- Each entry in this array identifies the image to present on the
-- corresponding entry in the pSwapchains array.
[$sel:vkPImageIndices:VkPresentInfoKHR] :: VkPresentInfoKHR -> Ptr Word32
-- | pResults is an array of VkResult typed elements with
-- swapchainCount entries. Applications that do not need
-- per-swapchain results can use NULL for
-- pResults. If non-NULL, each entry in
-- pResults will be set to the VkResult for presenting
-- the swapchain corresponding to the same index in pSwapchains.
[$sel:vkPResults:VkPresentInfoKHR] :: VkPresentInfoKHR -> Ptr VkResult
-- | VkDeviceGroupPresentCapabilitiesKHR - Present capabilities from other
-- physical devices
--
-- Description
--
-- modes always has
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR set.
--
-- The present mode flags are also used when presenting an image, in
-- VkDeviceGroupPresentInfoKHR::mode.
--
-- If a device group only includes a single physical device, then
-- modes must equal
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_CAPABILITIES_KHR
--
--
--
--
-- See Also
--
-- VkDeviceGroupPresentModeFlagsKHR, VkStructureType,
-- vkGetDeviceGroupPresentCapabilitiesKHR
data VkDeviceGroupPresentCapabilitiesKHR
VkDeviceGroupPresentCapabilitiesKHR :: VkStructureType -> Ptr () -> Vector VK_MAX_DEVICE_GROUP_SIZE Word32 -> VkDeviceGroupPresentModeFlagsKHR -> VkDeviceGroupPresentCapabilitiesKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupPresentCapabilitiesKHR] :: VkDeviceGroupPresentCapabilitiesKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupPresentCapabilitiesKHR] :: VkDeviceGroupPresentCapabilitiesKHR -> Ptr ()
-- | presentMask is an array of masks, where the mask at element i
-- is non-zero if physical device i has a presentation engine, and where
-- bit j is set in element i if physical device i can present
-- swapchain images from physical device j. If element i is non-zero,
-- then bit i must be set.
[$sel:vkPresentMask:VkDeviceGroupPresentCapabilitiesKHR] :: VkDeviceGroupPresentCapabilitiesKHR -> Vector VK_MAX_DEVICE_GROUP_SIZE Word32
-- | modes is a bitmask of
-- VkDeviceGroupPresentModeFlagBitsKHR indicating which device
-- group presentation modes are supported.
[$sel:vkModes:VkDeviceGroupPresentCapabilitiesKHR] :: VkDeviceGroupPresentCapabilitiesKHR -> VkDeviceGroupPresentModeFlagsKHR
-- | VkImageSwapchainCreateInfoKHR - Specify that an image will be bound to
-- swapchain memory
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_SWAPCHAIN_CREATE_INFO_KHR
--
--
--
-- - If swapchain is not VK_NULL_HANDLE,
-- swapchain must be a valid VkSwapchainKHR
-- handle
--
--
-- See Also
--
-- VkStructureType, VkSwapchainKHR
data VkImageSwapchainCreateInfoKHR
VkImageSwapchainCreateInfoKHR :: VkStructureType -> Ptr () -> VkSwapchainKHR -> VkImageSwapchainCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkImageSwapchainCreateInfoKHR] :: VkImageSwapchainCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageSwapchainCreateInfoKHR] :: VkImageSwapchainCreateInfoKHR -> Ptr ()
-- | swapchain is VK_NULL_HANDLE or a handle of a swapchain
-- that the image will be bound to.
[$sel:vkSwapchain:VkImageSwapchainCreateInfoKHR] :: VkImageSwapchainCreateInfoKHR -> VkSwapchainKHR
-- | VkBindImageMemorySwapchainInfoKHR - Structure specifying swapchain
-- image memory to bind to
--
-- Description
--
-- If swapchain is not NULL, the swapchain and
-- imageIndex are used to determine the memory that the image is
-- bound to, instead of memory and memoryOffset.
--
-- Memory can be bound to a swapchain and use the
-- pDeviceIndices or pSplitInstanceBindRegions members
-- of VkBindImageMemoryDeviceGroupInfo.
--
-- Valid Usage
--
--
-- - imageIndex must be less than the number of images
-- in swapchain
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BIND_IMAGE_MEMORY_SWAPCHAIN_INFO_KHR
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
-- See Also
--
-- VkStructureType, VkSwapchainKHR
data VkBindImageMemorySwapchainInfoKHR
VkBindImageMemorySwapchainInfoKHR :: VkStructureType -> Ptr () -> VkSwapchainKHR -> Word32 -> VkBindImageMemorySwapchainInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkBindImageMemorySwapchainInfoKHR] :: VkBindImageMemorySwapchainInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBindImageMemorySwapchainInfoKHR] :: VkBindImageMemorySwapchainInfoKHR -> Ptr ()
-- | swapchain is VK_NULL_HANDLE or a swapchain handle.
[$sel:vkSwapchain:VkBindImageMemorySwapchainInfoKHR] :: VkBindImageMemorySwapchainInfoKHR -> VkSwapchainKHR
-- | imageIndex is an image index within swapchain.
[$sel:vkImageIndex:VkBindImageMemorySwapchainInfoKHR] :: VkBindImageMemorySwapchainInfoKHR -> Word32
-- | VkAcquireNextImageInfoKHR - Structure specifying parameters of the
-- acquire
--
-- Description
--
-- If vkAcquireNextImageKHR is used, the device mask is considered
-- to include all physical devices in the logical device.
--
-- Note
--
-- vkAcquireNextImage2KHR signals at most one semaphore, even if
-- the application requests waiting for multiple physical devices to be
-- ready via the deviceMask. However, only a single physical
-- device can wait on that semaphore, since the semaphore becomes
-- unsignaled when the wait succeeds. For other physical devices to wait
-- for the image to be ready, it is necessary for the application to
-- submit semaphore signal operation(s) to that first physical device to
-- signal additional semaphore(s) after the wait succeeds, which the
-- other physical device(s) can wait upon.
--
-- Valid Usage
--
--
-- - swapchain must not be in the retired state
--
--
--
-- - If semaphore is not VK_NULL_HANDLE it must
-- be unsignaled
-- - If semaphore is not VK_NULL_HANDLE it must
-- not have any uncompleted signal or wait operations pending
-- - If fence is not VK_NULL_HANDLE it must be
-- unsignaled and must not be associated with any other queue
-- command that has not yet completed execution on that queue
-- - semaphore and fence must not both be
-- equal to VK_NULL_HANDLE
-- - deviceMask must be a valid device mask
-- - deviceMask must not be zero
-- - semaphore and fence must not both be
-- equal to VK_NULL_HANDLE.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_ACQUIRE_NEXT_IMAGE_INFO_KHR
--
--
--
-- - pNext must be NULL
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - If semaphore is not VK_NULL_HANDLE,
-- semaphore must be a valid VkSemaphore
-- handle
-- - If fence is not VK_NULL_HANDLE, fence
-- must be a valid VkFence handle
-- - Each of fence, semaphore, and swapchain
-- that are valid handles must have been created, allocated, or
-- retrieved from the same VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
--
-- - Host access to semaphore must be externally
-- synchronized
-- - Host access to fence must be externally
-- synchronized
--
--
-- See Also
--
-- VkFence, VkSemaphore, VkStructureType,
-- VkSwapchainKHR, vkAcquireNextImage2KHR
data VkAcquireNextImageInfoKHR
VkAcquireNextImageInfoKHR :: VkStructureType -> Ptr () -> VkSwapchainKHR -> Word64 -> VkSemaphore -> VkFence -> Word32 -> VkAcquireNextImageInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> Ptr ()
-- | swapchain is a non-retired swapchain from which an image is
-- acquired.
[$sel:vkSwapchain:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> VkSwapchainKHR
-- | timeout specifies how long the function waits, in
-- nanoseconds, if no image is available.
[$sel:vkTimeout:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> Word64
-- | semaphore is VK_NULL_HANDLE or a semaphore to
-- signal.
[$sel:vkSemaphore:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> VkSemaphore
-- | fence is VK_NULL_HANDLE or a fence to signal.
[$sel:vkFence:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> VkFence
-- | deviceMask is a mask of physical devices for which the
-- swapchain image will be ready to use when the semaphore or fence is
-- signaled.
[$sel:vkDeviceMask:VkAcquireNextImageInfoKHR] :: VkAcquireNextImageInfoKHR -> Word32
-- | VkDeviceGroupPresentInfoKHR - Mode and mask controlling which physical
-- devices' images are presented
--
-- Description
--
-- If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR, then each element
-- of pDeviceMasks selects which instance of the swapchain image
-- is presented. Each element of pDeviceMasks must have
-- exactly one bit set, and the corresponding physical device must
-- have a presentation engine as reported by
-- VkDeviceGroupPresentCapabilitiesKHR.
--
-- If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR, then each
-- element of pDeviceMasks selects which instance of the
-- swapchain image is presented. Each element of pDeviceMasks
-- must have exactly one bit set, and some physical device in the
-- logical device must include that bit in its
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask.
--
-- If mode is VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR,
-- then each element of pDeviceMasks selects which instances of
-- the swapchain image are component-wise summed and the sum of those
-- images is presented. If the sum in any component is outside the
-- representable range, the value of that component is undefined. Each
-- element of pDeviceMasks must have a value for which
-- all set bits are set in one of the elements of
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask.
--
-- If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR, then
-- each element of pDeviceMasks selects which instance(s) of the
-- swapchain images are presented. For each bit set in each element of
-- pDeviceMasks, the corresponding physical device must
-- have a presentation engine as reported by
-- VkDeviceGroupPresentCapabilitiesKHR.
--
-- If VkDeviceGroupPresentInfoKHR is not provided or
-- swapchainCount is zero then the masks are considered to be
-- 1. If VkDeviceGroupPresentInfoKHR is not provided,
-- mode is considered to be
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR.
--
-- Valid Usage
--
--
--
--
-- - If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR, then each element
-- of pDeviceMasks must have exactly one bit set, and the
-- corresponding element of
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask
-- must be non-zero
-- - If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_REMOTE_BIT_KHR, then each
-- element of pDeviceMasks must have exactly one bit set,
-- and some physical device in the logical device must include
-- that bit in its
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask.
-- - If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_SUM_BIT_KHR, then each element
-- of pDeviceMasks must have a value for which all set
-- bits are set in one of the elements of
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask
-- - If mode is
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_MULTI_DEVICE_BIT_KHR, then
-- for each bit set in each element of pDeviceMasks, the
-- corresponding element of
-- VkDeviceGroupPresentCapabilitiesKHR::presentMask
-- must be non-zero
-- - The value of each element of pDeviceMasks must be
-- equal to the device mask passed in
-- VkAcquireNextImageInfoKHR::deviceMask when the image
-- index was last acquired
-- - mode must have exactly one bit set, and that bit
-- must have been included in
-- VkDeviceGroupSwapchainCreateInfoKHR::modes
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_PRESENT_INFO_KHR
--
--
--
-- - If swapchainCount is not 0,
-- pDeviceMasks must be a valid pointer to an array of
-- swapchainCount uint32_t values
-- - mode must be a valid
-- VkDeviceGroupPresentModeFlagBitsKHR value
--
--
-- See Also
--
-- VkDeviceGroupPresentModeFlagBitsKHR, VkStructureType
data VkDeviceGroupPresentInfoKHR
VkDeviceGroupPresentInfoKHR :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> VkDeviceGroupPresentModeFlagBitsKHR -> VkDeviceGroupPresentInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupPresentInfoKHR] :: VkDeviceGroupPresentInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupPresentInfoKHR] :: VkDeviceGroupPresentInfoKHR -> Ptr ()
-- | swapchainCount is zero or the number of elements in
-- pDeviceMasks.
[$sel:vkSwapchainCount:VkDeviceGroupPresentInfoKHR] :: VkDeviceGroupPresentInfoKHR -> Word32
-- | pDeviceMasks is an array of device masks, one for each
-- element of VkPresentInfoKHR::pSwapchains.
[$sel:vkPDeviceMasks:VkDeviceGroupPresentInfoKHR] :: VkDeviceGroupPresentInfoKHR -> Ptr Word32
-- | mode is the device group present mode that will be used for
-- this present.
[$sel:vkMode:VkDeviceGroupPresentInfoKHR] :: VkDeviceGroupPresentInfoKHR -> VkDeviceGroupPresentModeFlagBitsKHR
-- | VkDeviceGroupSwapchainCreateInfoKHR - Structure specifying parameters
-- of a newly created swapchain object
--
-- Description
--
-- If this structure is not present, modes is considered to be
-- VK_DEVICE_GROUP_PRESENT_MODE_LOCAL_BIT_KHR.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_SWAPCHAIN_CREATE_INFO_KHR
--
--
--
--
-- See Also
--
-- VkDeviceGroupPresentModeFlagsKHR, VkStructureType
data VkDeviceGroupSwapchainCreateInfoKHR
VkDeviceGroupSwapchainCreateInfoKHR :: VkStructureType -> Ptr () -> VkDeviceGroupPresentModeFlagsKHR -> VkDeviceGroupSwapchainCreateInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupSwapchainCreateInfoKHR] :: VkDeviceGroupSwapchainCreateInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupSwapchainCreateInfoKHR] :: VkDeviceGroupSwapchainCreateInfoKHR -> Ptr ()
-- | modes is a bitfield of modes that the swapchain can be
-- used with.
[$sel:vkModes:VkDeviceGroupSwapchainCreateInfoKHR] :: VkDeviceGroupSwapchainCreateInfoKHR -> VkDeviceGroupPresentModeFlagsKHR
-- | VkSwapchainCreateFlagsKHR - Bitmask of VkSwapchainCreateFlagBitsKHR
--
-- Description
--
-- VkSwapchainCreateFlagsKHR is a bitmask type for setting a
-- mask of zero or more VkSwapchainCreateFlagBitsKHR.
--
-- See Also
--
-- VkSwapchainCreateFlagBitsKHR, VkSwapchainCreateInfoKHR
type VkSwapchainCreateFlagsKHR = VkSwapchainCreateFlagBitsKHR
-- | VkDeviceGroupPresentModeFlagsKHR - Bitmask of
-- VkDeviceGroupPresentModeFlagBitsKHR
--
-- Description
--
-- VkDeviceGroupPresentModeFlagsKHR is a bitmask type for
-- setting a mask of zero or more
-- VkDeviceGroupPresentModeFlagBitsKHR.
--
-- See Also
--
-- VkDeviceGroupPresentCapabilitiesKHR,
-- VkDeviceGroupPresentModeFlagBitsKHR,
-- VkDeviceGroupSwapchainCreateInfoKHR,
-- vkGetDeviceGroupSurfacePresentModesKHR
type VkDeviceGroupPresentModeFlagsKHR = VkDeviceGroupPresentModeFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentCapabilitiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentCapabilitiesKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupSwapchainCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupSwapchainCreateInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkAcquireNextImageInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkAcquireNextImageInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkBindImageMemorySwapchainInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkBindImageMemorySwapchainInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkImageSwapchainCreateInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkImageSwapchainCreateInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkPresentInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkPresentInfoKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentCapabilitiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupSwapchainCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkAcquireNextImageInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkBindImageMemorySwapchainInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkImageSwapchainCreateInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkPresentInfoKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkDeviceGroupPresentModeFlagBitsKHR
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_KHR_swapchain.VkSwapchainCreateFlagBitsKHR
module Graphics.Vulkan.Extensions.VK_KHR_display_swapchain
-- | vkCreateSharedSwapchainsKHR - Create multiple swapchains that share
-- presentable images
--
-- Parameters
--
--
-- - device is the device to create the swapchains for.
--
--
--
-- - swapchainCount is the number of swapchains to
-- create.
-- - pCreateInfos is a pointer to an array of
-- VkSwapchainCreateInfoKHR structures specifying the parameters
-- of the created swapchains.
-- - pAllocator is the allocator used for host memory
-- allocated for the swapchain objects when there is no more specific
-- allocator available (see Memory Allocation).
-- - pSwapchains is a pointer to an array of
-- VkSwapchainKHR handles in which the created swapchain objects
-- will be returned.
--
--
-- Description
--
-- vkCreateSharedSwapchains is similar to
-- vkCreateSwapchainKHR, except that it takes an array of
-- VkSwapchainCreateInfoKHR structures, and returns an array of
-- swapchain objects.
--
-- The swapchain creation parameters that affect the properties and
-- number of presentable images must match between all the
-- swapchains. If the displays used by any of the swapchains do not use
-- the same presentable image layout or are incompatible in a way that
-- prevents sharing images, swapchain creation will fail with the result
-- code VK_ERROR_INCOMPATIBLE_DISPLAY_KHR. If any error occurs,
-- no swapchains will be created. Images presented to multiple swapchains
-- must be re-acquired from all of them before transitioning away
-- from VK_IMAGE_LAYOUT_PRESENT_SRC_KHR. After destroying one or
-- more of the swapchains, the remaining swapchains and the presentable
-- images can continue to be used.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfos must be a valid pointer to an array
-- of swapchainCount valid VkSwapchainCreateInfoKHR
-- structures
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSwapchains must be a valid pointer to an array of
-- swapchainCount VkSwapchainKHR handles
-- - swapchainCount must be greater than
-- 0
--
--
-- Host Synchronization
--
--
-- - Host access to pCreateInfos[].surface must be
-- externally synchronized
--
--
--
-- - Host access to pCreateInfos[].oldSwapchain must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- 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
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkSwapchainCreateInfoKHR, VkSwapchainKHR
vkCreateSharedSwapchainsKHR :: ("device" ::: VkDevice) -> ("swapchainCount" ::: Word32) -> ("pCreateInfos" ::: Ptr VkSwapchainCreateInfoKHR) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSwapchains" ::: Ptr VkSwapchainKHR) -> IO VkResult
-- | VkDisplayPresentInfoKHR - Structure describing parameters of a queue
-- presentation to a swapchain
--
-- Description
--
-- If the extent of the srcRect and dstRect are not
-- equal, the presented pixels will be scaled accordingly.
--
-- Valid Usage
--
--
-- - srcRect must specify a rectangular region that is
-- a subset of the image being presented
--
--
--
-- - dstRect must specify a rectangular region that is
-- a subset of the visibleRegion parameter of the display mode
-- the swapchain being presented uses
-- - If the persistentContent member of the
-- VkDisplayPropertiesKHR structure returned by
-- vkGetPhysicalDeviceDisplayPropertiesKHR for the display the
-- present operation targets then persistent must be
-- VK_FALSE
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DISPLAY_PRESENT_INFO_KHR
--
--
-- See Also
--
-- VkBool32, VkRect2D, VkStructureType
data VkDisplayPresentInfoKHR
VkDisplayPresentInfoKHR :: VkStructureType -> Ptr () -> VkRect2D -> VkRect2D -> VkBool32 -> VkDisplayPresentInfoKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkDisplayPresentInfoKHR] :: VkDisplayPresentInfoKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDisplayPresentInfoKHR] :: VkDisplayPresentInfoKHR -> Ptr ()
-- | srcRect is a rectangular region of pixels to present. It
-- must be a subset of the image being presented. If
-- VkDisplayPresentInfoKHR is not specified, this region will be
-- assumed to be the entire presentable image.
[$sel:vkSrcRect:VkDisplayPresentInfoKHR] :: VkDisplayPresentInfoKHR -> VkRect2D
-- | dstRect is a rectangular region within the visible region of
-- the swapchain’s display mode. If VkDisplayPresentInfoKHR is
-- not specified, this region will be assumed to be the entire visible
-- region of the visible region of the swapchain’s mode. If the specified
-- rectangle is a subset of the display mode’s visible region, content
-- from display planes below the swapchain’s plane will be visible
-- outside the rectangle. If there are no planes below the swapchain’s,
-- the area outside the specified rectangle will be black. If portions of
-- the specified rectangle are outside of the display’s visible region,
-- pixels mapping only to those portions of the rectangle will be
-- discarded.
[$sel:vkDstRect:VkDisplayPresentInfoKHR] :: VkDisplayPresentInfoKHR -> VkRect2D
-- | persistent: If this is VK_TRUE, the display engine
-- will enable buffered mode on displays that support it. This allows the
-- display engine to stop sending content to the display until a new
-- image is presented. The display will instead maintain a copy of the
-- last presented image. This allows less power to be used, but
-- may increase presentation latency. If
-- VkDisplayPresentInfoKHR is not specified, persistent mode
-- will not be used.
[$sel:vkPersistent:VkDisplayPresentInfoKHR] :: VkDisplayPresentInfoKHR -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_display_swapchain.VkDisplayPresentInfoKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_display_swapchain.VkDisplayPresentInfoKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_display_swapchain.VkDisplayPresentInfoKHR
module Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing
-- | vkGetRefreshCycleDurationGOOGLE - Obtain the RC duration of the PE’s
-- display
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain to obtain the refresh duration
-- for.
-- - pDisplayTimingProperties is a pointer to an instance of
-- the VkRefreshCycleDurationGOOGLE structure.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - pDisplayTimingProperties must be a valid pointer
-- to a VkRefreshCycleDurationGOOGLE structure
-- - Both of device, and swapchain must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_DEVICE_LOST
--
--
-- See Also
--
-- VkDevice, VkRefreshCycleDurationGOOGLE,
-- VkSwapchainKHR
vkGetRefreshCycleDurationGOOGLE :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("pDisplayTimingProperties" ::: Ptr VkRefreshCycleDurationGOOGLE) -> IO VkResult
-- | vkGetPastPresentationTimingGOOGLE - Obtain timing of a
-- previously-presented image
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain to obtain presentation timing
-- information duration for.
-- - pPresentationTimingCount is a pointer to an integer
-- related to the number of VkPastPresentationTimingGOOGLE
-- structures to query, as described below.
-- - pPresentationTimings is either NULL or a pointer
-- to an an array of VkPastPresentationTimingGOOGLE
-- structures.
--
--
-- Description
--
-- If pPresentationTimings is NULL, then the number of
-- newly-available timing records for the given swapchain is
-- returned in pPresentationTimingCount. Otherwise,
-- pPresentationTimingCount must point to a variable set
-- by the user to the number of elements in the
-- pPresentationTimings array, and on return the variable is
-- overwritten with the number of structures actually written to
-- pPresentationTimings. If the value of
-- pPresentationTimingCount is less than the number of
-- newly-available timing records, at most
-- pPresentationTimingCount structures will be written. If
-- pPresentationTimingCount is smaller than the number of
-- newly-available timing records for the given swapchain,
-- VK_INCOMPLETE will be returned instead of VK_SUCCESS
-- to indicate that not all the available values were returned.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - pPresentationTimingCount must be a valid pointer
-- to a uint32_t value
-- - If the value referenced by pPresentationTimingCount is
-- not 0, and pPresentationTimings is not
-- NULL, pPresentationTimings must be a valid
-- pointer to an array of pPresentationTimingCount
-- VkPastPresentationTimingGOOGLE structures
-- - Both of device, and swapchain must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_DEVICE_LOST
--
--
-- See Also
--
-- VkDevice, VkPastPresentationTimingGOOGLE,
-- VkSwapchainKHR
vkGetPastPresentationTimingGOOGLE :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("pPresentationTimingCount" ::: Ptr Word32) -> ("pPresentationTimings" ::: Ptr VkPastPresentationTimingGOOGLE) -> IO VkResult
-- | VkRefreshCycleDurationGOOGLE - Structure containing the RC duration of
-- a display
--
-- Description
--
-- See Also
--
-- vkGetRefreshCycleDurationGOOGLE
data VkRefreshCycleDurationGOOGLE
VkRefreshCycleDurationGOOGLE :: Word64 -> VkRefreshCycleDurationGOOGLE
-- | refreshDuration is the number of nanoseconds from the start
-- of one refresh cycle to the next.
[$sel:vkRefreshDuration:VkRefreshCycleDurationGOOGLE] :: VkRefreshCycleDurationGOOGLE -> Word64
-- | VkPastPresentationTimingGOOGLE - Structure containing timing
-- information about a previously-presented image
--
-- Description
--
-- The results for a given swapchain and presentID are
-- only returned once from vkGetPastPresentationTimingGOOGLE.
--
-- The application can use the
-- VkPastPresentationTimingGOOGLE values to occasionally adjust
-- its timing. For example, if actualPresentTime is later than
-- expected (e.g. one refreshDuration late), the application may
-- increase its target IPD to a higher multiple of
-- refreshDuration (e.g. decrease its frame rate from 60Hz to
-- 30Hz). If actualPresentTime and earliestPresentTime
-- are consistently different, and if presentMargin is
-- consistently large enough, the application may decrease its target IPD
-- to a smaller multiple of refreshDuration (e.g. increase its
-- frame rate from 30Hz to 60Hz). If actualPresentTime and
-- earliestPresentTime are same, and if presentMargin
-- is consistently high, the application may delay the start of its
-- input-render-present loop in order to decrease the latency between
-- user input and the corresponding present (always leaving some margin
-- in case a new image takes longer to render than the previous image).
-- An application that desires its target IPD to always be the same as
-- refreshDuration, can also adjust features until
-- actualPresentTime is never late and presentMargin is
-- satisfactory.
--
-- See Also
--
-- vkGetPastPresentationTimingGOOGLE
data VkPastPresentationTimingGOOGLE
VkPastPresentationTimingGOOGLE :: Word32 -> Word64 -> Word64 -> Word64 -> Word64 -> VkPastPresentationTimingGOOGLE
-- | presentID is an application-provided value that was given to
-- a previous vkQueuePresentKHR command via
-- VkPresentTimeGOOGLE::presentID (see below). It
-- can be used to uniquely identify a previous present with the
-- vkQueuePresentKHR command.
[$sel:vkPresentID:VkPastPresentationTimingGOOGLE] :: VkPastPresentationTimingGOOGLE -> Word32
-- | desiredPresentTime is an application-provided value that was
-- given to a previous vkQueuePresentKHR command via
-- VkPresentTimeGOOGLE::desiredPresentTime. If non-zero,
-- it was used by the application to indicate that an image not be
-- presented any sooner than desiredPresentTime.
[$sel:vkDesiredPresentTime:VkPastPresentationTimingGOOGLE] :: VkPastPresentationTimingGOOGLE -> Word64
-- | actualPresentTime is the time when the image of the
-- swapchain was actually displayed.
[$sel:vkActualPresentTime:VkPastPresentationTimingGOOGLE] :: VkPastPresentationTimingGOOGLE -> Word64
-- | earliestPresentTime is the time when the image of the
-- swapchain could have been displayed. This may differ
-- from actualPresentTime if the application requested that the
-- image be presented no sooner than
-- VkPresentTimeGOOGLE::desiredPresentTime.
[$sel:vkEarliestPresentTime:VkPastPresentationTimingGOOGLE] :: VkPastPresentationTimingGOOGLE -> Word64
-- | presentMargin is an indication of how early the
-- vkQueuePresentKHR command was processed compared to how soon
-- it needed to be processed, and still be presented at
-- earliestPresentTime.
[$sel:vkPresentMargin:VkPastPresentationTimingGOOGLE] :: VkPastPresentationTimingGOOGLE -> Word64
-- | VkPresentTimesInfoGOOGLE - The earliest time each image should be
-- presented
--
-- Description
--
-- Valid Usage
--
--
-- - swapchainCount must be the same value as
-- VkPresentInfoKHR::swapchainCount, where
-- VkPresentInfoKHR is in the pNext chain of this
-- VkPresentTimesInfoGOOGLE structure.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PRESENT_TIMES_INFO_GOOGLE
--
--
--
-- - If pTimes is not NULL, pTimes
-- must be a valid pointer to an array of swapchainCount
-- VkPresentTimeGOOGLE structures
-- - swapchainCount must be greater than
-- 0
--
--
-- See Also
--
-- VkPresentTimeGOOGLE, VkStructureType
data VkPresentTimesInfoGOOGLE
VkPresentTimesInfoGOOGLE :: VkStructureType -> Ptr () -> Word32 -> Ptr VkPresentTimeGOOGLE -> VkPresentTimesInfoGOOGLE
-- | sType is the type of this structure.
[$sel:vkSType:VkPresentTimesInfoGOOGLE] :: VkPresentTimesInfoGOOGLE -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPresentTimesInfoGOOGLE] :: VkPresentTimesInfoGOOGLE -> Ptr ()
-- | swapchainCount is the number of swapchains being presented to
-- by this command.
[$sel:vkSwapchainCount:VkPresentTimesInfoGOOGLE] :: VkPresentTimesInfoGOOGLE -> Word32
-- | pTimes is NULL or a pointer to an array of
-- VkPresentTimeGOOGLE elements with swapchainCount
-- entries. If not NULL, each element of pTimes
-- contains the earliest time to present the image corresponding to the
-- entry in the VkPresentInfoKHR::pImageIndices array.
[$sel:vkPTimes:VkPresentTimesInfoGOOGLE] :: VkPresentTimesInfoGOOGLE -> Ptr VkPresentTimeGOOGLE
-- | VkPresentTimeGOOGLE - The earliest time image should be presented
--
-- Description
--
-- See Also
--
-- VkPresentTimesInfoGOOGLE
data VkPresentTimeGOOGLE
VkPresentTimeGOOGLE :: Word32 -> Word64 -> VkPresentTimeGOOGLE
-- | presentID is an application-provided identification value,
-- that can be used with the results of
-- vkGetPastPresentationTimingGOOGLE, in order to uniquely
-- identify this present. In order to be useful to the application, it
-- should be unique within some period of time that is meaningful
-- to the application.
[$sel:vkPresentID:VkPresentTimeGOOGLE] :: VkPresentTimeGOOGLE -> Word32
-- | desiredPresentTime specifies that the image given
-- should not be displayed to the user any earlier than this time.
-- desiredPresentTime is a time in nanoseconds, relative to a
-- monotonically-increasing clock (e.g. CLOCK_MONOTONIC (see
-- clock_gettime(2)) on Android and Linux). A value of zero specifies
-- that the presentation engine may display the image at any time.
-- This is useful when the application desires to provide
-- presentID, but doesn’t need a specific
-- desiredPresentTime.
[$sel:vkDesiredPresentTime:VkPresentTimeGOOGLE] :: VkPresentTimeGOOGLE -> Word64
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimesInfoGOOGLE
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimesInfoGOOGLE
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimeGOOGLE
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimeGOOGLE
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPastPresentationTimingGOOGLE
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPastPresentationTimingGOOGLE
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkRefreshCycleDurationGOOGLE
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkRefreshCycleDurationGOOGLE
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimesInfoGOOGLE
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPresentTimeGOOGLE
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkPastPresentationTimingGOOGLE
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_GOOGLE_display_timing.VkRefreshCycleDurationGOOGLE
module Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata
-- | vkSetHdrMetadataEXT - function to set Hdr metadata
--
-- Parameters
--
--
-- - device is the logical device where the swapchain(s) were
-- created.
--
--
--
-- - swapchainCount is the number of swapchains included in
-- pSwapchains.
-- - pSwapchains is a pointer to the array of
-- swapchainCount VkSwapchainKHR handles.
-- - pMetadata is a pointer to the array of
-- swapchainCount VkHdrMetadataEXT structures.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pSwapchains must be a valid pointer to an array of
-- swapchainCount valid VkSwapchainKHR handles
-- - pMetadata must be a valid pointer to an array of
-- swapchainCount valid VkHdrMetadataEXT
-- structures
-- - swapchainCount must be greater than
-- 0
-- - Both of device, and the elements of pSwapchains
-- must have been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- See Also
--
-- VkDevice, VkHdrMetadataEXT, VkSwapchainKHR
vkSetHdrMetadataEXT :: ("device" ::: VkDevice) -> ("swapchainCount" ::: Word32) -> ("pSwapchains" ::: Ptr VkSwapchainKHR) -> ("pMetadata" ::: Ptr VkHdrMetadataEXT) -> IO ()
-- | VkXYColorEXT - structure to specify X,Y chromaticity coordinates
--
-- Members
--
-- Description
--
-- See Also
--
-- VkHdrMetadataEXT
data VkXYColorEXT
VkXYColorEXT :: CFloat -> CFloat -> VkXYColorEXT
[$sel:vkX:VkXYColorEXT] :: VkXYColorEXT -> CFloat
[$sel:vkY:VkXYColorEXT] :: VkXYColorEXT -> CFloat
-- | VkHdrMetadataEXT - structure to specify Hdr metadata
--
-- Description
--
-- Note
--
-- The validity and use of this data is outside the scope of Vulkan and
-- thus no Valid Usage is given.
--
-- See Also
--
-- VkStructureType, VkXYColorEXT,
-- vkSetHdrMetadataEXT
data VkHdrMetadataEXT
VkHdrMetadataEXT :: VkStructureType -> Ptr () -> VkXYColorEXT -> VkXYColorEXT -> VkXYColorEXT -> VkXYColorEXT -> CFloat -> CFloat -> CFloat -> CFloat -> VkHdrMetadataEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> Ptr ()
-- | displayPrimaryRed is the mastering display’s red primary in
-- chromaticity coordinates
[$sel:vkDisplayPrimaryRed:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> VkXYColorEXT
-- | displayPrimaryGreen is the mastering display’s green primary
-- in chromaticity coordinates
[$sel:vkDisplayPrimaryGreen:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> VkXYColorEXT
-- | displayPrimaryBlue is the mastering display’s blue primary in
-- chromaticity coordinates
[$sel:vkDisplayPrimaryBlue:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> VkXYColorEXT
-- | whitePoint is the mastering display’s white-point in
-- chromaticity coordinates
[$sel:vkWhitePoint:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> VkXYColorEXT
-- | maxLuminance is the maximum luminance of the mastering
-- display in nits
[$sel:vkMaxLuminance:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> CFloat
-- | minLuminance is the minimum luminance of the mastering
-- display in nits
[$sel:vkMinLuminance:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> CFloat
-- | maxContentLightLevel is content’s maximum luminance in nits
[$sel:vkMaxContentLightLevel:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> CFloat
-- | maxFrameAverageLightLevel is the maximum frame average light
-- level in nits
[$sel:vkMaxFrameAverageLightLevel:VkHdrMetadataEXT] :: VkHdrMetadataEXT -> CFloat
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkHdrMetadataEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkHdrMetadataEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkXYColorEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkXYColorEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkHdrMetadataEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_hdr_metadata.VkXYColorEXT
module Graphics.Vulkan.Extensions.VK_EXT_display_control
-- | VkDisplayPowerStateEXT - Possible power states for a display
--
-- See Also
--
-- VkDisplayPowerInfoEXT
newtype VkDisplayPowerStateEXT
VkDisplayPowerStateEXT :: Int32 -> VkDisplayPowerStateEXT
-- | VK_DISPLAY_POWER_STATE_OFF_EXT specifies that the display is
-- powered down.
-- | VK_DISPLAY_POWER_STATE_SUSPEND_EXT specifies that the display
-- is put into a low power mode, from which it may be able to
-- transition back to VK_DISPLAY_POWER_STATE_ON_EXT more quickly
-- than if it were in VK_DISPLAY_POWER_STATE_OFF_EXT. This state
-- may be the same as VK_DISPLAY_POWER_STATE_OFF_EXT.
-- | VK_DISPLAY_POWER_STATE_ON_EXT specifies that the display is
-- powered on.
-- | VkDeviceEventTypeEXT - Events that can occur on a device object
--
-- See Also
--
-- VkDeviceEventInfoEXT
newtype VkDeviceEventTypeEXT
VkDeviceEventTypeEXT :: Int32 -> VkDeviceEventTypeEXT
-- | VK_DEVICE_EVENT_TYPE_DISPLAY_HOTPLUG_EXT specifies that the
-- fence is signaled when a display is plugged into or unplugged from the
-- specified device. Applications can use this notification to
-- determine when they need to re-enumerate the available displays on a
-- device.
-- | VkDisplayEventTypeEXT - Events that can occur on a display object
--
-- See Also
--
-- VkDisplayEventInfoEXT
newtype VkDisplayEventTypeEXT
VkDisplayEventTypeEXT :: Int32 -> VkDisplayEventTypeEXT
-- | VK_DISPLAY_EVENT_TYPE_FIRST_PIXEL_OUT_EXT specifies that the
-- fence is signaled when the first pixel of the next display refresh
-- cycle leaves the display engine for the display.
-- | vkDisplayPowerControlEXT - Set the power state of a display
--
-- Parameters
--
--
-- - device is a logical device associated with
-- display.
--
--
--
-- - display is the display whose power state is
-- modified.
-- - pDisplayPowerInfo is an instance of
-- VkDisplayPowerInfoEXT specifying the new power state of
-- display.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - display must be a valid VkDisplayKHR
-- handle
-- - pDisplayPowerInfo must be a valid pointer to a
-- valid VkDisplayPowerInfoEXT structure
--
--
-- Return Codes
--
--
--
-- See Also
--
-- VkDevice, VkDisplayKHR, VkDisplayPowerInfoEXT
vkDisplayPowerControlEXT :: ("device" ::: VkDevice) -> ("display" ::: VkDisplayKHR) -> ("pDisplayPowerInfo" ::: Ptr VkDisplayPowerInfoEXT) -> IO VkResult
-- | vkRegisterDeviceEventEXT - Signal a fence when a device event occurs
--
-- Parameters
--
--
-- - device is a logical device on which the event may
-- occur.
--
--
--
-- - pDeviceEventInfo is a pointer to an instance of the
-- VkDeviceEventInfoEXT structure describing the event of interest
-- to the application.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pFence points to a handle in which the resulting fence
-- object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pDeviceEventInfo must be a valid pointer to a
-- valid VkDeviceEventInfoEXT structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pFence must be a valid pointer to a
-- VkFence handle
--
--
-- Return Codes
--
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkDeviceEventInfoEXT, VkFence
vkRegisterDeviceEventEXT :: ("device" ::: VkDevice) -> ("pDeviceEventInfo" ::: Ptr VkDeviceEventInfoEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pFence" ::: Ptr VkFence) -> IO VkResult
-- | vkRegisterDisplayEventEXT - Signal a fence when a display event occurs
--
-- Parameters
--
--
-- - device is a logical device associated with
-- display
--
--
--
-- - display is the display on which the event may
-- occur.
-- - pDisplayEventInfo is a pointer to an instance of the
-- VkDisplayEventInfoEXT structure describing the event of
-- interest to the application.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pFence points to a handle in which the resulting fence
-- object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - display must be a valid VkDisplayKHR
-- handle
-- - pDisplayEventInfo must be a valid pointer to a
-- valid VkDisplayEventInfoEXT structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pFence must be a valid pointer to a
-- VkFence handle
--
--
-- Return Codes
--
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkDisplayEventInfoEXT, VkDisplayKHR, VkFence
vkRegisterDisplayEventEXT :: ("device" ::: VkDevice) -> ("display" ::: VkDisplayKHR) -> ("pDisplayEventInfo" ::: Ptr VkDisplayEventInfoEXT) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pFence" ::: Ptr VkFence) -> IO VkResult
-- | vkGetSwapchainCounterEXT - Query the current value of a surface
-- counter
--
-- Parameters
--
--
-- - device is the VkDevice associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain from which to query the
-- counter value.
-- - counter is the counter to query.
-- - pCounterValue will return the current value of the
-- counter.
--
--
-- Description
--
-- If a counter is not available because the swapchain is out of date,
-- the implementation may return
-- VK_ERROR_OUT_OF_DATE_KHR.
--
-- Valid Usage
--
--
-- - One or more present commands on swapchain must
-- have been processed by the presentation engine.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - counter must be a valid
-- VkSurfaceCounterFlagBitsEXT value
-- - pCounterValue must be a valid pointer to a
-- uint64_t value
-- - Both of device, and swapchain must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_DEVICE_LOST
--
--
-- See Also
--
-- VkDevice, VkSurfaceCounterFlagBitsEXT,
-- VkSwapchainKHR
vkGetSwapchainCounterEXT :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> ("counter" ::: VkSurfaceCounterFlagBitsEXT) -> ("pCounterValue" ::: Ptr Word64) -> IO VkResult
-- | VkDisplayPowerInfoEXT - Describe the power state of a display
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DISPLAY_POWER_INFO_EXT
--
--
--
--
-- See Also
--
-- VkDisplayPowerStateEXT, VkStructureType,
-- vkDisplayPowerControlEXT
data VkDisplayPowerInfoEXT
VkDisplayPowerInfoEXT :: VkStructureType -> Ptr () -> VkDisplayPowerStateEXT -> VkDisplayPowerInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDisplayPowerInfoEXT] :: VkDisplayPowerInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDisplayPowerInfoEXT] :: VkDisplayPowerInfoEXT -> Ptr ()
-- | powerState is a VkDisplayPowerStateEXT value
-- specifying the new power state of the display.
[$sel:vkPowerState:VkDisplayPowerInfoEXT] :: VkDisplayPowerInfoEXT -> VkDisplayPowerStateEXT
-- | VkDeviceEventInfoEXT - Describe a device event to create
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_EVENT_INFO_EXT
--
--
--
--
-- See Also
--
-- VkDeviceEventTypeEXT, VkStructureType,
-- vkRegisterDeviceEventEXT
data VkDeviceEventInfoEXT
VkDeviceEventInfoEXT :: VkStructureType -> Ptr () -> VkDeviceEventTypeEXT -> VkDeviceEventInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceEventInfoEXT] :: VkDeviceEventInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceEventInfoEXT] :: VkDeviceEventInfoEXT -> Ptr ()
[$sel:vkDeviceEvent:VkDeviceEventInfoEXT] :: VkDeviceEventInfoEXT -> VkDeviceEventTypeEXT
-- | VkDisplayEventInfoEXT - Describe a display event to create
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DISPLAY_EVENT_INFO_EXT
--
--
--
--
-- See Also
--
-- VkDisplayEventTypeEXT, VkStructureType,
-- vkRegisterDisplayEventEXT
data VkDisplayEventInfoEXT
VkDisplayEventInfoEXT :: VkStructureType -> Ptr () -> VkDisplayEventTypeEXT -> VkDisplayEventInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDisplayEventInfoEXT] :: VkDisplayEventInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDisplayEventInfoEXT] :: VkDisplayEventInfoEXT -> Ptr ()
-- | displayEvent is a VkDisplayEventTypeEXT specifying
-- when the fence will be signaled.
[$sel:vkDisplayEvent:VkDisplayEventInfoEXT] :: VkDisplayEventInfoEXT -> VkDisplayEventTypeEXT
-- | VkSwapchainCounterCreateInfoEXT - Specify the surface counters desired
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SWAPCHAIN_COUNTER_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkStructureType, VkSurfaceCounterFlagsEXT
data VkSwapchainCounterCreateInfoEXT
VkSwapchainCounterCreateInfoEXT :: VkStructureType -> Ptr () -> VkSurfaceCounterFlagsEXT -> VkSwapchainCounterCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkSwapchainCounterCreateInfoEXT] :: VkSwapchainCounterCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSwapchainCounterCreateInfoEXT] :: VkSwapchainCounterCreateInfoEXT -> Ptr ()
-- | surfaceCounters is a bitmask of
-- VkSurfaceCounterFlagBitsEXT specifying surface counters to
-- enable for the swapchain.
[$sel:vkSurfaceCounters:VkSwapchainCounterCreateInfoEXT] :: VkSwapchainCounterCreateInfoEXT -> VkSurfaceCounterFlagsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkSwapchainCounterCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkSwapchainCounterCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventTypeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventTypeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventTypeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventTypeEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventTypeEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventTypeEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerStateEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerStateEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerStateEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkSwapchainCounterCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventTypeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayEventTypeEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventTypeEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDeviceEventTypeEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerStateEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_display_control.VkDisplayPowerStateEXT
module Graphics.Vulkan.Extensions.VK_KHR_shared_presentable_image
-- | vkGetSwapchainStatusKHR - Get a swapchain’s status
--
-- Parameters
--
--
-- - device is the device associated with
-- swapchain.
--
--
--
-- - swapchain is the swapchain to query.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - swapchain must be a valid VkSwapchainKHR
-- handle
-- - Both of device, and swapchain must have
-- been created, allocated, or retrieved from the same
-- VkInstance
--
--
-- Host Synchronization
--
--
-- - Host access to swapchain must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkSwapchainKHR
vkGetSwapchainStatusKHR :: ("device" ::: VkDevice) -> ("swapchain" ::: VkSwapchainKHR) -> IO VkResult
-- | VkSharedPresentSurfaceCapabilitiesKHR - structure describing
-- capabilities of a surface for shared presentation
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_SHARED_PRESENT_SURFACE_CAPABILITIES_KHR
--
--
-- See Also
--
-- VkImageUsageFlags, VkStructureType
data VkSharedPresentSurfaceCapabilitiesKHR
VkSharedPresentSurfaceCapabilitiesKHR :: VkStructureType -> Ptr () -> VkImageUsageFlags -> VkSharedPresentSurfaceCapabilitiesKHR
-- | sType is the type of this structure.
[$sel:vkSType:VkSharedPresentSurfaceCapabilitiesKHR] :: VkSharedPresentSurfaceCapabilitiesKHR -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkSharedPresentSurfaceCapabilitiesKHR] :: VkSharedPresentSurfaceCapabilitiesKHR -> Ptr ()
-- | sharedPresentSupportedUsageFlags is a bitmask of
-- VkImageUsageFlagBits representing the ways the application
-- can use the shared presentable image from a swapchain created
-- with VkPresentModeKHR set to
-- VK_PRESENT_MODE_SHARED_DEMAND_REFRESH_KHR or
-- VK_PRESENT_MODE_SHARED_CONTINUOUS_REFRESH_KHR for the surface
-- on the specified device. VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT
-- must be included in the set but implementations may
-- support additional usages.
[$sel:vkSharedPresentSupportedUsageFlags:VkSharedPresentSurfaceCapabilitiesKHR] :: VkSharedPresentSurfaceCapabilitiesKHR -> VkImageUsageFlags
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_shared_presentable_image.VkSharedPresentSurfaceCapabilitiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_shared_presentable_image.VkSharedPresentSurfaceCapabilitiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_shared_presentable_image.VkSharedPresentSurfaceCapabilitiesKHR
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2
-- | VkPointClippingBehavior - Enum specifying the point clipping behaviour
--
-- See Also
--
-- VkPhysicalDevicePointClippingProperties
newtype VkPointClippingBehavior
VkPointClippingBehavior :: Int32 -> VkPointClippingBehavior
-- | VK_POINT_CLIPPING_BEHAVIOR_ALL_CLIP_PLANES specifies that the
-- primitive is discarded if the vertex lies outside any clip plane,
-- including the planes bounding the view volume.
-- | VK_POINT_CLIPPING_BEHAVIOR_USER_CLIP_PLANES_ONLY specifies
-- that the primitive is discarded only if the vertex lies outside any
-- user clip plane.
-- | VkTessellationDomainOrigin - Enum describing tessellation domain
-- origin
--
-- Description
--
--
--
--
--
-- This enum affects how the VertexOrderCw and
-- VertexOrderCcw tessellation execution modes are interpreted,
-- since the winding is defined relative to the orientation of the
-- domain.
--
-- See Also
--
-- VkPipelineTessellationDomainOriginStateCreateInfo
newtype VkTessellationDomainOrigin
VkTessellationDomainOrigin :: Int32 -> VkTessellationDomainOrigin
-- | VkInputAttachmentAspectReference - Structure specifying a
-- subpass/input attachment pair and an aspect mask that can be
-- read.
--
-- Description
--
-- Valid Usage
--
--
-- - There must be an input attachment at
-- pCreateInfo::pSubpasses[subpass].pInputAttachments[inputAttachmentIndex].
--
--
--
-- - The specified input attachment must have more than one
-- aspect mask.
-- - aspectMask must be a subset of the aspect masks in
-- the specified input attachment.
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - aspectMask must not be 0
--
--
-- See Also
--
-- VkImageAspectFlags,
-- VkRenderPassInputAttachmentAspectCreateInfo
data VkInputAttachmentAspectReference
VkInputAttachmentAspectReference :: Word32 -> Word32 -> VkImageAspectFlags -> VkInputAttachmentAspectReference
-- | subpass is an index into the pSubpasses array of the
-- parent VkRenderPassCreateInfo structure.
[$sel:vkSubpass:VkInputAttachmentAspectReference] :: VkInputAttachmentAspectReference -> Word32
-- | inputAttachmentIndex is an index into the
-- pInputAttachments of the specified subpass.
[$sel:vkInputAttachmentIndex:VkInputAttachmentAspectReference] :: VkInputAttachmentAspectReference -> Word32
-- | aspectMask is a mask of which aspect(s) can be
-- accessed within the specified subpass.
[$sel:vkAspectMask:VkInputAttachmentAspectReference] :: VkInputAttachmentAspectReference -> VkImageAspectFlags
-- | VkRenderPassInputAttachmentAspectCreateInfo - Structure specifying,
-- for a given subpass/input attachment pair, which aspect can be
-- read.
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_RENDER_PASS_INPUT_ATTACHMENT_ASPECT_CREATE_INFO
--
--
--
-- - pAspectReferences must be a valid pointer to an
-- array of aspectReferenceCount valid
-- VkInputAttachmentAspectReference structures
-- - aspectReferenceCount must be greater than
-- 0
--
--
-- See Also
--
-- VkInputAttachmentAspectReference, VkStructureType
data VkRenderPassInputAttachmentAspectCreateInfo
VkRenderPassInputAttachmentAspectCreateInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr VkInputAttachmentAspectReference -> VkRenderPassInputAttachmentAspectCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkRenderPassInputAttachmentAspectCreateInfo] :: VkRenderPassInputAttachmentAspectCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkRenderPassInputAttachmentAspectCreateInfo] :: VkRenderPassInputAttachmentAspectCreateInfo -> Ptr ()
-- | aspectReferenceCount is the number of elements in the
-- pAspectReferences array.
[$sel:vkAspectReferenceCount:VkRenderPassInputAttachmentAspectCreateInfo] :: VkRenderPassInputAttachmentAspectCreateInfo -> Word32
-- | pAspectReferences points to an array of
-- aspectReferenceCount number of
-- VkInputAttachmentAspectReference structures describing which
-- aspect(s) can be accessed for a given input attachment within a
-- given subpass.
[$sel:vkPAspectReferences:VkRenderPassInputAttachmentAspectCreateInfo] :: VkRenderPassInputAttachmentAspectCreateInfo -> Ptr VkInputAttachmentAspectReference
-- | VkPhysicalDevicePointClippingProperties - Structure describing the
-- point clipping behavior supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDevicePointClippingProperties
-- structure describe the following implementation-dependent limit:
--
-- Description
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - pointClippingBehavior is the point clipping behavior
-- supported by the implementation, and is of type
-- VkPointClippingBehavior.
--
--
-- If the VkPhysicalDevicePointClippingProperties structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_POINT_CLIPPING_PROPERTIES
--
--
-- See Also
--
-- VkPointClippingBehavior, VkStructureType
data VkPhysicalDevicePointClippingProperties
VkPhysicalDevicePointClippingProperties :: VkStructureType -> Ptr () -> VkPointClippingBehavior -> VkPhysicalDevicePointClippingProperties
[$sel:vkSType:VkPhysicalDevicePointClippingProperties] :: VkPhysicalDevicePointClippingProperties -> VkStructureType
[$sel:vkPNext:VkPhysicalDevicePointClippingProperties] :: VkPhysicalDevicePointClippingProperties -> Ptr ()
[$sel:vkPointClippingBehavior:VkPhysicalDevicePointClippingProperties] :: VkPhysicalDevicePointClippingProperties -> VkPointClippingBehavior
-- | VkImageViewUsageCreateInfo - Specify the intended usage of an image
-- view
--
-- Description
--
-- When this structure is chained to VkImageViewCreateInfo the
-- usage field overrides the implicit usage parameter
-- inherited from image creation time and its value is used instead for
-- the purposes of determining the valid usage conditions of
-- VkImageViewCreateInfo.
--
-- Valid Usage
--
--
-- - usage must not include any set bits that were not
-- set in the usage member of the VkImageCreateInfo
-- structure used to create the image this image view is created
-- from.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_VIEW_USAGE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkImageUsageFlags, VkStructureType
data VkImageViewUsageCreateInfo
VkImageViewUsageCreateInfo :: VkStructureType -> Ptr () -> VkImageUsageFlags -> VkImageViewUsageCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkImageViewUsageCreateInfo] :: VkImageViewUsageCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageViewUsageCreateInfo] :: VkImageViewUsageCreateInfo -> Ptr ()
-- | usage is a bitmask describing the allowed usages of the image
-- view. See VkImageUsageFlagBits for a description of the
-- supported bits.
[$sel:vkUsage:VkImageViewUsageCreateInfo] :: VkImageViewUsageCreateInfo -> VkImageUsageFlags
-- | VkPipelineTessellationDomainOriginStateCreateInfo - Structure
-- specifying the orientation of the tessellation domain
--
-- Description
--
-- If the VkPipelineTessellationDomainOriginStateCreateInfo
-- structure is included in the pNext chain of
-- VkPipelineTessellationStateCreateInfo, it controls the origin
-- of the tessellation domain. If this structure is not present, it is as
-- if domainOrigin were
-- VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_DOMAIN_ORIGIN_STATE_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkStructureType, VkTessellationDomainOrigin
data VkPipelineTessellationDomainOriginStateCreateInfo
VkPipelineTessellationDomainOriginStateCreateInfo :: VkStructureType -> Ptr () -> VkTessellationDomainOrigin -> VkPipelineTessellationDomainOriginStateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineTessellationDomainOriginStateCreateInfo] :: VkPipelineTessellationDomainOriginStateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineTessellationDomainOriginStateCreateInfo] :: VkPipelineTessellationDomainOriginStateCreateInfo -> Ptr ()
-- | domainOrigin controls the origin of the tessellation domain
-- space, and is of type VkTessellationDomainOrigin.
[$sel:vkDomainOrigin:VkPipelineTessellationDomainOriginStateCreateInfo] :: VkPipelineTessellationDomainOriginStateCreateInfo -> VkTessellationDomainOrigin
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPipelineTessellationDomainOriginStateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPipelineTessellationDomainOriginStateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkImageViewUsageCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkImageViewUsageCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPhysicalDevicePointClippingProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPhysicalDevicePointClippingProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkRenderPassInputAttachmentAspectCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkRenderPassInputAttachmentAspectCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkInputAttachmentAspectReference
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkInputAttachmentAspectReference
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkTessellationDomainOrigin
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkTessellationDomainOrigin
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkTessellationDomainOrigin
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPointClippingBehavior
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPointClippingBehavior
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPointClippingBehavior
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPipelineTessellationDomainOriginStateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkImageViewUsageCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPhysicalDevicePointClippingProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkRenderPassInputAttachmentAspectCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkInputAttachmentAspectReference
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkTessellationDomainOrigin
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkTessellationDomainOrigin
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPointClippingBehavior
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance2.VkPointClippingBehavior
module Graphics.Vulkan.Extensions.VK_KHR_maintenance2
type VkPointClippingBehaviorKHR = VkPointClippingBehavior
type VkTessellationDomainOriginKHR = VkTessellationDomainOrigin
type VkInputAttachmentAspectReferenceKHR = VkInputAttachmentAspectReference
type VkRenderPassInputAttachmentAspectCreateInfoKHR = VkRenderPassInputAttachmentAspectCreateInfo
type VkPhysicalDevicePointClippingPropertiesKHR = VkPhysicalDevicePointClippingProperties
type VkImageViewUsageCreateInfoKHR = VkImageViewUsageCreateInfo
type VkPipelineTessellationDomainOriginStateCreateInfoKHR = VkPipelineTessellationDomainOriginStateCreateInfo
module Graphics.Vulkan.Core10.Pass
-- | VkAttachmentLoadOp - Specify how contents of an attachment are treated
-- at the beginning of a subpass
--
-- See Also
--
-- VkAttachmentDescription
newtype VkAttachmentLoadOp
VkAttachmentLoadOp :: Int32 -> VkAttachmentLoadOp
-- | VK_ATTACHMENT_LOAD_OP_LOAD specifies that the previous
-- contents of the image within the render area will be preserved. For
-- attachments with a depth/stencil format, this uses the access type
-- VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT. For attachments
-- with a color format, this uses the access type
-- VK_ACCESS_COLOR_ATTACHMENT_READ_BIT.
-- | VK_ATTACHMENT_LOAD_OP_CLEAR specifies that the contents
-- within the render area will be cleared to a uniform value, which is
-- specified when a render pass instance is begun. For attachments with a
-- depth/stencil format, this uses the access type
-- VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT. For attachments
-- with a color format, this uses the access type
-- VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT.
-- | VK_ATTACHMENT_LOAD_OP_DONT_CARE specifies that the previous
-- contents within the area need not be preserved; the contents of the
-- attachment will be undefined inside the render area. For attachments
-- with a depth/stencil format, this uses the access type
-- VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT. For attachments
-- with a color format, this uses the access type
-- VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT.
-- | VkAttachmentStoreOp - Specify how contents of an attachment are
-- treated at the end of a subpass
--
-- See Also
--
-- VkAttachmentDescription
newtype VkAttachmentStoreOp
VkAttachmentStoreOp :: Int32 -> VkAttachmentStoreOp
-- | VK_ATTACHMENT_STORE_OP_STORE specifies the contents generated
-- during the render pass and within the render area are written to
-- memory. For attachments with a depth/stencil format, this uses the
-- access type VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT. For
-- attachments with a color format, this uses the access type
-- VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT.
-- | VK_ATTACHMENT_STORE_OP_DONT_CARE specifies the contents
-- within the render area are not needed after rendering, and may
-- be discarded; the contents of the attachment will be undefined inside
-- the render area. For attachments with a depth/stencil format, this
-- uses the access type
-- VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT. For attachments
-- with a color format, this uses the access type
-- VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT.
-- | VkPipelineBindPoint - Specify the bind point of a pipeline object to a
-- command buffer
--
-- See Also
--
-- VkDescriptorUpdateTemplateCreateInfo,
-- VkIndirectCommandsLayoutCreateInfoNVX,
-- VkSubpassDescription, vkCmdBindDescriptorSets,
-- vkCmdBindPipeline, vkCmdPushDescriptorSetKHR
newtype VkPipelineBindPoint
VkPipelineBindPoint :: Int32 -> VkPipelineBindPoint
-- | VK_PIPELINE_BIND_POINT_GRAPHICS specifies binding as a
-- graphics pipeline.
-- | VK_PIPELINE_BIND_POINT_COMPUTE specifies binding as a compute
-- pipeline.
-- | VkFramebufferCreateFlags - Reserved for future use
--
-- Description
--
-- VkFramebufferCreateFlags is a bitmask type for setting a
-- mask, but is currently reserved for future use.
--
-- See Also
--
-- VkFramebufferCreateInfo
newtype VkFramebufferCreateFlags
VkFramebufferCreateFlags :: VkFlags -> VkFramebufferCreateFlags
-- | VkRenderPassCreateFlags - Reserved for future use
--
-- Description
--
-- VkRenderPassCreateFlags is a bitmask type for setting a mask,
-- but is currently reserved for future use.
--
-- See Also
--
-- VkRenderPassCreateInfo
newtype VkRenderPassCreateFlags
VkRenderPassCreateFlags :: VkFlags -> VkRenderPassCreateFlags
-- | VkAccessFlagBits - Bitmask specifying memory access types that will
-- participate in a memory dependency
--
-- Description
--
--
-- - VK_ACCESS_INDIRECT_COMMAND_READ_BIT specifies read access
-- to an indirect command structure read as part of an indirect drawing
-- or dispatch command.
--
--
--
-- - VK_ACCESS_INDEX_READ_BIT specifies read access to an
-- index buffer as part of an indexed drawing command, bound by
-- vkCmdBindIndexBuffer.
-- - VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT specifies read access
-- to a vertex buffer as part of a drawing command, bound by
-- vkCmdBindVertexBuffers.
-- - VK_ACCESS_UNIFORM_READ_BIT specifies read access to a
-- uniform buffer.
-- - VK_ACCESS_INPUT_ATTACHMENT_READ_BIT specifies read access
-- to an input attachment within a render pass during fragment
-- shading.
-- - VK_ACCESS_SHADER_READ_BIT specifies read access to a
-- storage buffer, uniform texel buffer, storage texel
-- buffer, sampled image, or storage image.
-- - VK_ACCESS_SHADER_WRITE_BIT specifies write access to a
-- storage buffer, storage texel buffer, or storage
-- image.
-- - VK_ACCESS_COLOR_ATTACHMENT_READ_BIT specifies read access
-- to a color attachment, such as via blending, logic
-- operations, or via certain subpass load operations. It does
-- not include advanced blend operations.
-- - VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT is
-- similar to VK_ACCESS_COLOR_ATTACHMENT_READ_BIT, but also
-- includes advanced blend operations.
-- - VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT specifies write
-- access to a color or resolve attachment during a render
-- pass or via certain subpass load and store operations.
-- - VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT specifies
-- read access to a depth/stencil attachment, via depth or
-- stencil operations or via certain subpass load
-- operations.
-- - VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT specifies
-- write access to a depth/stencil attachment, via depth or
-- stencil operations or via certain subpass load and store
-- operations.
-- - VK_ACCESS_TRANSFER_READ_BIT specifies read access to an
-- image or buffer in a copy operation.
-- - VK_ACCESS_TRANSFER_WRITE_BIT specifies write access to an
-- image or buffer in a clear or copy operation.
-- - VK_ACCESS_HOST_READ_BIT specifies read access by a host
-- operation. Accesses of this type are not performed through a resource,
-- but directly on memory.
-- - VK_ACCESS_HOST_WRITE_BIT specifies write access by a host
-- operation. Accesses of this type are not performed through a resource,
-- but directly on memory.
-- - VK_ACCESS_MEMORY_READ_BIT specifies read access via
-- non-specific entities. These entities include the Vulkan device and
-- host, but may also include entities external to the Vulkan
-- device or otherwise not part of the core Vulkan pipeline. When
-- included in a destination access mask, makes all available writes
-- visible to all future read accesses on entities known to the Vulkan
-- device.
-- - VK_ACCESS_MEMORY_WRITE_BIT specifies write access via
-- non-specific entities. These entities include the Vulkan device and
-- host, but may also include entities external to the Vulkan
-- device or otherwise not part of the core Vulkan pipeline. When
-- included in a source access mask, all writes that are performed by
-- entities known to the Vulkan device are made available. When included
-- in a destination access mask, makes all available writes visible to
-- all future write accesses on entities known to the Vulkan device.
-- - VK_ACCESS_COMMAND_PROCESS_READ_BIT_NVX specifies reads
-- from VkBuffer inputs to vkCmdProcessCommandsNVX.
-- - VK_ACCESS_COMMAND_PROCESS_WRITE_BIT_NVX specifies writes
-- to the target command buffer in vkCmdProcessCommandsNVX.
--
--
-- Certain access types are only performed by a subset of pipeline
-- stages. Any synchronization command that takes both stage masks and
-- access masks uses both to define the access scopes - only the
-- specified access types performed by the specified stages are included
-- in the access scope. An application must not specify an access
-- flag in a synchronization command if it does not include a pipeline
-- stage in the corresponding stage mask that is able to perform accesses
-- of that type. The following table lists, for each access flag, which
-- pipeline stages can perform that type of access.
--
--
-- +-----------------------------------+-----------------------------------+
-- | Access flag | Supported pipeline stages |
-- +===================================+===================================+
-- | @VK_ACCESS_INDIRECT_COMMAND_READ_ | @VK_PIPELINE_STAGE_DRAW_INDIRECT_ |
-- | BIT@ | BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_INDEX_READ_BIT@ | @VK_PIPELINE_STAGE_VERTEX_INPUT_B |
-- | | IT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_VERTEX_ATTRIBUTE_READ_ | @VK_PIPELINE_STAGE_VERTEX_INPUT_B |
-- | BIT@ | IT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_UNIFORM_READ_BIT@ | @VK_PIPELINE_STAGE_VERTEX_SHADER_ |
-- | | BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_C |
-- | | ONTROL_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_E |
-- | | VALUATION_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_GEOMETRY_SHADE |
-- | | R_BIT@, |
-- | | @VK_PIPELINE_STAGE_FRAGMENT_SHADE |
-- | | R_BIT@, |
-- | | or |
-- | | @VK_PIPELINE_STAGE_COMPUTE_SHADER |
-- | | _BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_INPUT_ATTACHMENT_READ_ | @VK_PIPELINE_STAGE_FRAGMENT_SHADE |
-- | BIT@ | R_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_SHADER_READ_BIT@ | @VK_PIPELINE_STAGE_VERTEX_SHADER_ |
-- | | BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_C |
-- | | ONTROL_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_E |
-- | | VALUATION_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_GEOMETRY_SHADE |
-- | | R_BIT@, |
-- | | @VK_PIPELINE_STAGE_FRAGMENT_SHADE |
-- | | R_BIT@, |
-- | | or |
-- | | @VK_PIPELINE_STAGE_COMPUTE_SHADER |
-- | | _BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_SHADER_WRITE_BIT@ | @VK_PIPELINE_STAGE_VERTEX_SHADER_ |
-- | | BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_C |
-- | | ONTROL_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_TESSELLATION_E |
-- | | VALUATION_SHADER_BIT@, |
-- | | @VK_PIPELINE_STAGE_GEOMETRY_SHADE |
-- | | R_BIT@, |
-- | | @VK_PIPELINE_STAGE_FRAGMENT_SHADE |
-- | | R_BIT@, |
-- | | or |
-- | | @VK_PIPELINE_STAGE_COMPUTE_SHADER |
-- | | _BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_COLOR_ATTACHMENT_READ_ | @VK_PIPELINE_STAGE_COLOR_ATTACHME |
-- | BIT@ | NT_OUTPUT_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_COLOR_ATTACHMENT_READ_ | @VK_PIPELINE_STAGE_COLOR_ATTACHME |
-- | NONCOHERENT_BIT_EXT@ | NT_OUTPUT_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_COLOR_ATTACHMENT_WRITE | @VK_PIPELINE_STAGE_COLOR_ATTACHME |
-- | _BIT@ | NT_OUTPUT_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_DEPTH_STENCIL_ATTACHME | @VK_PIPELINE_STAGE_EARLY_FRAGMENT |
-- | NT_READ_BIT@ | _TESTS_BIT@, |
-- | | or |
-- | | @VK_PIPELINE_STAGE_LATE_FRAGMENT_ |
-- | | TESTS_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_DEPTH_STENCIL_ATTACHME | @VK_PIPELINE_STAGE_EARLY_FRAGMENT |
-- | NT_WRITE_BIT@ | _TESTS_BIT@, |
-- | | or |
-- | | @VK_PIPELINE_STAGE_LATE_FRAGMENT_ |
-- | | TESTS_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_TRANSFER_READ_BIT@ | @VK_PIPELINE_STAGE_TRANSFER_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_TRANSFER_WRITE_BIT@ | @VK_PIPELINE_STAGE_TRANSFER_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_HOST_READ_BIT@ | @VK_PIPELINE_STAGE_HOST_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_HOST_WRITE_BIT@ | @VK_PIPELINE_STAGE_HOST_BIT@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_MEMORY_READ_BIT@ | N\/A |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_MEMORY_WRITE_BIT@ | N\/A |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_COMMAND_PROCESS_READ_B | @VK_PIPELINE_STAGE_COMMAND_PROCES |
-- | IT_NVX@ | S_BIT_NVX@ |
-- +-----------------------------------+-----------------------------------+
-- | @VK_ACCESS_COMMAND_PROCESS_WRITE_ | @VK_PIPELINE_STAGE_COMMAND_PROCES |
-- | BIT_NVX@ | S_BIT_NVX@ |
-- +-----------------------------------+-----------------------------------+
--
-- Supported access types
--
--
-- If a memory object does not have the
-- VK_MEMORY_PROPERTY_HOST_COHERENT_BIT property, then
-- vkFlushMappedMemoryRanges must be called in order to
-- guarantee that writes to the memory object from the host are made
-- visible to the VK_ACCESS_HOST_WRITE_BIT access type,
-- where it can be further made available to the device by
-- synchronization commands. Similarly,
-- vkInvalidateMappedMemoryRanges must be called to
-- guarantee that writes which are visible to the
-- VK_ACCESS_HOST_READ_BIT access type are made visible
-- to host operations.
--
-- If the memory object does have the
-- VK_MEMORY_PROPERTY_HOST_COHERENT_BIT property flag, writes to
-- the memory object from the host are automatically made visible to the
-- VK_ACCESS_HOST_WRITE_BIT access type. Similarly,
-- writes made visible to the VK_ACCESS_HOST_READ_BIT access
-- type are automatically made visible to the host.
--
-- Note
--
-- The vkQueueSubmit command automatically guarantees that host
-- writes flushed to VK_ACCESS_HOST_WRITE_BIT are made available if
-- they were flushed before the command executed, so in most cases an
-- explicit memory barrier is not needed for this case. In the few
-- circumstances where a submit does not occur between the host write and
-- the device read access, writes can be made available by using
-- an explicit memory barrier.
--
-- See Also
--
-- VkAccessFlags
newtype VkAccessFlagBits
VkAccessFlagBits :: VkFlags -> VkAccessFlagBits
-- | VkSubpassDescriptionFlagBits - Bitmask specifying usage of a subpass
--
-- See Also
--
-- VkSubpassDescriptionFlags
newtype VkSubpassDescriptionFlagBits
VkSubpassDescriptionFlagBits :: VkFlags -> VkSubpassDescriptionFlagBits
-- | VkAttachmentDescriptionFlagBits - Bitmask specifying additional
-- properties of an attachment
--
-- See Also
--
-- VkAttachmentDescriptionFlags
newtype VkAttachmentDescriptionFlagBits
VkAttachmentDescriptionFlagBits :: VkFlags -> VkAttachmentDescriptionFlagBits
-- | VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT specifies that the
-- attachment aliases the same device memory as other attachments.
-- | VkDependencyFlagBits - Bitmask specifying how execution and memory
-- dependencies are formed
--
-- See Also
--
-- VkDependencyFlags
newtype VkDependencyFlagBits
VkDependencyFlagBits :: VkFlags -> VkDependencyFlagBits
-- | VK_DEPENDENCY_BY_REGION_BIT specifies that dependencies will
-- be framebuffer-local.
-- | VkFramebuffer - Opaque handle to a framebuffer object
--
-- Description
--
-- See Also
--
-- VkCommandBufferInheritanceInfo, VkRenderPassBeginInfo,
-- vkCreateFramebuffer, vkDestroyFramebuffer
type VkFramebuffer = Ptr VkFramebuffer_T
-- | vkCreateFramebuffer - Create a new framebuffer object
--
-- Parameters
--
--
-- - device is the logical device that creates the
-- framebuffer.
--
--
--
-- - pCreateInfo points to a VkFramebufferCreateInfo
-- structure which describes additional information about framebuffer
-- creation.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pFramebuffer points to a VkFramebuffer handle in
-- which the resulting framebuffer object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkFramebufferCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pFramebuffer must be a valid pointer to a
-- VkFramebuffer handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkFramebuffer,
-- VkFramebufferCreateInfo
vkCreateFramebuffer :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkFramebufferCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pFramebuffer" ::: Ptr VkFramebuffer) -> IO VkResult
-- | vkDestroyFramebuffer - Destroy a framebuffer object
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- framebuffer.
--
--
--
-- - framebuffer is the handle of the framebuffer to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to framebuffer
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- framebuffer was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- framebuffer was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If framebuffer is not VK_NULL_HANDLE,
-- framebuffer must be a valid VkFramebuffer
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If framebuffer is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to framebuffer must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkFramebuffer
vkDestroyFramebuffer :: ("device" ::: VkDevice) -> ("framebuffer" ::: VkFramebuffer) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkCreateRenderPass - Create a new render pass object
--
-- Parameters
--
--
-- - device is the logical device that creates the render
-- pass.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkRenderPassCreateInfo structure that describes the parameters
-- of the render pass.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pRenderPass points to a VkRenderPass handle in
-- which the resulting render pass object is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkRenderPassCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pRenderPass must be a valid pointer to a
-- VkRenderPass handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkRenderPass,
-- VkRenderPassCreateInfo
vkCreateRenderPass :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkRenderPassCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pRenderPass" ::: Ptr VkRenderPass) -> IO VkResult
-- | vkDestroyRenderPass - Destroy a render pass object
--
-- Parameters
--
--
-- - device is the logical device that destroys the render
-- pass.
--
--
--
-- - renderPass is the handle of the render pass to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to renderPass
-- must have completed execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- renderPass was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- renderPass was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If renderPass is not VK_NULL_HANDLE,
-- renderPass must be a valid VkRenderPass
-- handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If renderPass is a valid handle, it must have been
-- created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to renderPass must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkRenderPass
vkDestroyRenderPass :: ("device" ::: VkDevice) -> ("renderPass" ::: VkRenderPass) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkGetRenderAreaGranularity - Returns the granularity for optimal
-- render area
--
-- Parameters
--
--
-- - device is the logical device that owns the render
-- pass.
--
--
--
-- - renderPass is a handle to a render pass.
-- - pGranularity points to a VkExtent2D structure in
-- which the granularity is returned.
--
--
-- Description
--
-- The conditions leading to an optimal renderArea are:
--
--
-- - the offset.x member in renderArea is a multiple
-- of the width member of the returned VkExtent2D (the
-- horizontal granularity).
-- - the offset.y member in renderArea is a multiple
-- of the height of the returned VkExtent2D (the vertical
-- granularity).
-- - either the offset.width member in renderArea is
-- a multiple of the horizontal granularity or
-- offset.x+offset.width is equal to the width
-- of the framebuffer in the VkRenderPassBeginInfo.
-- - either the offset.height member in renderArea is
-- a multiple of the vertical granularity or
-- offset.y+offset.height is equal to the
-- height of the framebuffer in the
-- VkRenderPassBeginInfo.
--
--
-- Subpass dependencies are not affected by the render area, and apply to
-- the entire image subresources attached to the framebuffer as specified
-- in the description of automatic layout transitions. Similarly,
-- pipeline barriers are valid even if their effect extends outside the
-- render area.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - renderPass must be a valid VkRenderPass
-- handle
-- - pGranularity must be a valid pointer to a
-- VkExtent2D structure
-- - renderPass must have been created, allocated, or
-- retrieved from device
--
--
-- See Also
--
-- VkDevice, VkExtent2D, VkRenderPass
vkGetRenderAreaGranularity :: ("device" ::: VkDevice) -> ("renderPass" ::: VkRenderPass) -> ("pGranularity" ::: Ptr VkExtent2D) -> IO ()
-- | VkAttachmentDescription - Structure specifying an attachment
-- description
--
-- Description
--
-- If the attachment uses a color format, then loadOp and
-- storeOp are used, and stencilLoadOp and
-- stencilStoreOp are ignored. If the format has depth and/or
-- stencil components, loadOp and storeOp apply only to
-- the depth data, while stencilLoadOp and
-- stencilStoreOp define how the stencil data is handled.
-- loadOp and stencilLoadOp define the load
-- operations that execute as part of the first subpass that uses the
-- attachment. storeOp and stencilStoreOp define the
-- store operations that execute as part of the last subpass that
-- uses the attachment.
--
-- The load operation for each sample in an attachment happens-before any
-- recorded command which accesses the sample in the first subpass where
-- the attachment is used. Load operations for attachments with a
-- depth/stencil format execute in the
-- VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT pipeline stage.
-- Load operations for attachments with a color format execute in the
-- VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT pipeline stage.
--
-- The store operation for each sample in an attachment happens-after any
-- recorded command which accesses the sample in the last subpass where
-- the attachment is used. Store operations for attachments with a
-- depth/stencil format execute in the
-- VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT pipeline stage.
-- Store operations for attachments with a color format execute in the
-- VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT pipeline stage.
--
-- If an attachment is not used by any subpass, then loadOp,
-- storeOp, stencilStoreOp, and stencilLoadOp
-- are ignored, and the attachment’s memory contents will not be modified
-- by execution of a render pass instance.
--
-- The load and store operations apply on the first and last use of each
-- view in the render pass, respectively. If a view index of an
-- attachment is not included in the view mask in any subpass that uses
-- it, then the load and store operations are ignored, and the
-- attachment’s memory contents will not be modified by execution of a
-- render pass instance.
--
-- During a render pass instance, input/color attachments with color
-- formats that have a component size of 8, 16, or 32 bits must be
-- represented in the attachment’s format throughout the instance.
-- Attachments with other floating- or fixed-point color formats, or with
-- depth components may be represented in a format with a
-- precision higher than the attachment format, but must be
-- represented with the same range. When such a component is loaded via
-- the loadOp, it will be converted into an
-- implementation-dependent format used by the render pass. Such
-- components must be converted from the render pass format, to
-- the format of the attachment, before they are resolved or stored at
-- the end of a render pass instance via storeOp. Conversions
-- occur as described in Numeric Representation and Computation
-- and Fixed-Point Data Conversions.
--
-- If flags includes
-- VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT, then the attachment
-- is treated as if it shares physical memory with another attachment in
-- the same render pass. This information limits the ability of the
-- implementation to reorder certain operations (like layout transitions
-- and the loadOp) such that it is not improperly reordered
-- against other uses of the same physical memory via a different
-- attachment. This is described in more detail below.
--
-- Valid Usage
--
--
-- - finalLayout must not be
-- VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED
--
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkAttachmentDescriptionFlags, VkAttachmentLoadOp,
-- VkAttachmentStoreOp, VkFormat, VkImageLayout,
-- VkRenderPassCreateInfo, VkSampleCountFlagBits
data VkAttachmentDescription
VkAttachmentDescription :: VkAttachmentDescriptionFlags -> VkFormat -> VkSampleCountFlagBits -> VkAttachmentLoadOp -> VkAttachmentStoreOp -> VkAttachmentLoadOp -> VkAttachmentStoreOp -> VkImageLayout -> VkImageLayout -> VkAttachmentDescription
-- | flags is a bitmask of VkAttachmentDescriptionFlagBits
-- specifying additional properties of the attachment.
[$sel:vkFlags:VkAttachmentDescription] :: VkAttachmentDescription -> VkAttachmentDescriptionFlags
-- | format is a VkFormat value specifying the format of
-- the image that will be used for the attachment.
[$sel:vkFormat:VkAttachmentDescription] :: VkAttachmentDescription -> VkFormat
-- | samples is the number of samples of the image as defined in
-- VkSampleCountFlagBits.
[$sel:vkSamples:VkAttachmentDescription] :: VkAttachmentDescription -> VkSampleCountFlagBits
-- | loadOp is a VkAttachmentLoadOp value specifying how
-- the contents of color and depth components of the attachment are
-- treated at the beginning of the subpass where it is first used.
[$sel:vkLoadOp:VkAttachmentDescription] :: VkAttachmentDescription -> VkAttachmentLoadOp
-- | storeOp is a VkAttachmentStoreOp value specifying how
-- the contents of color and depth components of the attachment are
-- treated at the end of the subpass where it is last used.
[$sel:vkStoreOp:VkAttachmentDescription] :: VkAttachmentDescription -> VkAttachmentStoreOp
-- | stencilLoadOp is a VkAttachmentLoadOp value specifying
-- how the contents of stencil components of the attachment are treated
-- at the beginning of the subpass where it is first used.
[$sel:vkStencilLoadOp:VkAttachmentDescription] :: VkAttachmentDescription -> VkAttachmentLoadOp
-- | stencilStoreOp is a VkAttachmentStoreOp value
-- specifying how the contents of stencil components of the attachment
-- are treated at the end of the last subpass where it is used.
[$sel:vkStencilStoreOp:VkAttachmentDescription] :: VkAttachmentDescription -> VkAttachmentStoreOp
-- | initialLayout is the layout the attachment image subresource
-- will be in when a render pass instance begins.
[$sel:vkInitialLayout:VkAttachmentDescription] :: VkAttachmentDescription -> VkImageLayout
-- | finalLayout is the layout the attachment image subresource
-- will be transitioned to when a render pass instance ends. During a
-- render pass instance, an attachment can use a different layout
-- in each subpass, if desired.
[$sel:vkFinalLayout:VkAttachmentDescription] :: VkAttachmentDescription -> VkImageLayout
-- | VkAttachmentReference - Structure specifying an attachment reference
--
-- Description
--
-- Valid Usage
--
--
-- - layout must not be
-- VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkImageLayout, VkSubpassDescription
data VkAttachmentReference
VkAttachmentReference :: Word32 -> VkImageLayout -> VkAttachmentReference
-- | attachment is the index of the attachment of the render pass,
-- and corresponds to the index of the corresponding element in the
-- pAttachments array of the VkRenderPassCreateInfo
-- structure. If any color or depth/stencil attachments are
-- VK_ATTACHMENT_UNUSED, then no writes occur for those
-- attachments.
[$sel:vkAttachment:VkAttachmentReference] :: VkAttachmentReference -> Word32
-- | layout is a VkImageLayout value specifying the layout
-- the attachment uses during the subpass.
[$sel:vkLayout:VkAttachmentReference] :: VkAttachmentReference -> VkImageLayout
-- | VkSubpassDescription - Structure specifying a subpass description
--
-- Description
--
-- The contents of an attachment within the render area become undefined
-- at the start of a subpass S if all of the following conditions
-- are true:
--
--
-- - The attachment is used as a color, depth/stencil, or resolve
-- attachment in any subpass in the render pass.
-- - There is a subpass S1 that uses or preserves the
-- attachment, and a subpass dependency from S1 to S.
-- - The attachment is not used or preserved in subpass S.
--
--
-- Once the contents of an attachment become undefined in subpass
-- S, they remain undefined for subpasses in subpass dependency
-- chains starting with subpass S until they are written again.
-- However, they remain valid for subpasses in other subpass dependency
-- chains starting with subpass S1 if those subpasses use or
-- preserve the attachment.
--
-- Valid Usage
--
--
-- - pipelineBindPoint must be
-- VK_PIPELINE_BIND_POINT_GRAPHICS
--
--
--
-- - colorAttachmentCount must be less than or equal to
-- VkPhysicalDeviceLimits::maxColorAttachments
-- - 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 loadOp
-- must not be VK_ATTACHMENT_LOAD_OP_CLEAR
-- - If pResolveAttachments is not NULL, for each
-- resolve attachment that does not have the value
-- VK_ATTACHMENT_UNUSED, the corresponding color attachment
-- must not have the value VK_ATTACHMENT_UNUSED
-- - If pResolveAttachments is not NULL, the sample
-- count of each element of pColorAttachments must be
-- anything other than VK_SAMPLE_COUNT_1_BIT
-- - Each element of pResolveAttachments must have a
-- sample count of VK_SAMPLE_COUNT_1_BIT
-- - Each element of pResolveAttachments must have the
-- same VkFormat as its corresponding color attachment
-- - All attachments in pColorAttachments that are not
-- VK_ATTACHMENT_UNUSED must have the same sample
-- count
-- - All attachments in pColorAttachments that are not
-- VK_ATTACHMENT_UNUSED must have a sample count that is
-- smaller than or equal to the sample count of
-- pDepthStencilAttachment if it is not
-- VK_ATTACHMENT_UNUSED
-- - If any input attachments are VK_ATTACHMENT_UNUSED, then
-- any pipelines bound during the subpass must not access those
-- input attachments from the fragment shader
-- - The attachment member of each element of
-- pPreserveAttachments must not be
-- VK_ATTACHMENT_UNUSED
-- - Each element of pPreserveAttachments must not also
-- be an element of any other member of the subpass description
-- - If any attachment is used as both an input attachment and a color
-- or depth/stencil attachment, then each use must use the same
-- layout
-- - If flags includes
-- VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX, it
-- must also include
-- VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX.
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - If inputAttachmentCount is not 0,
-- pInputAttachments must be a valid pointer to an array
-- of inputAttachmentCount valid VkAttachmentReference
-- structures
-- - If colorAttachmentCount is not 0,
-- pColorAttachments must be a valid pointer to an array
-- of colorAttachmentCount valid VkAttachmentReference
-- structures
-- - If colorAttachmentCount is not 0, and
-- pResolveAttachments is not NULL,
-- pResolveAttachments must be a valid pointer to an
-- array of colorAttachmentCount valid
-- VkAttachmentReference structures
-- - If pDepthStencilAttachment is not NULL,
-- pDepthStencilAttachment must be a valid pointer to a
-- valid VkAttachmentReference structure
-- - If preserveAttachmentCount is not 0,
-- pPreserveAttachments must be a valid pointer to an
-- array of preserveAttachmentCount uint32_t
-- values
--
--
-- See Also
--
-- VkAttachmentReference, VkPipelineBindPoint,
-- VkRenderPassCreateInfo, VkSubpassDescriptionFlags
data VkSubpassDescription
VkSubpassDescription :: VkSubpassDescriptionFlags -> VkPipelineBindPoint -> Word32 -> Ptr VkAttachmentReference -> Word32 -> Ptr VkAttachmentReference -> Ptr VkAttachmentReference -> Ptr VkAttachmentReference -> Word32 -> Ptr Word32 -> VkSubpassDescription
-- | flags is a bitmask of VkSubpassDescriptionFlagBits
-- specifying usage of the subpass.
[$sel:vkFlags:VkSubpassDescription] :: VkSubpassDescription -> VkSubpassDescriptionFlags
-- | pipelineBindPoint is a VkPipelineBindPoint value
-- specifying whether this is a compute or graphics subpass. Currently,
-- only graphics subpasses are supported.
[$sel:vkPipelineBindPoint:VkSubpassDescription] :: VkSubpassDescription -> VkPipelineBindPoint
-- | inputAttachmentCount is the number of input attachments.
[$sel:vkInputAttachmentCount:VkSubpassDescription] :: VkSubpassDescription -> Word32
-- | pInputAttachments is an array of VkAttachmentReference
-- structures (defined below) that lists which of the render pass’s
-- attachments can be read in the fragment shader stage during the
-- subpass, and what layout each attachment will be in during the
-- subpass. Each element of the array corresponds to an input attachment
-- unit number in the shader, i.e. if the shader declares an input
-- variable layout(input_attachment_index=X, set=Y, binding=Z)
-- then it uses the attachment provided in pInputAttachments[X].
-- Input attachments must also be bound to the pipeline with a
-- descriptor set, with the input attachment descriptor written in the
-- location (set=Y, binding=Z). Fragment shaders can use subpass
-- input variables to access the contents of an input attachment at the
-- fragment’s (x, y, layer) framebuffer coordinates.
[$sel:vkPInputAttachments:VkSubpassDescription] :: VkSubpassDescription -> Ptr VkAttachmentReference
-- | colorAttachmentCount is the number of color attachments.
[$sel:vkColorAttachmentCount:VkSubpassDescription] :: VkSubpassDescription -> Word32
-- | pColorAttachments is an array of
-- colorAttachmentCount VkAttachmentReference structures
-- that lists which of the render pass’s attachments will be used as
-- color attachments in the subpass, and what layout each attachment will
-- be in during the subpass. Each element of the array corresponds to a
-- fragment shader output location, i.e. if the shader declared an output
-- variable layout(location=X) then it uses the attachment
-- provided in pColorAttachments[X].
[$sel:vkPColorAttachments:VkSubpassDescription] :: VkSubpassDescription -> Ptr VkAttachmentReference
-- | pResolveAttachments is NULL or an array of
-- colorAttachmentCount VkAttachmentReference structures
-- that lists which of the render pass’s attachments are resolved to at
-- the end of the subpass, and what layout each attachment will be in
-- during the multisample resolve operation. If
-- pResolveAttachments is not NULL, each of its
-- elements corresponds to a color attachment (the element in
-- pColorAttachments at the same index), and a multisample
-- resolve operation is defined for each attachment. At the end of each
-- subpass, multisample resolve operations read the subpass’s color
-- attachments, and resolve the samples for each pixel to the same pixel
-- location in the corresponding resolve attachments, unless the resolve
-- attachment index is VK_ATTACHMENT_UNUSED. If the first use of
-- an attachment in a render pass is as a resolve attachment, then the
-- loadOp is effectively ignored as the resolve is guaranteed to
-- overwrite all pixels in the render area.
[$sel:vkPResolveAttachments:VkSubpassDescription] :: VkSubpassDescription -> Ptr VkAttachmentReference
-- | pDepthStencilAttachment is a pointer to a
-- VkAttachmentReference specifying which attachment will be used
-- for depth/stencil data and the layout it will be in during the
-- subpass. Setting the attachment index to VK_ATTACHMENT_UNUSED
-- or leaving this pointer as NULL indicates that no
-- depth/stencil attachment will be used in the subpass.
[$sel:vkPDepthStencilAttachment:VkSubpassDescription] :: VkSubpassDescription -> Ptr VkAttachmentReference
-- | preserveAttachmentCount is the number of preserved
-- attachments.
[$sel:vkPreserveAttachmentCount:VkSubpassDescription] :: VkSubpassDescription -> Word32
-- | pPreserveAttachments is an array of
-- preserveAttachmentCount render pass attachment indices
-- describing the attachments that are not used by a subpass, but whose
-- contents must be preserved throughout the subpass.
[$sel:vkPPreserveAttachments:VkSubpassDescription] :: VkSubpassDescription -> Ptr Word32
-- | VkSubpassDependency - Structure specifying a subpass dependency
--
-- Description
--
-- If srcSubpass is equal to dstSubpass then the
-- VkSubpassDependency describes a subpass self-dependency,
-- and only constrains the pipeline barriers allowed within a subpass
-- instance. Otherwise, when a render pass instance which includes a
-- subpass dependency is submitted to a queue, it defines a memory
-- dependency between the subpasses identified by srcSubpass and
-- dstSubpass.
--
-- If srcSubpass is equal to VK_SUBPASS_EXTERNAL, the
-- first synchronization scope includes commands that occur
-- earlier in submission order than the
-- vkCmdBeginRenderPass used to begin the render pass instance.
-- Otherwise, the first set of commands includes all commands submitted
-- as part of the subpass instance identified by srcSubpass and
-- any load, store or multisample resolve operations on attachments used
-- in srcSubpass. In either case, the first synchronization
-- scope is limited to operations on the pipeline stages determined by
-- the source stage mask specified by srcStageMask.
--
-- If dstSubpass is equal to VK_SUBPASS_EXTERNAL, the
-- second synchronization scope includes commands that occur later
-- in submission order than the vkCmdEndRenderPass used to
-- end the render pass instance. Otherwise, the second set of commands
-- includes all commands submitted as part of the subpass instance
-- identified by dstSubpass and any load, store or multisample
-- resolve operations on attachments used in dstSubpass. In
-- either case, the second synchronization scope is limited to operations
-- on the pipeline stages determined by the destination stage mask
-- specified by dstStageMask.
--
-- The first access scope is limited to access in the pipeline
-- stages determined by the source stage mask specified by
-- srcStageMask. It is also limited to access types in the
-- source access mask specified by srcAccessMask.
--
-- The second access scope is limited to access in the pipeline
-- stages determined by the destination stage mask specified by
-- dstStageMask. It is also limited to access types in the
-- destination access mask specified by dstAccessMask.
--
-- The availability and visibility operations defined by a subpass
-- dependency affect the execution of image layout transitions
-- within the render pass.
--
-- Note
--
-- For non-attachment resources, the memory dependency expressed by
-- subpass dependency is nearly identical to that of a
-- VkMemoryBarrier (with matching
-- srcAccessMask/dstAccessMask parameters) submitted as
-- a part of a vkCmdPipelineBarrier (with matching
-- srcStageMask/dstStageMask parameters). The only
-- difference being that its scopes are limited to the identified
-- subpasses rather than potentially affecting everything before and
-- after.
--
-- For attachments however, subpass dependencies work more like an
-- VkImageMemoryBarrier defined similarly to the
-- VkMemoryBarrier above, the queue family indices set to
-- VK_QUEUE_FAMILY_IGNORED, and layouts as follows:
--
--
-- - The equivalent to oldLayout is the attachment’s layout
-- according to the subpass description for srcSubpass.
-- - The equivalent to newLayout is the attachment’s layout
-- according to the subpass description for dstSubpass.
--
--
-- Valid Usage
--
--
-- - If srcSubpass is not VK_SUBPASS_EXTERNAL,
-- srcStageMask must not include
-- VK_PIPELINE_STAGE_HOST_BIT
--
--
--
-- - If dstSubpass is not VK_SUBPASS_EXTERNAL,
-- dstStageMask must not include
-- VK_PIPELINE_STAGE_HOST_BIT
-- - If the geometry shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the geometry shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - srcSubpass must be less than or equal to
-- dstSubpass, unless one of them is
-- VK_SUBPASS_EXTERNAL, to avoid cyclic dependencies and ensure
-- a valid execution order
-- - srcSubpass and dstSubpass must not both
-- be equal to VK_SUBPASS_EXTERNAL
-- - If srcSubpass is equal to dstSubpass,
-- srcStageMask and dstStageMask must only
-- contain one of VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
-- VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT,
-- VK_PIPELINE_STAGE_VERTEX_INPUT_BIT,
-- VK_PIPELINE_STAGE_VERTEX_SHADER_BIT,
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT,
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT,
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT,
-- VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT,
-- VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT,
-- VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT,
-- VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
-- VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT, or
-- VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT
-- - If srcSubpass is equal to dstSubpass and not all
-- of the stages in srcStageMask and dstStageMask are
-- framebuffer-space stages, the logically latest pipeline
-- stage in srcStageMask must be logically earlier
-- than or equal to the logically earliest pipeline stage in
-- dstStageMask
-- - Any access flag included in srcAccessMask must be
-- supported by one of the pipeline stages in srcStageMask, as
-- specified in the table of supported access types.
-- - Any access flag included in dstAccessMask must be
-- supported by one of the pipeline stages in dstStageMask, as
-- specified in the table of supported access types.
-- - If dependencyFlags includes
-- VK_DEPENDENCY_VIEW_LOCAL_BIT, then both srcSubpass
-- and dstSubpass must not equal
-- VK_SUBPASS_EXTERNAL
-- - If dependencyFlags includes
-- VK_DEPENDENCY_VIEW_LOCAL_BIT, then the render pass
-- must have multiview enabled
-- - If srcSubpass equals dstSubpass and that subpass
-- has more than one bit set in the view mask, then
-- dependencyFlags must include
-- VK_DEPENDENCY_VIEW_LOCAL_BIT
--
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkAccessFlags, VkDependencyFlags,
-- VkPipelineStageFlags, VkRenderPassCreateInfo
data VkSubpassDependency
VkSubpassDependency :: Word32 -> Word32 -> VkPipelineStageFlags -> VkPipelineStageFlags -> VkAccessFlags -> VkAccessFlags -> VkDependencyFlags -> VkSubpassDependency
-- | srcSubpass is the subpass index of the first subpass in the
-- dependency, or VK_SUBPASS_EXTERNAL.
[$sel:vkSrcSubpass:VkSubpassDependency] :: VkSubpassDependency -> Word32
-- | dstSubpass is the subpass index of the second subpass in the
-- dependency, or VK_SUBPASS_EXTERNAL.
[$sel:vkDstSubpass:VkSubpassDependency] :: VkSubpassDependency -> Word32
-- | srcStageMask is a bitmask of VkPipelineStageFlagBits
-- specifying the source stage mask.
[$sel:vkSrcStageMask:VkSubpassDependency] :: VkSubpassDependency -> VkPipelineStageFlags
-- | dstStageMask is a bitmask of VkPipelineStageFlagBits
-- specifying the destination stage mask
[$sel:vkDstStageMask:VkSubpassDependency] :: VkSubpassDependency -> VkPipelineStageFlags
-- | srcAccessMask is a bitmask of VkAccessFlagBits
-- specifying a source access mask.
[$sel:vkSrcAccessMask:VkSubpassDependency] :: VkSubpassDependency -> VkAccessFlags
-- | dstAccessMask is a bitmask of VkAccessFlagBits
-- specifying a destination access mask.
[$sel:vkDstAccessMask:VkSubpassDependency] :: VkSubpassDependency -> VkAccessFlags
-- | dependencyFlags is a bitmask of VkDependencyFlagBits.
[$sel:vkDependencyFlags:VkSubpassDependency] :: VkSubpassDependency -> VkDependencyFlags
-- | VkRenderPassCreateInfo - Structure specifying parameters of a newly
-- created render pass
--
-- Description
--
-- Valid Usage
--
--
-- - If any two subpasses operate on attachments with overlapping
-- ranges of the same VkDeviceMemory object, and at least one
-- subpass writes to that area of VkDeviceMemory, a subpass
-- dependency must be included (either directly or via some
-- intermediate subpasses) between them
--
--
--
-- - If the attachment member of any element of
-- pInputAttachments, pColorAttachments,
-- pResolveAttachments or pDepthStencilAttachment, or
-- the attachment indexed by any element of pPreserveAttachments
-- in any element of pSubpasses is bound to a range of a
-- VkDeviceMemory object that overlaps with any other attachment
-- in any subpass (including the same subpass), the
-- VkAttachmentDescription structures describing them
-- must include VK_ATTACHMENT_DESCRIPTION_MAY_ALIAS_BIT
-- in flags
-- - If the attachment member of any element of
-- pInputAttachments, pColorAttachments,
-- pResolveAttachments or pDepthStencilAttachment, or
-- any element of pPreserveAttachments in any element of
-- pSubpasses is not VK_ATTACHMENT_UNUSED, it
-- must be less than attachmentCount
-- - The value of each element of the pPreserveAttachments
-- member in each element of pSubpasses must not be
-- VK_ATTACHMENT_UNUSED
-- - For any member of pAttachments with a loadOp
-- equal to VK_ATTACHMENT_LOAD_OP_CLEAR, the first use of that
-- attachment must not specify a layout equal to
-- VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL or
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL.
-- - For any member of pAttachments with a loadOp
-- equal to VK_ATTACHMENT_LOAD_OP_CLEAR, the first use of that
-- attachment must not specify a layout equal to
-- VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL.
-- - For any member of pAttachments with a
-- stencilLoadOp equal to VK_ATTACHMENT_LOAD_OP_CLEAR,
-- the first use of that attachment must not specify a
-- layout equal to
-- VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL.
-- - For any element of pDependencies, if the
-- srcSubpass is not VK_SUBPASS_EXTERNAL, all stage
-- flags included in the srcStageMask member of that dependency
-- must be a pipeline stage supported by the pipeline
-- identified by the pipelineBindPoint member of the source
-- subpass.
-- - For any element of pDependencies, if the
-- dstSubpass is not VK_SUBPASS_EXTERNAL, all stage
-- flags included in the dstStageMask member of that dependency
-- must be a pipeline stage supported by the pipeline
-- identified by the pipelineBindPoint member of the source
-- subpass.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of
-- VkRenderPassInputAttachmentAspectCreateInfo or
-- VkRenderPassMultiviewCreateInfo
-- - Each sType member in the pNext chain must
-- be unique
-- - flags must be 0
-- - If attachmentCount is not 0,
-- pAttachments must be a valid pointer to an array of
-- attachmentCount valid VkAttachmentDescription
-- structures
-- - pSubpasses must be a valid pointer to an array of
-- subpassCount valid VkSubpassDescription
-- structures
-- - If dependencyCount is not 0,
-- pDependencies must be a valid pointer to an array of
-- dependencyCount valid VkSubpassDependency
-- structures
-- - subpassCount must be greater than 0
--
--
-- See Also
--
-- VkAttachmentDescription, VkRenderPassCreateFlags,
-- VkStructureType, VkSubpassDependency,
-- VkSubpassDescription, vkCreateRenderPass
data VkRenderPassCreateInfo
VkRenderPassCreateInfo :: VkStructureType -> Ptr () -> VkRenderPassCreateFlags -> Word32 -> Ptr VkAttachmentDescription -> Word32 -> Ptr VkSubpassDescription -> Word32 -> Ptr VkSubpassDependency -> VkRenderPassCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> VkRenderPassCreateFlags
-- | attachmentCount is the number of attachments used by this
-- render pass, or zero indicating no attachments. Attachments are
-- referred to by zero-based indices in the range
-- [0,attachmentCount).
[$sel:vkAttachmentCount:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Word32
-- | pAttachments points to an array of attachmentCount
-- number of VkAttachmentDescription structures describing
-- properties of the attachments, or NULL if
-- attachmentCount is zero.
[$sel:vkPAttachments:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Ptr VkAttachmentDescription
-- | subpassCount is the number of subpasses to create for this
-- render pass. Subpasses are referred to by zero-based indices in the
-- range [0,subpassCount). A render pass must have at
-- least one subpass.
[$sel:vkSubpassCount:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Word32
-- | pSubpasses points to an array of subpassCount number
-- of VkSubpassDescription structures describing properties of the
-- subpasses.
[$sel:vkPSubpasses:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Ptr VkSubpassDescription
-- | dependencyCount is the number of dependencies between pairs
-- of subpasses, or zero indicating no dependencies.
[$sel:vkDependencyCount:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Word32
-- | pDependencies points to an array of dependencyCount
-- number of VkSubpassDependency structures describing
-- dependencies between pairs of subpasses, or NULL if
-- dependencyCount is zero.
[$sel:vkPDependencies:VkRenderPassCreateInfo] :: VkRenderPassCreateInfo -> Ptr VkSubpassDependency
-- | VkFramebufferCreateInfo - Structure specifying parameters of a newly
-- created framebuffer
--
-- Description
--
-- Applications must ensure that all accesses to memory that backs
-- image subresources used as attachments in a given renderpass instance
-- either happen-before the load operations for those attachments,
-- or happen-after the store operations for those attachments.
--
-- For depth/stencil attachments, each aspect can be used
-- separately as attachments and non-attachments as long as the
-- non-attachment accesses are also via an image subresource in either
-- the
-- VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
-- layout or the
-- VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
-- layout, and the attachment resource uses whichever of those two
-- layouts the image accesses do not. Use of non-attachment aspects in
-- this case is only well defined if the attachment is used in the
-- subpass where the non-attachment access is being made, or the layout
-- of the image subresource is constant throughout the entire render pass
-- instance, including the initialLayout and
-- finalLayout.
--
-- Note
--
-- These restrictions mean that the render pass has full knowledge of all
-- uses of all of the attachments, so that the implementation is able to
-- make correct decisions about when and how to perform layout
-- transitions, when to overlap execution of subpasses, etc.
--
-- It is legal for a subpass to use no color or depth/stencil
-- attachments, and rather use shader side effects such as image stores
-- and atomics to produce an output. In this case, the subpass continues
-- to use the width, height, and layers of the
-- framebuffer to define the dimensions of the rendering area, and the
-- rasterizationSamples from each pipeline’s
-- VkPipelineMultisampleStateCreateInfo to define the number of
-- samples used in rasterization; however, if
-- VkPhysicalDeviceFeatures::variableMultisampleRate is
-- VK_FALSE, then all pipelines to be bound with a given
-- zero-attachment subpass must have the same value for
-- VkPipelineMultisampleStateCreateInfo::rasterizationSamples.
--
-- Valid Usage
--
--
-- - attachmentCount must be equal to the attachment
-- count specified in renderPass
--
--
--
-- - Each element of pAttachments that is used as a color
-- attachment or resolve attachment by renderPass must
-- have been created with a usage value including
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT
-- - Each element of pAttachments that is used as a
-- depth/stencil attachment by renderPass must have been
-- created with a usage value including
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT
-- - Each element of pAttachments that is used as an input
-- attachment by renderPass must have been created with a
-- usage value including
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT
-- - Each element of pAttachments must have been
-- created with an VkFormat value that matches the VkFormat
-- specified by the corresponding VkAttachmentDescription in
-- renderPass
-- - Each element of pAttachments must have been
-- created with a samples value that matches the
-- samples value specified by the corresponding
-- VkAttachmentDescription in renderPass
-- - Each element of pAttachments must have dimensions
-- at least as large as the corresponding framebuffer dimension
-- - Each element of pAttachments must only specify a
-- single mip level
-- - Each element of pAttachments must have been
-- created with the identity swizzle
-- - width must be greater than 0.
-- - width must be less than or equal to
-- VkPhysicalDeviceLimits::maxFramebufferWidth
-- - height must be greater than 0.
-- - height must be less than or equal to
-- VkPhysicalDeviceLimits::maxFramebufferHeight
-- - layers must be greater than 0.
-- - layers must be less than or equal to
-- VkPhysicalDeviceLimits::maxFramebufferLayers
-- - Each element of pAttachments that is a 2D or 2D array
-- image view taken from a 3D image must not be a depth/stencil
-- format
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - renderPass must be a valid VkRenderPass
-- handle
-- - If attachmentCount is not 0,
-- pAttachments must be a valid pointer to an array of
-- attachmentCount valid VkImageView handles
-- - Both of renderPass, and the elements of
-- pAttachments that are valid handles must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkFramebufferCreateFlags, VkImageView,
-- VkRenderPass, VkStructureType,
-- vkCreateFramebuffer
data VkFramebufferCreateInfo
VkFramebufferCreateInfo :: VkStructureType -> Ptr () -> VkFramebufferCreateFlags -> VkRenderPass -> Word32 -> Ptr VkImageView -> Word32 -> Word32 -> Word32 -> VkFramebufferCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> VkFramebufferCreateFlags
-- | renderPass is a render pass that defines what render passes
-- the framebuffer will be compatible with. See Render Pass
-- Compatibility for details.
[$sel:vkRenderPass:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> VkRenderPass
-- | attachmentCount is the number of attachments.
[$sel:vkAttachmentCount:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Word32
-- | pAttachments is an array of VkImageView handles,
-- each of which will be used as the corresponding attachment in a render
-- pass instance.
[$sel:vkPAttachments:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Ptr VkImageView
-- | width, height and layers define the
-- dimensions of the framebuffer. If the render pass uses multiview, then
-- layers must be one and each attachment requires a
-- number of layers that is greater than the maximum bit index set in the
-- view mask in the subpasses in which it is used.
[$sel:vkWidth:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Word32
[$sel:vkHeight:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Word32
[$sel:vkLayers:VkFramebufferCreateInfo] :: VkFramebufferCreateInfo -> Word32
-- | VkAccessFlags - Bitmask of VkAccessFlagBits
--
-- Description
--
-- VkAccessFlags is a bitmask type for setting a mask of zero or
-- more VkAccessFlagBits.
--
-- See Also
--
-- VkAccessFlagBits, VkBufferMemoryBarrier,
-- VkImageMemoryBarrier, VkMemoryBarrier,
-- VkSubpassDependency
type VkAccessFlags = VkAccessFlagBits
-- | VkSubpassDescriptionFlags - Bitmask of VkSubpassDescriptionFlagBits
--
-- Description
--
-- VkSubpassDescriptionFlags is a bitmask type for setting a
-- mask of zero or more VkSubpassDescriptionFlagBits.
--
-- See Also
--
-- VkSubpassDescription, VkSubpassDescriptionFlagBits
type VkSubpassDescriptionFlags = VkSubpassDescriptionFlagBits
-- | VkAttachmentDescriptionFlags - Bitmask of
-- VkAttachmentDescriptionFlagBits
--
-- Description
--
-- VkAttachmentDescriptionFlags is a bitmask type for setting a
-- mask of zero or more VkAttachmentDescriptionFlagBits.
--
-- See Also
--
-- VkAttachmentDescription, VkAttachmentDescriptionFlagBits
type VkAttachmentDescriptionFlags = VkAttachmentDescriptionFlagBits
-- | VkDependencyFlags - Bitmask of VkDependencyFlagBits
--
-- Description
--
-- VkDependencyFlags is a bitmask type for setting a mask of
-- zero or more VkDependencyFlagBits.
--
-- See Also
--
-- VkDependencyFlagBits, VkSubpassDependency,
-- vkCmdPipelineBarrier
type VkDependencyFlags = VkDependencyFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkRenderPassCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkRenderPassCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkSubpassDependency
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkSubpassDependency
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAttachmentDescription
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAttachmentDescription
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkSubpassDescription
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkSubpassDescription
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkFramebufferCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkFramebufferCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAttachmentReference
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAttachmentReference
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkPipelineBindPoint
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkPipelineBindPoint
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkPipelineBindPoint
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAttachmentStoreOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkAttachmentStoreOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAttachmentStoreOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAttachmentLoadOp
instance GHC.Classes.Ord Graphics.Vulkan.Core10.Pass.VkAttachmentLoadOp
instance GHC.Classes.Eq Graphics.Vulkan.Core10.Pass.VkAttachmentLoadOp
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkRenderPassCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkSubpassDependency
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAttachmentDescription
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkSubpassDescription
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkFramebufferCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.Pass.VkAttachmentReference
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkDependencyFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkAttachmentDescriptionFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkSubpassDescriptionFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkAccessFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkRenderPassCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkFramebufferCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkPipelineBindPoint
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkPipelineBindPoint
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAttachmentStoreOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkAttachmentStoreOp
instance GHC.Show.Show Graphics.Vulkan.Core10.Pass.VkAttachmentLoadOp
instance GHC.Read.Read Graphics.Vulkan.Core10.Pass.VkAttachmentLoadOp
module Graphics.Vulkan.Extensions.VK_NVX_multiview_per_view_attributes
-- | VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX specifies
-- that shaders compiled for this subpass write the attributes for all
-- views in a single invocation of each vertex processing stage. All
-- pipelines compiled against a subpass that includes this bit
-- must write per-view attributes to the code:*PerViewNV[] shader
-- outputs, in addition to the non-per-view (e.g. Position)
-- outputs.
-- | VK_SUBPASS_DESCRIPTION_PER_VIEW_POSITION_X_ONLY_BIT_NVX
-- specifies that shaders compiled for this subpass use per-view
-- positions which only differ in value in the x component. Per-view
-- viewport mask can also be used.
-- | VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX - Structure
-- describing multiview limits that can be supported by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - perViewPositionAllComponents is VK_TRUE if the
-- implementation supports per-view position values that differ in
-- components other than the X component.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PER_VIEW_ATTRIBUTES_PROPERTIES_NVX
--
--
-- If the
-- VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
[$sel:vkSType:VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX] :: VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX] :: VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX -> Ptr ()
[$sel:vkPerViewPositionAllComponents:VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX] :: VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_multiview_per_view_attributes.VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_multiview_per_view_attributes.VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_multiview_per_view_attributes.VkPhysicalDeviceMultiviewPerViewAttributesPropertiesNVX
module Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced
-- | VkBlendOverlapEXT - Enumerant specifying the blend overlap parameter
--
-- Description
--
--
-- - VK_BLEND_OVERLAP_UNCORRELATED_EXT specifies that there is
-- no correlation between the source and destination coverage.
--
--
--
-- - VK_BLEND_OVERLAP_CONJOINT_EXT specifies that the source
-- and destination coverage are considered to have maximal overlap.
-- - VK_BLEND_OVERLAP_DISJOINT_EXT specifies that the source
-- and destination coverage are considered to have minimal overlap.
--
--
--
-- +-----------------------------------+-----------------------------------+
-- | Overlap Mode | Weighting Equations |
-- +===================================+===================================+
-- | @VK_BLEND_OVERLAP_UNCORRELATED_EX | \\[ |
-- | T@ | \\begin{aligned} |
-- | | |
-- | | p_0(A_s,A_d) & = A |
-- | | _sA_d \\\\ |
-- | | |
-- | | p_1(A_s,A_d) & = A |
-- | | _s(1-A_d) \\\\ |
-- | | |
-- | | p_2(A_s,A_d) & = A |
-- | | _d(1-A_s) \\\\ |
-- | | |
-- | | \\end{aligned}\\] |
-- +-----------------------------------+-----------------------------------+
-- | @VK_BLEND_OVERLAP_CONJOINT_EXT@ | \\[ |
-- | | \\begin{aligned} |
-- | | |
-- | | p_0(A_s,A_d) & = m |
-- | | in(A_s,A_d) \\\\ |
-- | | |
-- | | p_1(A_s,A_d) & = m |
-- | | ax(A_s-A_d,0) \\\\ |
-- | | |
-- | | p_2(A_s,A_d) & = m |
-- | | ax(A_d-A_s,0) \\\\ |
-- | | |
-- | | \\end{aligned}\\] |
-- +-----------------------------------+-----------------------------------+
-- | @VK_BLEND_OVERLAP_DISJOINT_EXT@ | \\[ |
-- | | \\begin{aligned} |
-- | | |
-- | | p_0(A_s,A_d) & = m |
-- | | ax(A_s+A_d-1,0) \\\\ |
-- | | |
-- | | p_1(A_s,A_d) & = m |
-- | | in(A_s,1-A_d) \\\\ |
-- | | |
-- | | p_2(A_s,A_d) & = m |
-- | | in(A_d,1-A_s) \\\\ |
-- | | |
-- | | \\end{aligned}\\] |
-- +-----------------------------------+-----------------------------------+
--
-- Advanced Blend Overlap Modes
--
--
-- See Also
--
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT
newtype VkBlendOverlapEXT
VkBlendOverlapEXT :: Int32 -> VkBlendOverlapEXT
-- | VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT - Structure
-- describing advanced blending features that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT structure
-- describe the following features:
--
-- Description
--
--
-- - advancedBlendCoherentOperations specifies whether
-- blending using advanced blend operations is guaranteed to
-- execute atomically and in primitive order. If this is
-- VK_TRUE,
-- VK_ACCESS_COLOR_ATTACHMENT_READ_NONCOHERENT_BIT_EXT is
-- treated the same as VK_ACCESS_COLOR_ATTACHMENT_READ_BIT, and
-- advanced blending needs no additional synchronization over basic
-- blending. If this is VK_FALSE, then memory dependencies are
-- required to guarantee order between two advanced blending operations
-- that occur on the same sample.
--
--
-- If the VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceFeatures2, it is filled with values indicating
-- whether each feature is supported.
-- VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT can
-- also be used in pNext chain of VkDeviceCreateInfo to
-- enable the features.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_FEATURES_EXT
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT :: VkStructureType -> Ptr () -> VkBool32 -> VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
[$sel:vkSType:VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT] :: VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT] :: VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT -> Ptr ()
[$sel:vkAdvancedBlendCoherentOperations:VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT] :: VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT -> VkBool32
-- | VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT - Structure
-- describing advanced blending limits that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - advancedBlendMaxColorAttachments is one greater than the
-- highest color attachment index that can be used in a subpass,
-- for a pipeline that uses an advanced blend operation.
--
--
--
-- - advancedBlendIndependentBlend specifies whether advanced
-- blend operations can vary per-attachment.
-- - advancedBlendNonPremultipliedSrcColor specifies whether
-- the source color can be treated as non-premultiplied. If this
-- is VK_FALSE, then
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT::srcPremultiplied
-- must be VK_TRUE.
-- - advancedBlendNonPremultipliedDstColor specifies whether
-- the destination color can be treated as non-premultiplied. If
-- this is VK_FALSE, then
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT::dstPremultiplied
-- must be VK_TRUE.
-- - advancedBlendCorrelatedOverlap specifies whether the
-- overlap mode can be treated as correlated. If this is
-- VK_FALSE, then
-- VkPipelineColorBlendAdvancedStateCreateInfoEXT::blendOverlap
-- must be VK_BLEND_OVERLAP_UNCORRELATED_EXT.
-- - advancedBlendAllOperations specifies whether all advanced
-- blend operation enums are supported. See the valid usage of
-- VkPipelineColorBlendAttachmentState.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_BLEND_OPERATION_ADVANCED_PROPERTIES_EXT
--
--
-- If the VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT :: VkStructureType -> Ptr () -> Word32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> Ptr ()
[$sel:vkAdvancedBlendMaxColorAttachments:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> Word32
[$sel:vkAdvancedBlendIndependentBlend:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkBool32
[$sel:vkAdvancedBlendNonPremultipliedSrcColor:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkBool32
[$sel:vkAdvancedBlendNonPremultipliedDstColor:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkBool32
[$sel:vkAdvancedBlendCorrelatedOverlap:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkBool32
[$sel:vkAdvancedBlendAllOperations:VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT] :: VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT -> VkBool32
-- | VkPipelineColorBlendAdvancedStateCreateInfoEXT - Structure specifying
-- parameters that affect advanced blend operations
--
-- Description
--
-- If this structure is not present, srcPremultiplied and
-- dstPremultiplied are both considered to be VK_TRUE,
-- and blendOverlap is considered to be
-- VK_BLEND_OVERLAP_UNCORRELATED_EXT.
--
-- Valid Usage
--
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_ADVANCED_STATE_CREATE_INFO_EXT
--
--
--
--
-- See Also
--
-- VkBlendOverlapEXT, VkBool32, VkStructureType
data VkPipelineColorBlendAdvancedStateCreateInfoEXT
VkPipelineColorBlendAdvancedStateCreateInfoEXT :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkBlendOverlapEXT -> VkPipelineColorBlendAdvancedStateCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkPipelineColorBlendAdvancedStateCreateInfoEXT] :: VkPipelineColorBlendAdvancedStateCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkPipelineColorBlendAdvancedStateCreateInfoEXT] :: VkPipelineColorBlendAdvancedStateCreateInfoEXT -> Ptr ()
-- | srcPremultiplied specifies whether the source color of the
-- blend operation is treated as premultiplied.
[$sel:vkSrcPremultiplied:VkPipelineColorBlendAdvancedStateCreateInfoEXT] :: VkPipelineColorBlendAdvancedStateCreateInfoEXT -> VkBool32
-- | dstPremultiplied specifies whether the destination color of
-- the blend operation is treated as premultiplied.
[$sel:vkDstPremultiplied:VkPipelineColorBlendAdvancedStateCreateInfoEXT] :: VkPipelineColorBlendAdvancedStateCreateInfoEXT -> VkBool32
-- | blendOverlap is a VkBlendOverlapEXT value specifying
-- how the source and destination sample’s coverage is correlated.
[$sel:vkBlendOverlap:VkPipelineColorBlendAdvancedStateCreateInfoEXT] :: VkPipelineColorBlendAdvancedStateCreateInfoEXT -> VkBlendOverlapEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPipelineColorBlendAdvancedStateCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPipelineColorBlendAdvancedStateCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkBlendOverlapEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkBlendOverlapEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkBlendOverlapEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPipelineColorBlendAdvancedStateCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkPhysicalDeviceBlendOperationAdvancedFeaturesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkBlendOverlapEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_blend_operation_advanced.VkBlendOverlapEXT
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview
-- | VK_DEPENDENCY_VIEW_LOCAL_BIT specifies that a subpass has
-- more than one view.
-- | VkPhysicalDeviceMultiviewFeatures - Structure describing multiview
-- features that can be supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceMultiviewFeatures
-- structure describe the following features:
--
-- Description
--
--
-- - multiview specifies whether the implementation supports
-- multiview rendering within a render pass. If this feature is not
-- enabled, the view mask of each subpass must always be
-- zero.
--
--
--
-- - multiviewGeometryShader specifies whether the
-- implementation supports multiview rendering within a render pass, with
-- geometry shaders. If this feature is not enabled, then a
-- pipeline compiled against a subpass with a non-zero view mask
-- must not include a geometry shader.
-- - multiviewTessellationShader specifies whether the
-- implementation supports multiview rendering within a render pass, with
-- tessellation shaders. If this feature is not enabled, then a
-- pipeline compiled against a subpass with a non-zero view mask
-- must not include any tessellation shaders.
--
--
-- If the VkPhysicalDeviceMultiviewFeatures structure is
-- included in the pNext chain of
-- VkPhysicalDeviceFeatures2, it is filled with values indicating
-- whether each feature is supported.
-- VkPhysicalDeviceMultiviewFeatures can also be used in
-- the pNext chain of VkDeviceCreateInfo to enable the
-- features.
--
-- Valid Usage
--
--
-- - If multiviewGeometryShader is enabled then
-- multiview must also be enabled.
--
--
--
-- - If multiviewTessellationShader is enabled then
-- multiview must also be enabled.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_FEATURES
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceMultiviewFeatures
VkPhysicalDeviceMultiviewFeatures :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceMultiviewFeatures
[$sel:vkSType:VkPhysicalDeviceMultiviewFeatures] :: VkPhysicalDeviceMultiviewFeatures -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceMultiviewFeatures] :: VkPhysicalDeviceMultiviewFeatures -> Ptr ()
[$sel:vkMultiview:VkPhysicalDeviceMultiviewFeatures] :: VkPhysicalDeviceMultiviewFeatures -> VkBool32
[$sel:vkMultiviewGeometryShader:VkPhysicalDeviceMultiviewFeatures] :: VkPhysicalDeviceMultiviewFeatures -> VkBool32
[$sel:vkMultiviewTessellationShader:VkPhysicalDeviceMultiviewFeatures] :: VkPhysicalDeviceMultiviewFeatures -> VkBool32
-- | VkPhysicalDeviceMultiviewProperties - Structure describing multiview
-- limits that can be supported by an implementation
--
-- Members
--
-- The members of the VkPhysicalDeviceMultiviewProperties
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxMultiviewViewCount is one greater than the maximum
-- view index that can be used in a subpass.
--
--
--
-- - maxMultiviewInstanceIndex is the maximum valid value of
-- instance index allowed to be generated by a drawing command recorded
-- within a subpass of a multiview render pass instance.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MULTIVIEW_PROPERTIES
--
--
-- If the VkPhysicalDeviceMultiviewProperties structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- See Also
--
-- VkStructureType
data VkPhysicalDeviceMultiviewProperties
VkPhysicalDeviceMultiviewProperties :: VkStructureType -> Ptr () -> Word32 -> Word32 -> VkPhysicalDeviceMultiviewProperties
[$sel:vkSType:VkPhysicalDeviceMultiviewProperties] :: VkPhysicalDeviceMultiviewProperties -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceMultiviewProperties] :: VkPhysicalDeviceMultiviewProperties -> Ptr ()
[$sel:vkMaxMultiviewViewCount:VkPhysicalDeviceMultiviewProperties] :: VkPhysicalDeviceMultiviewProperties -> Word32
[$sel:vkMaxMultiviewInstanceIndex:VkPhysicalDeviceMultiviewProperties] :: VkPhysicalDeviceMultiviewProperties -> Word32
-- | VkRenderPassMultiviewCreateInfo - Structure containing multiview info
-- for all subpasses
--
-- Description
--
-- When a subpass uses a non-zero view mask, multiview
-- functionality is considered to be enabled. Multiview is all-or-nothing
-- for a render pass - that is, either all subpasses must have a
-- non-zero view mask (though some subpasses may have only one
-- view) or all must be zero. Multiview causes all drawing and
-- clear commands in the subpass to behave as if they were broadcast to
-- each view, where a view is represented by one layer of the framebuffer
-- attachments. All draws and clears are broadcast to each view
-- index whose bit is set in the view mask. The view index is
-- provided in the ViewIndex shader input variable, and color,
-- depth/stencil, and input attachments all read/write the layer of the
-- framebuffer corresponding to the view index.
--
-- If the view mask is zero for all subpasses, multiview is considered to
-- be disabled and all drawing commands execute normally, without this
-- additional broadcasting.
--
-- Some implementations may not support multiview in conjunction
-- with geometry shaders or tessellation shaders.
--
-- When multiview is enabled, the VK_DEPENDENCY_VIEW_LOCAL_BIT
-- bit in a dependency can be used to express a view-local
-- dependency, meaning that each view in the destination subpass depends
-- on a single view in the source subpass. Unlike pipeline barriers, a
-- subpass dependency can potentially have a different view mask
-- in the source subpass and the destination subpass. If the dependency
-- is view-local, then each view (dstView) in the destination subpass
-- depends on the view dstView + pViewOffsets[dependency] in the source
-- subpass. If there is not such a view in the source subpass, then this
-- dependency does not affect that view in the destination subpass. If
-- the dependency is not view-local, then all views in the destination
-- subpass depend on all views in the source subpass, and the view offset
-- is ignored. A non-zero view offset is not allowed in a
-- self-dependency.
--
-- The elements of pCorrelationMasks are a set of masks of views
-- indicating that views in the same mask may exhibit spatial
-- coherency between the views, making it more efficient to render them
-- concurrently. Correlation masks must not have a functional
-- effect on the results of the multiview rendering.
--
-- When multiview is enabled, at the beginning of each subpass all
-- non-render pass state is undefined. In particular, each time
-- vkCmdBeginRenderPass or vkCmdNextSubpass is called the
-- graphics pipeline must be bound, any relevant descriptor sets
-- or vertex/index buffers must be bound, and any relevant dynamic
-- state or push constants must be set before they are used.
--
-- A multiview subpass can declare that its shaders will write
-- per-view attributes for all views in a single invocation, by setting
-- the VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX bit in
-- the subpass description. The only supported per-view attributes are
-- position and viewport mask, and per-view position and viewport masks
-- are written to output array variables decorated with
-- PositionPerViewNV and ViewportMaskPerViewNV,
-- respectively. If {html_spec_relative}#VK_NV_viewport_array2
-- is not supported and enabled, ViewportMaskPerViewNV
-- must not be used. Values written to elements of
-- PositionPerViewNV and ViewportMaskPerViewNV
-- must not depend on the ViewIndex. The shader
-- must also write to an output variable decorated with
-- Position, and the value written to Position
-- must equal the value written to
-- PositionPerViewNV[ViewIndex]. Similarly, if
-- ViewportMaskPerViewNV is written to then the shader
-- must also write to an output variable decorated with
-- ViewportMaskNV, and the value written to
-- ViewportMaskNV must equal the value written to
-- ViewportMaskPerViewNV[ViewIndex]. Implementations
-- will either use values taken from Position and
-- ViewportMaskNV and invoke the shader once for each view, or
-- will use values taken from PositionPerViewNV and
-- ViewportMaskPerViewNV and invoke the shader fewer times. The
-- values written to Position and ViewportMaskNV
-- must not depend on the values written to
-- PositionPerViewNV and ViewportMaskPerViewNV, or vice
-- versa (to allow compilers to eliminate the unused outputs). All
-- attributes that do not have *PerViewNV counterparts must not
-- depend on ViewIndex.
--
-- Per-view attributes are all-or-nothing for a subpass. That is, all
-- pipelines compiled against a subpass that includes the
-- VK_SUBPASS_DESCRIPTION_PER_VIEW_ATTRIBUTES_BIT_NVX bit
-- must write per-view attributes to the *PerViewNV[] shader
-- outputs, in addition to the non-per-view (e.g. Position)
-- outputs. Pipelines compiled against a subpass that does not include
-- this bit must not include the *PerViewNV[] outputs in their
-- interfaces.
--
-- Valid Usage
--
--
-- - If subpassCount is not zero, subpassCount
-- must be equal to the subpassCount in the
-- VkRenderPassCreateInfo structure at the start of the
-- chain
--
--
--
-- - If dependencyCount is not zero, dependencyCount
-- must be equal to the dependencyCount in the
-- VkRenderPassCreateInfo structure at the start of the
-- chain
-- - Each view index must not be set in more than one element of
-- pCorrelationMasks
-- - If an element of pViewOffsets is non-zero, the
-- corresponding VkSubpassDependency structure must have
-- different values of srcSubpass and dstSubpass.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_RENDER_PASS_MULTIVIEW_CREATE_INFO
--
--
--
-- - If subpassCount is not 0, pViewMasks
-- must be a valid pointer to an array of subpassCount
-- uint32_t values
-- - If dependencyCount is not 0,
-- pViewOffsets must be a valid pointer to an array of
-- dependencyCount int32_t values
-- - If correlationMaskCount is not 0,
-- pCorrelationMasks must be a valid pointer to an array
-- of correlationMaskCount uint32_t values
--
--
-- See Also
--
-- VkStructureType
data VkRenderPassMultiviewCreateInfo
VkRenderPassMultiviewCreateInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> Word32 -> Ptr Int32 -> Word32 -> Ptr Word32 -> VkRenderPassMultiviewCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Ptr ()
-- | subpassCount is zero or is the number of subpasses in the
-- render pass.
[$sel:vkSubpassCount:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Word32
-- | pViewMasks points to an array of subpassCount number
-- of view masks, where each mask is a bitfield of view indices
-- describing which views rendering is broadcast to in each subpass, when
-- multiview is enabled. If subpassCount is zero, each view mask
-- is treated as zero.
[$sel:vkPViewMasks:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Ptr Word32
-- | dependencyCount is zero or the number of dependencies in the
-- render pass.
[$sel:vkDependencyCount:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Word32
-- | pViewOffsets points to an array of dependencyCount
-- view offsets, one for each dependency. If dependencyCount is
-- zero, each dependency’s view offset is treated as zero. Each view
-- offset controls which views in the source subpass the views in the
-- destination subpass depend on.
[$sel:vkPViewOffsets:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Ptr Int32
-- | correlationMaskCount is zero or a number of correlation
-- masks.
[$sel:vkCorrelationMaskCount:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Word32
-- | pCorrelationMasks is an array of view masks indicating sets
-- of views that may be more efficient to render concurrently.
[$sel:vkPCorrelationMasks:VkRenderPassMultiviewCreateInfo] :: VkRenderPassMultiviewCreateInfo -> Ptr Word32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkRenderPassMultiviewCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkRenderPassMultiviewCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewProperties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewProperties
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewFeatures
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewFeatures
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkRenderPassMultiviewCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewProperties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_multiview.VkPhysicalDeviceMultiviewFeatures
module Graphics.Vulkan.Extensions.VK_KHR_multiview
type VkPhysicalDeviceMultiviewFeaturesKHR = VkPhysicalDeviceMultiviewFeatures
type VkPhysicalDeviceMultiviewPropertiesKHR = VkPhysicalDeviceMultiviewProperties
type VkRenderPassMultiviewCreateInfoKHR = VkRenderPassMultiviewCreateInfo
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group
-- | VkPeerMemoryFeatureFlagBits - Bitmask specifying supported peer memory
-- features
--
-- Description
--
--
-- - VK_PEER_MEMORY_FEATURE_COPY_SRC_BIT specifies that the
-- memory can be accessed as the source of a
-- vkCmdCopyBuffer, vkCmdCopyImage,
-- vkCmdCopyBufferToImage, or vkCmdCopyImageToBuffer
-- command.
--
--
--
-- - VK_PEER_MEMORY_FEATURE_COPY_DST_BIT specifies that the
-- memory can be accessed as the destination of a
-- vkCmdCopyBuffer, vkCmdCopyImage,
-- vkCmdCopyBufferToImage, or vkCmdCopyImageToBuffer
-- command.
-- - VK_PEER_MEMORY_FEATURE_GENERIC_SRC_BIT specifies that the
-- memory can be read as any memory access type.
-- - VK_PEER_MEMORY_FEATURE_GENERIC_DST_BIT specifies that the
-- memory can be written as any memory access type. Shader atomics
-- are considered to be writes.
--
--
-- Note
--
-- The peer memory features of a memory heap also apply to any accesses
-- that may be performed during image layout transitions.
--
-- VK_PEER_MEMORY_FEATURE_COPY_DST_BIT must be supported
-- for all host local heaps and for at least one device local heap.
--
-- If a device does not support a peer memory feature, it is still valid
-- to use a resource that includes both local and peer memory bindings
-- with the corresponding access type as long as only the local bindings
-- are actually accessed. For example, an application doing split-frame
-- rendering would use framebuffer attachments that include both local
-- and peer memory bindings, but would scissor the rendering to only
-- update local memory.
--
-- See Also
--
-- VkPeerMemoryFeatureFlags
newtype VkPeerMemoryFeatureFlagBits
VkPeerMemoryFeatureFlagBits :: VkFlags -> VkPeerMemoryFeatureFlagBits
-- | VkMemoryAllocateFlagBits - Bitmask specifying flags for a device
-- memory allocation
--
-- See Also
--
-- VkMemoryAllocateFlags
newtype VkMemoryAllocateFlagBits
VkMemoryAllocateFlagBits :: VkFlags -> VkMemoryAllocateFlagBits
-- | VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT specifies that memory will
-- be allocated for the devices in
-- VkMemoryAllocateFlagsInfo::deviceMask.
-- | VK_DEPENDENCY_DEVICE_GROUP_BIT specifies that dependencies
-- are non-device-local dependency.
-- | vkGetDeviceGroupPeerMemoryFeatures - Query supported peer memory
-- features of a device
--
-- Parameters
--
--
-- - device is the logical device that owns the memory.
--
--
--
-- - heapIndex is the index of the memory heap from which the
-- memory is allocated.
-- - localDeviceIndex is the device index of the physical
-- device that performs the memory access.
-- - remoteDeviceIndex is the device index of the physical
-- device that the memory is allocated for.
-- - pPeerMemoryFeatures is a pointer to a bitmask of
-- VkPeerMemoryFeatureFlagBits indicating which types of memory
-- accesses are supported for the combination of heap, local, and remote
-- devices.
--
--
-- Description
--
-- Valid Usage
--
--
-- - heapIndex must be less than
-- memoryHeapCount
--
--
--
-- - localDeviceIndex must be a valid device index
-- - remoteDeviceIndex must be a valid device
-- index
-- - localDeviceIndex must not equal
-- remoteDeviceIndex
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pPeerMemoryFeatures must be a valid pointer to a
-- VkPeerMemoryFeatureFlags value
-- - pPeerMemoryFeatures must not be 0
--
--
-- See Also
--
-- VkDevice, VkPeerMemoryFeatureFlags
vkGetDeviceGroupPeerMemoryFeatures :: ("device" ::: VkDevice) -> ("heapIndex" ::: Word32) -> ("localDeviceIndex" ::: Word32) -> ("remoteDeviceIndex" ::: Word32) -> ("pPeerMemoryFeatures" ::: Ptr VkPeerMemoryFeatureFlags) -> IO ()
-- | vkCmdSetDeviceMask - Modify device mask of a command buffer
--
-- Parameters
--
--
-- - commandBuffer is command buffer whose current device mask
-- is modified.
--
--
--
-- - deviceMask is the new value of the current device
-- mask.
--
--
-- Description
--
-- deviceMask is used to filter out subsequent commands from
-- executing on all physical devices whose bit indices are not set in the
-- mask.
--
-- Valid Usage
--
--
-- - deviceMask must be a valid device mask value
--
--
--
-- - deviceMask must not be zero
-- - deviceMask must not include any set bits that were
-- not in the
-- VkDeviceGroupCommandBufferBeginInfo::deviceMask value
-- when the command buffer began recording.
-- - If vkCmdSetDeviceMask is called inside a render pass
-- instance, deviceMask must not include any set bits
-- that were not in the
-- VkDeviceGroupRenderPassBeginInfo::deviceMask value
-- when the render pass instance began recording.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, compute, or transfer
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- | | | Transfer | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdSetDeviceMask :: ("commandBuffer" ::: VkCommandBuffer) -> ("deviceMask" ::: Word32) -> IO ()
-- | vkCmdDispatchBase - Dispatch compute work items
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - baseGroupX is the start value for the X component of
-- WorkgroupId.
-- - baseGroupY is the start value for the Y component of
-- WorkgroupId.
-- - baseGroupZ is the start value for the Z component of
-- WorkgroupId.
-- - groupCountX is the number of local workgroups to dispatch
-- in the X dimension.
-- - groupCountY is the number of local workgroups to dispatch
-- in the Y dimension.
-- - groupCountZ is the number of local workgroups to dispatch
-- in the Z dimension.
--
--
-- Description
--
-- When the command is executed, a global workgroup consisting of
-- groupCountX × groupCountY × groupCountZ local workgroups is assembled,
-- with WorkgroupId values ranging from [baseGroup, baseGroup +
-- groupCount) in each component. vkCmdDispatch is equivalent to
-- vkCmdDispatchBase(0,0,0,groupCountX,groupCountY,groupCountZ).
--
-- Valid Usage
--
--
--
--
-- - baseGroupX must be less than
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[0]
-- - baseGroupX must be less than
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[1]
-- - baseGroupZ must be less than
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[2]
-- - groupCountX must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[0]
-- minus baseGroupX
-- - groupCountY must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[1]
-- minus baseGroupY
-- - groupCountZ must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[2]
-- minus baseGroupZ
-- - If any of baseGroupX, baseGroupY, or
-- baseGroupZ are not zero, then the bound compute pipeline
-- must have been created with the
-- VK_PIPELINE_CREATE_DISPATCH_BASE flag.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support compute operations
-- - This command must only be called outside of a render pass
-- instance
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Compute | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdDispatchBase :: ("commandBuffer" ::: VkCommandBuffer) -> ("baseGroupX" ::: Word32) -> ("baseGroupY" ::: Word32) -> ("baseGroupZ" ::: Word32) -> ("groupCountX" ::: Word32) -> ("groupCountY" ::: Word32) -> ("groupCountZ" ::: Word32) -> IO ()
-- | VkMemoryAllocateFlagsInfo - Structure controlling how many instances
-- of memory will be allocated
--
-- Description
--
-- If VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT is not set, the number
-- of instances allocated depends on whether
-- VK_MEMORY_HEAP_MULTI_INSTANCE_BIT is set in the memory heap.
-- If VK_MEMORY_HEAP_MULTI_INSTANCE_BIT is set, then memory is
-- allocated for every physical device in the logical device (as if
-- deviceMask has bits set for all device indices). If
-- VK_MEMORY_HEAP_MULTI_INSTANCE_BIT is not set, then a single
-- instance of memory is allocated (as if deviceMask is set to
-- one).
--
-- On some implementations, allocations from a multi-instance heap
-- may consume memory on all physical devices even if the
-- deviceMask excludes some devices. If
-- VkPhysicalDeviceGroupProperties::subsetAllocation is
-- VK_TRUE, then memory is only consumed for the devices in the
-- device mask.
--
-- Note
--
-- In practice, most allocations on a multi-instance heap will be
-- allocated across all physical devices. Unicast allocation support is
-- an optional optimization for a minority of allocations.
--
-- Valid Usage
--
--
-- - If VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT is set,
-- deviceMask must be a valid device mask.
--
--
--
-- - If VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT is set,
-- deviceMask must not be zero
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_FLAGS_INFO
--
--
--
--
-- See Also
--
-- VkMemoryAllocateFlags, VkStructureType
data VkMemoryAllocateFlagsInfo
VkMemoryAllocateFlagsInfo :: VkStructureType -> Ptr () -> VkMemoryAllocateFlags -> Word32 -> VkMemoryAllocateFlagsInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryAllocateFlagsInfo] :: VkMemoryAllocateFlagsInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryAllocateFlagsInfo] :: VkMemoryAllocateFlagsInfo -> Ptr ()
-- | flags is a bitmask of VkMemoryAllocateFlagBits
-- controlling the allocation.
[$sel:vkFlags:VkMemoryAllocateFlagsInfo] :: VkMemoryAllocateFlagsInfo -> VkMemoryAllocateFlags
-- | deviceMask is a mask of physical devices in the logical
-- device, indicating that memory must be allocated on each device
-- in the mask, if VK_MEMORY_ALLOCATE_DEVICE_MASK_BIT is set in
-- flags.
[$sel:vkDeviceMask:VkMemoryAllocateFlagsInfo] :: VkMemoryAllocateFlagsInfo -> Word32
-- | VkDeviceGroupRenderPassBeginInfo - Set the initial device mask and
-- render areas for a render pass instance
--
-- Description
--
-- The deviceMask serves several purposes. It is an upper bound
-- on the set of physical devices that can be used during the
-- render pass instance, and the initial device mask when the render pass
-- instance begins. Render pass attachment load, store, and resolve
-- operations only apply to physical devices included in the device mask.
-- Subpass dependencies only apply to the physical devices in the device
-- mask.
--
-- If deviceRenderAreaCount is not zero, then the elements of
-- pDeviceRenderAreas override the value of
-- VkRenderPassBeginInfo::renderArea, and provide a
-- render area specific to each physical device. These render areas serve
-- the same purpose as VkRenderPassBeginInfo::renderArea,
-- including controlling the region of attachments that are cleared by
-- VK_ATTACHMENT_LOAD_OP_CLEAR and that are resolved into
-- resolve attachments.
--
-- If this structure is not present, the render pass instance’s device
-- mask is the value of
-- VkDeviceGroupCommandBufferBeginInfo::deviceMask. If
-- this structure is not present or if deviceRenderAreaCount is
-- zero, VkRenderPassBeginInfo::renderArea is used for
-- all physical devices.
--
-- Valid Usage
--
--
-- - deviceMask must be a valid device mask value
--
--
--
-- - deviceMask must not be zero
-- - deviceMask must be a subset of the command
-- buffer’s initial device mask
-- - deviceRenderAreaCount must either be zero or equal
-- to the number of physical devices in the logical device.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_RENDER_PASS_BEGIN_INFO
--
--
--
-- - If deviceRenderAreaCount is not 0,
-- pDeviceRenderAreas must be a valid pointer to an array
-- of deviceRenderAreaCount VkRect2D structures
--
--
-- See Also
--
-- VkRect2D, VkStructureType
data VkDeviceGroupRenderPassBeginInfo
VkDeviceGroupRenderPassBeginInfo :: VkStructureType -> Ptr () -> Word32 -> Word32 -> Ptr VkRect2D -> VkDeviceGroupRenderPassBeginInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupRenderPassBeginInfo] :: VkDeviceGroupRenderPassBeginInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupRenderPassBeginInfo] :: VkDeviceGroupRenderPassBeginInfo -> Ptr ()
-- | deviceMask is the device mask for the render pass instance.
[$sel:vkDeviceMask:VkDeviceGroupRenderPassBeginInfo] :: VkDeviceGroupRenderPassBeginInfo -> Word32
-- | deviceRenderAreaCount is the number of elements in the
-- pDeviceRenderAreas array.
[$sel:vkDeviceRenderAreaCount:VkDeviceGroupRenderPassBeginInfo] :: VkDeviceGroupRenderPassBeginInfo -> Word32
-- | pDeviceRenderAreas is an array of structures of type
-- VkRect2D defining the render area for each physical device.
[$sel:vkPDeviceRenderAreas:VkDeviceGroupRenderPassBeginInfo] :: VkDeviceGroupRenderPassBeginInfo -> Ptr VkRect2D
-- | VkDeviceGroupCommandBufferBeginInfo - Set the initial device mask for
-- a command buffer
--
-- Description
--
-- The initial device mask also acts as an upper bound on the set of
-- devices that can ever be in the device mask in the command
-- buffer.
--
-- If this structure is not present, the initial value of a command
-- buffer’s device mask is set to include all physical devices in the
-- logical device when the command buffer begins recording.
--
-- Valid Usage
--
--
-- - deviceMask must be a valid device mask value
--
--
--
-- - deviceMask must not be zero
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_COMMAND_BUFFER_BEGIN_INFO
--
--
-- See Also
--
-- VkStructureType
data VkDeviceGroupCommandBufferBeginInfo
VkDeviceGroupCommandBufferBeginInfo :: VkStructureType -> Ptr () -> Word32 -> VkDeviceGroupCommandBufferBeginInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupCommandBufferBeginInfo] :: VkDeviceGroupCommandBufferBeginInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupCommandBufferBeginInfo] :: VkDeviceGroupCommandBufferBeginInfo -> Ptr ()
-- | deviceMask is the initial value of the command buffer’s
-- device mask.
[$sel:vkDeviceMask:VkDeviceGroupCommandBufferBeginInfo] :: VkDeviceGroupCommandBufferBeginInfo -> Word32
-- | VkDeviceGroupSubmitInfo - Structure indicating which physical devices
-- execute semaphore operations and command buffers
--
-- Description
--
-- If this structure is not present, semaphore operations and command
-- buffers execute on device index zero.
--
-- Valid Usage
--
--
-- - waitSemaphoreCount must equal
-- VkSubmitInfo::waitSemaphoreCount
--
--
--
-- - commandBufferCount must equal
-- VkSubmitInfo::commandBufferCount
-- - signalSemaphoreCount must equal
-- VkSubmitInfo::signalSemaphoreCount
-- - All elements of pWaitSemaphoreDeviceIndices and
-- pSignalSemaphoreDeviceIndices must be valid device
-- indices
-- - All elements of pCommandBufferDeviceMasks must be
-- valid device masks
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_SUBMIT_INFO
--
--
--
-- - If waitSemaphoreCount is not 0,
-- pWaitSemaphoreDeviceIndices must be a valid pointer to
-- an array of waitSemaphoreCount uint32_t values
-- - If commandBufferCount is not 0,
-- pCommandBufferDeviceMasks must be a valid pointer to
-- an array of commandBufferCount uint32_t values
-- - If signalSemaphoreCount is not 0,
-- pSignalSemaphoreDeviceIndices must be a valid pointer
-- to an array of signalSemaphoreCount uint32_t
-- values
--
--
-- See Also
--
-- VkStructureType
data VkDeviceGroupSubmitInfo
VkDeviceGroupSubmitInfo :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> Word32 -> Ptr Word32 -> Word32 -> Ptr Word32 -> VkDeviceGroupSubmitInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Ptr ()
-- | waitSemaphoreCount is the number of elements in the
-- pWaitSemaphoreDeviceIndices array.
[$sel:vkWaitSemaphoreCount:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Word32
-- | pWaitSemaphoreDeviceIndices is an array of device indices
-- indicating which physical device executes the semaphore wait operation
-- in the corresponding element of
-- VkSubmitInfo::pWaitSemaphores.
[$sel:vkPWaitSemaphoreDeviceIndices:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Ptr Word32
-- | commandBufferCount is the number of elements in the
-- pCommandBufferDeviceMasks array.
[$sel:vkCommandBufferCount:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Word32
-- | pCommandBufferDeviceMasks is an array of device masks
-- indicating which physical devices execute the command buffer in the
-- corresponding element of
-- VkSubmitInfo::pCommandBuffers. A physical device
-- executes the command buffer if the corresponding bit is set in the
-- mask.
[$sel:vkPCommandBufferDeviceMasks:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Ptr Word32
-- | signalSemaphoreCount is the number of elements in the
-- pSignalSemaphoreDeviceIndices array.
[$sel:vkSignalSemaphoreCount:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Word32
-- | pSignalSemaphoreDeviceIndices is an array of device indices
-- indicating which physical device executes the semaphore signal
-- operation in the corresponding element of
-- VkSubmitInfo::pSignalSemaphores.
[$sel:vkPSignalSemaphoreDeviceIndices:VkDeviceGroupSubmitInfo] :: VkDeviceGroupSubmitInfo -> Ptr Word32
-- | VkDeviceGroupBindSparseInfo - Structure indicating which instances are
-- bound
--
-- Description
--
-- These device indices apply to all buffer and image memory binds
-- included in the batch that points to this structure. The semaphore
-- waits and signals for the batch are executed only by the physical
-- device specified by the resourceDeviceIndex.
--
-- If this structure is not present, resourceDeviceIndex and
-- memoryDeviceIndex are assumed to be zero.
--
-- Valid Usage
--
--
-- - resourceDeviceIndex and memoryDeviceIndex
-- must both be valid device indices.
--
--
--
-- - Each memory allocation bound in this batch must have
-- allocated an instance for memoryDeviceIndex.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GROUP_BIND_SPARSE_INFO
--
--
-- See Also
--
-- VkStructureType
data VkDeviceGroupBindSparseInfo
VkDeviceGroupBindSparseInfo :: VkStructureType -> Ptr () -> Word32 -> Word32 -> VkDeviceGroupBindSparseInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGroupBindSparseInfo] :: VkDeviceGroupBindSparseInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGroupBindSparseInfo] :: VkDeviceGroupBindSparseInfo -> Ptr ()
-- | resourceDeviceIndex is a device index indicating which
-- instance of the resource is bound.
[$sel:vkResourceDeviceIndex:VkDeviceGroupBindSparseInfo] :: VkDeviceGroupBindSparseInfo -> Word32
-- | memoryDeviceIndex is a device index indicating which instance
-- of the memory the resource instance is bound to.
[$sel:vkMemoryDeviceIndex:VkDeviceGroupBindSparseInfo] :: VkDeviceGroupBindSparseInfo -> Word32
-- | VkPeerMemoryFeatureFlags - Bitmask of VkPeerMemoryFeatureFlagBits
--
-- Description
--
-- VkPeerMemoryFeatureFlags is a bitmask type for setting a mask
-- of zero or more VkPeerMemoryFeatureFlagBits.
--
-- See Also
--
-- VkPeerMemoryFeatureFlagBits,
-- vkGetDeviceGroupPeerMemoryFeatures,
-- vkGetDeviceGroupPeerMemoryFeaturesKHR
type VkPeerMemoryFeatureFlags = VkPeerMemoryFeatureFlagBits
-- | VkMemoryAllocateFlags - Bitmask of VkMemoryAllocateFlagBits
--
-- Description
--
-- VkMemoryAllocateFlags is a bitmask type for setting a mask of
-- zero or more VkMemoryAllocateFlagBits.
--
-- See Also
--
-- VkMemoryAllocateFlagBits, VkMemoryAllocateFlagsInfo
type VkMemoryAllocateFlags = VkMemoryAllocateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagsInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagsInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupBindSparseInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupBindSparseInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupSubmitInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupSubmitInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupCommandBufferBeginInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupCommandBufferBeginInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupRenderPassBeginInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupRenderPassBeginInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagsInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupBindSparseInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupSubmitInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupCommandBufferBeginInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkDeviceGroupRenderPassBeginInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkMemoryAllocateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_device_group.VkPeerMemoryFeatureFlagBits
module Graphics.Vulkan.Extensions.VK_KHR_device_group
vkGetDeviceGroupPeerMemoryFeaturesKHR :: ("device" ::: VkDevice) -> ("heapIndex" ::: Word32) -> ("localDeviceIndex" ::: Word32) -> ("remoteDeviceIndex" ::: Word32) -> ("pPeerMemoryFeatures" ::: Ptr VkPeerMemoryFeatureFlags) -> IO ()
vkCmdSetDeviceMaskKHR :: ("commandBuffer" ::: VkCommandBuffer) -> ("deviceMask" ::: Word32) -> IO ()
vkCmdDispatchBaseKHR :: ("commandBuffer" ::: VkCommandBuffer) -> ("baseGroupX" ::: Word32) -> ("baseGroupY" ::: Word32) -> ("baseGroupZ" ::: Word32) -> ("groupCountX" ::: Word32) -> ("groupCountY" ::: Word32) -> ("groupCountZ" ::: Word32) -> IO ()
type VkPeerMemoryFeatureFlagBitsKHR = VkPeerMemoryFeatureFlagBits
type VkMemoryAllocateFlagBitsKHR = VkMemoryAllocateFlagBits
type VkPeerMemoryFeatureFlagsKHR = VkPeerMemoryFeatureFlags
type VkMemoryAllocateFlagsKHR = VkMemoryAllocateFlags
type VkMemoryAllocateFlagsInfoKHR = VkMemoryAllocateFlagsInfo
type VkBindBufferMemoryDeviceGroupInfoKHR = VkBindBufferMemoryDeviceGroupInfo
type VkBindImageMemoryDeviceGroupInfoKHR = VkBindImageMemoryDeviceGroupInfo
type VkDeviceGroupRenderPassBeginInfoKHR = VkDeviceGroupRenderPassBeginInfo
type VkDeviceGroupCommandBufferBeginInfoKHR = VkDeviceGroupCommandBufferBeginInfo
type VkDeviceGroupSubmitInfoKHR = VkDeviceGroupSubmitInfo
type VkDeviceGroupBindSparseInfoKHR = VkDeviceGroupBindSparseInfo
module Graphics.Vulkan.Core10.CommandBuffer
-- | VkCommandBufferLevel - Enumerant specifying a command buffer level
--
-- See Also
--
-- VkCommandBufferAllocateInfo
newtype VkCommandBufferLevel
VkCommandBufferLevel :: Int32 -> VkCommandBufferLevel
-- | VK_COMMAND_BUFFER_LEVEL_PRIMARY specifies a primary command
-- buffer.
-- | VK_COMMAND_BUFFER_LEVEL_SECONDARY specifies a secondary
-- command buffer.
-- | VkQueryControlFlagBits - Bitmask specifying constraints on a query
--
-- See Also
--
-- VkQueryControlFlags
newtype VkQueryControlFlagBits
VkQueryControlFlagBits :: VkFlags -> VkQueryControlFlagBits
-- | VK_QUERY_CONTROL_PRECISE_BIT specifies the precision of
-- occlusion queries.
-- | VkCommandBufferResetFlagBits - Bitmask controlling behavior of a
-- command buffer reset
--
-- See Also
--
-- VkCommandBufferResetFlags
newtype VkCommandBufferResetFlagBits
VkCommandBufferResetFlagBits :: VkFlags -> VkCommandBufferResetFlagBits
-- | VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT specifies that
-- most or all memory resources currently owned by the command buffer
-- should be returned to the parent command pool. If this flag is
-- not set, then the command buffer may hold onto memory resources
-- and reuse them when recording commands. commandBuffer is
-- moved to the initial state.
-- | VkCommandBufferUsageFlagBits - Bitmask specifying usage behavior for
-- command buffer
--
-- See Also
--
-- VkCommandBufferUsageFlags
newtype VkCommandBufferUsageFlagBits
VkCommandBufferUsageFlagBits :: VkFlags -> VkCommandBufferUsageFlagBits
-- | VK_COMMAND_BUFFER_USAGE_ONE_TIME_SUBMIT_BIT specifies that
-- each recording of the command buffer will only be submitted once, and
-- the command buffer will be reset and recorded again between each
-- submission.
-- | VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT specifies
-- that a secondary command buffer is considered to be entirely inside a
-- render pass. If this is a primary command buffer, then this bit is
-- ignored.
-- | VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT specifies that a
-- command buffer can be resubmitted to a queue while it is in the
-- /pending state/, and recorded into multiple primary command buffers.
-- | vkAllocateCommandBuffers - Allocate command buffers from an existing
-- command pool
--
-- Parameters
--
--
-- - device is the logical device that owns the command
-- pool.
--
--
--
-- - pAllocateInfo is a pointer to an instance of the
-- VkCommandBufferAllocateInfo structure describing parameters
-- of the allocation.
-- - pCommandBuffers is a pointer to an array of
-- VkCommandBuffer handles in which the resulting command buffer
-- objects are returned. The array must be at least the length
-- specified by the commandBufferCount member of
-- pAllocateInfo. Each allocated command buffer begins in the
-- initial state.
--
--
-- Description
--
-- vkAllocateCommandBuffers can be used to create
-- multiple command buffers. If the creation of any of those command
-- buffers fails, the implementation must destroy all successfully
-- created command buffer objects from this command, set all entries of
-- the pCommandBuffers array to NULL and return the
-- error.
--
-- When command buffers are first allocated, they are in the initial
-- state.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pAllocateInfo must be a valid pointer to a valid
-- VkCommandBufferAllocateInfo structure
-- - pCommandBuffers must be a valid pointer to an
-- array of pAllocateInfo::commandBufferCount
-- VkCommandBuffer handles
--
--
-- Host Synchronization
--
--
-- - Host access to pAllocateInfo::commandPool must be
-- externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkCommandBuffer, VkCommandBufferAllocateInfo,
-- VkDevice
vkAllocateCommandBuffers :: ("device" ::: VkDevice) -> ("pAllocateInfo" ::: Ptr VkCommandBufferAllocateInfo) -> ("pCommandBuffers" ::: Ptr VkCommandBuffer) -> IO VkResult
-- | vkFreeCommandBuffers - Free command buffers
--
-- Parameters
--
--
-- - device is the logical device that owns the command
-- pool.
--
--
--
-- - commandPool is the command pool from which the command
-- buffers were allocated.
-- - commandBufferCount is the length of the
-- pCommandBuffers array.
-- - pCommandBuffers is an array of handles of command buffers
-- to free.
--
--
-- Description
--
-- Any primary command buffer that is in the recording or executable
-- state and has any element of pCommandBuffers recorded
-- into it, becomes invalid.
--
-- Valid Usage
--
--
-- - All elements of pCommandBuffers must not be in the
-- pending state
--
--
--
-- - pCommandBuffers must be a valid pointer to an
-- array of commandBufferCount VkCommandBuffer handles,
-- each element of which must either be a valid handle or
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - commandPool must be a valid VkCommandPool
-- handle
-- - commandBufferCount must be greater than
-- 0
-- - commandPool must have been created, allocated, or
-- retrieved from device
-- - Each element of pCommandBuffers that is a valid handle
-- must have been created, allocated, or retrieved from
-- commandPool
--
--
-- Host Synchronization
--
--
-- - Host access to commandPool must be externally
-- synchronized
--
--
--
-- - Host access to each member of pCommandBuffers must
-- be externally synchronized
--
--
-- See Also
--
-- VkCommandBuffer, VkCommandPool, VkDevice
vkFreeCommandBuffers :: ("device" ::: VkDevice) -> ("commandPool" ::: VkCommandPool) -> ("commandBufferCount" ::: Word32) -> ("pCommandBuffers" ::: Ptr VkCommandBuffer) -> IO ()
-- | vkBeginCommandBuffer - Start recording a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the handle of the command buffer which
-- is to be put in the recording state.
--
--
--
-- - pBeginInfo is an instance of the
-- VkCommandBufferBeginInfo structure, which defines additional
-- information about how the command buffer begins recording.
--
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - If commandBuffer was allocated from a
-- VkCommandPool which did not have the
-- VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT flag set,
-- commandBuffer must be in the initial
-- state.
-- - If commandBuffer is a secondary command buffer, the
-- pInheritanceInfo member of pBeginInfo must be
-- a valid VkCommandBufferInheritanceInfo structure
-- - If commandBuffer is a secondary command buffer and either
-- the occlusionQueryEnable member of the
-- pInheritanceInfo member of pBeginInfo is
-- VK_FALSE, or the precise occlusion queries feature is not
-- enabled, the queryFlags member of the
-- pInheritanceInfo member pBeginInfo must not
-- contain VK_QUERY_CONTROL_PRECISE_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pBeginInfo must be a valid pointer to a valid
-- VkCommandBufferBeginInfo structure
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkCommandBuffer, VkCommandBufferBeginInfo
vkBeginCommandBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("pBeginInfo" ::: Ptr VkCommandBufferBeginInfo) -> IO VkResult
-- | vkEndCommandBuffer - Finish recording a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer to complete
-- recording.
--
--
-- Description
--
-- If there was an error during recording, the application will be
-- notified by an unsuccessful return code returned by
-- vkEndCommandBuffer. If the application wishes to further use
-- the command buffer, the command buffer must be reset. The
-- command buffer must have been in the recording state,
-- and is moved to the executable state.
--
-- Valid Usage
--
--
--
--
-- - If commandBuffer is a primary command buffer, there
-- must not be an active render pass instance
-- - All queries made active during the recording of
-- commandBuffer must have been made inactive
-- - If commandBuffer is a secondary command buffer, there
-- must not be an outstanding vkCmdBeginDebugUtilsLabelEXT
-- command recorded to commandBuffer that has not previously
-- been ended by a call to vkCmdEndDebugUtilsLabelEXT.
-- - If commandBuffer is a secondary command buffer, there
-- must not be an outstanding vkCmdDebugMarkerBeginEXT
-- command recorded to commandBuffer that has not previously
-- been ended by a call to vkCmdDebugMarkerEndEXT.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkCommandBuffer
vkEndCommandBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> IO VkResult
-- | vkResetCommandBuffer - Reset a command buffer to the initial state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer to reset. The command
-- buffer can be in any state other than pending, and is
-- moved into the initial state.
--
--
--
--
-- Description
--
-- Any primary command buffer that is in the recording or executable
-- state and has commandBuffer recorded into it, becomes
-- invalid.
--
-- Valid Usage
--
--
--
--
-- - commandBuffer must have been allocated from a pool
-- that was created with the
-- VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkCommandBuffer, VkCommandBufferResetFlags
vkResetCommandBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("flags" ::: VkCommandBufferResetFlags) -> IO VkResult
-- | VkCommandBufferAllocateInfo - Structure specifying the allocation
-- parameters for command buffer object
--
-- Description
--
-- Valid Usage
--
--
-- - commandBufferCount must be greater than
-- 0
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO
--
--
--
-- - pNext must be NULL
-- - commandPool must be a valid VkCommandPool
-- handle
-- - level must be a valid VkCommandBufferLevel
-- value
--
--
-- See Also
--
-- VkCommandBufferLevel, VkCommandPool,
-- VkStructureType, vkAllocateCommandBuffers
data VkCommandBufferAllocateInfo
VkCommandBufferAllocateInfo :: VkStructureType -> Ptr () -> VkCommandPool -> VkCommandBufferLevel -> Word32 -> VkCommandBufferAllocateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkCommandBufferAllocateInfo] :: VkCommandBufferAllocateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCommandBufferAllocateInfo] :: VkCommandBufferAllocateInfo -> Ptr ()
-- | commandPool is the command pool from which the command
-- buffers are allocated.
[$sel:vkCommandPool:VkCommandBufferAllocateInfo] :: VkCommandBufferAllocateInfo -> VkCommandPool
-- | level is an VkCommandBufferLevel value specifying the
-- command buffer level.
[$sel:vkLevel:VkCommandBufferAllocateInfo] :: VkCommandBufferAllocateInfo -> VkCommandBufferLevel
-- | commandBufferCount is the number of command buffers to
-- allocate from the pool.
[$sel:vkCommandBufferCount:VkCommandBufferAllocateInfo] :: VkCommandBufferAllocateInfo -> Word32
-- | VkCommandBufferInheritanceInfo - Structure specifying command buffer
-- inheritance info
--
-- Members
--
--
-- - sType is the type of this structure.
--
--
--
-- - pNext is NULL or a pointer to an
-- extension-specific structure.
-- - renderPass is a VkRenderPass object defining
-- which render passes the VkCommandBuffer will be
-- compatible with and can be executed within. If the
-- VkCommandBuffer will not be executed within a render pass
-- instance, renderPass is ignored.
-- - subpass is the index of the subpass within the render
-- pass instance that the VkCommandBuffer will be executed
-- within. If the VkCommandBuffer will not be executed within a
-- render pass instance, subpass is ignored.
-- - framebuffer optionally refers to the
-- VkFramebuffer object that the VkCommandBuffer will
-- be rendering to if it is executed within a render pass instance. It
-- can be VK_NULL_HANDLE if the framebuffer is not known,
-- or if the VkCommandBuffer will not be executed within a
-- render pass instance.NoteSpecifying the exact framebuffer that
-- the secondary command buffer will be executed with may result
-- in better performance at command buffer execution time.
-- - occlusionQueryEnable specifies whether the command buffer
-- can be executed while an occlusion query is active in the
-- primary command buffer. If this is VK_TRUE, then this command
-- buffer can be executed whether the primary command buffer has
-- an occlusion query active or not. If this is VK_FALSE, then
-- the primary command buffer must not have an occlusion query
-- active.
-- - queryFlags specifies the query flags that can be
-- used by an active occlusion query in the primary command buffer when
-- this secondary command buffer is executed. If this value includes the
-- VK_QUERY_CONTROL_PRECISE_BIT bit, then the active query
-- can return boolean results or actual sample counts. If this bit
-- is not set, then the active query must not use the
-- VK_QUERY_CONTROL_PRECISE_BIT bit.
-- - pipelineStatistics is a bitmask of
-- VkQueryPipelineStatisticFlagBits specifying the set of pipeline
-- statistics that can be counted by an active query in the
-- primary command buffer when this secondary command buffer is executed.
-- If this value includes a given bit, then this command buffer
-- can be executed whether the primary command buffer has a
-- pipeline statistics query active that includes this bit or not. If
-- this value excludes a given bit, then the active pipeline statistics
-- query must not be from a query pool that counts that
-- statistic.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If the inherited queries feature is not enabled,
-- occlusionQueryEnable must be VK_FALSE
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COMMAND_BUFFER_INHERITANCE_INFO
--
--
--
-- - pNext must be NULL
-- - Both of framebuffer, and renderPass that are
-- valid handles must have been created, allocated, or retrieved
-- from the same VkDevice
--
--
-- See Also
--
-- VkBool32, VkCommandBufferBeginInfo,
-- VkFramebuffer, VkQueryControlFlags,
-- VkQueryPipelineStatisticFlags, VkRenderPass,
-- VkStructureType
data VkCommandBufferInheritanceInfo
VkCommandBufferInheritanceInfo :: VkStructureType -> Ptr () -> VkRenderPass -> Word32 -> VkFramebuffer -> VkBool32 -> VkQueryControlFlags -> VkQueryPipelineStatisticFlags -> VkCommandBufferInheritanceInfo
[$sel:vkSType:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkStructureType
[$sel:vkPNext:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> Ptr ()
[$sel:vkRenderPass:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkRenderPass
[$sel:vkSubpass:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> Word32
[$sel:vkFramebuffer:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkFramebuffer
[$sel:vkOcclusionQueryEnable:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkBool32
[$sel:vkQueryFlags:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkQueryControlFlags
[$sel:vkPipelineStatistics:VkCommandBufferInheritanceInfo] :: VkCommandBufferInheritanceInfo -> VkQueryPipelineStatisticFlags
-- | VkCommandBufferBeginInfo - Structure specifying a command buffer begin
-- operation
--
-- Description
--
-- Valid Usage
--
--
-- - If flags contains
-- VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT, the
-- renderPass member of pInheritanceInfo must be
-- a valid VkRenderPass
--
--
--
-- - If flags contains
-- VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT, the
-- subpass member of pInheritanceInfo must be a
-- valid subpass index within the renderPass member of
-- pInheritanceInfo
-- - If flags contains
-- VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT, the
-- framebuffer member of pInheritanceInfo must
-- be either VK_NULL_HANDLE, or a valid VkFramebuffer
-- that is compatible with the renderPass member of
-- pInheritanceInfo
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO
--
--
--
--
-- See Also
--
-- VkCommandBufferInheritanceInfo,
-- VkCommandBufferUsageFlags, VkStructureType,
-- vkBeginCommandBuffer
data VkCommandBufferBeginInfo
VkCommandBufferBeginInfo :: VkStructureType -> Ptr () -> VkCommandBufferUsageFlags -> Ptr VkCommandBufferInheritanceInfo -> VkCommandBufferBeginInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkCommandBufferBeginInfo] :: VkCommandBufferBeginInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCommandBufferBeginInfo] :: VkCommandBufferBeginInfo -> Ptr ()
-- | flags is a bitmask of VkCommandBufferUsageFlagBits
-- specifying usage behavior for the command buffer.
[$sel:vkFlags:VkCommandBufferBeginInfo] :: VkCommandBufferBeginInfo -> VkCommandBufferUsageFlags
-- | pInheritanceInfo is a pointer to a
-- VkCommandBufferInheritanceInfo structure, which is used if
-- commandBuffer is a secondary command buffer. If this is a
-- primary command buffer, then this value is ignored.
[$sel:vkPInheritanceInfo:VkCommandBufferBeginInfo] :: VkCommandBufferBeginInfo -> Ptr VkCommandBufferInheritanceInfo
-- | VkQueryControlFlags - Bitmask of VkQueryControlFlagBits
--
-- Description
--
-- VkQueryControlFlags is a bitmask type for setting a mask of
-- zero or more VkQueryControlFlagBits.
--
-- See Also
--
-- VkCommandBufferInheritanceInfo, VkQueryControlFlagBits,
-- vkCmdBeginQuery
type VkQueryControlFlags = VkQueryControlFlagBits
-- | VkCommandBufferResetFlags - Bitmask of VkCommandBufferResetFlagBits
--
-- Description
--
-- VkCommandBufferResetFlags is a bitmask type for setting a
-- mask of zero or more VkCommandBufferResetFlagBits.
--
-- See Also
--
-- VkCommandBufferResetFlagBits, vkResetCommandBuffer
type VkCommandBufferResetFlags = VkCommandBufferResetFlagBits
-- | VkCommandBufferUsageFlags - Bitmask of VkCommandBufferUsageFlagBits
--
-- Description
--
-- VkCommandBufferUsageFlags is a bitmask type for setting a
-- mask of zero or more VkCommandBufferUsageFlagBits.
--
-- See Also
--
-- VkCommandBufferBeginInfo, VkCommandBufferUsageFlagBits
type VkCommandBufferUsageFlags = VkCommandBufferUsageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferBeginInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferBeginInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferInheritanceInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferInheritanceInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferAllocateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferAllocateInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferLevel
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferLevel
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferLevel
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferBeginInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferInheritanceInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferAllocateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferUsageFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferResetFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBuffer.VkQueryControlFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferLevel
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBuffer.VkCommandBufferLevel
module Graphics.Vulkan.Core10.DescriptorSet
-- | VkDescriptorType - Specifies the type of a descriptor in a descriptor
-- set
--
-- Description
--
--
--
--
--
-- When a descriptor set is updated via elements of
-- VkWriteDescriptorSet, members of pImageInfo,
-- pBufferInfo and pTexelBufferView are only accessed
-- by the implementation when they correspond to descriptor type being
-- defined - otherwise they are ignored. The members accessed are as
-- follows for each descriptor type:
--
--
-- - For VK_DESCRIPTOR_TYPE_SAMPLER, only the sample
-- member of each element of
-- VkWriteDescriptorSet::pImageInfo is accessed.
-- - For VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, only the
-- imageView and imageLayout members of each element of
-- VkWriteDescriptorSet::pImageInfo are accessed.
-- - For VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, all
-- members of each element of
-- VkWriteDescriptorSet::pImageInfo are accessed.
-- - For VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, all members of
-- each element of VkWriteDescriptorSet::pBufferInfo are
-- accessed.
-- - For VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER, each element of
-- VkWriteDescriptorSet::pTexelBufferView is
-- accessed.
--
--
-- See Also
--
-- VkDescriptorPoolSize, VkDescriptorSetLayoutBinding,
-- VkDescriptorUpdateTemplateEntry, VkWriteDescriptorSet
newtype VkDescriptorType
VkDescriptorType :: Int32 -> VkDescriptorType
-- | VkDescriptorSetLayoutCreateFlagBits - Bitmask specifying descriptor
-- set layout properties
--
-- See Also
--
-- VkDescriptorSetLayoutCreateFlags
newtype VkDescriptorSetLayoutCreateFlagBits
VkDescriptorSetLayoutCreateFlagBits :: VkFlags -> VkDescriptorSetLayoutCreateFlagBits
-- | VkDescriptorPoolCreateFlagBits - Bitmask specifying certain supported
-- operations on a descriptor pool
--
-- See Also
--
-- VkDescriptorPoolCreateFlags
newtype VkDescriptorPoolCreateFlagBits
VkDescriptorPoolCreateFlagBits :: VkFlags -> VkDescriptorPoolCreateFlagBits
-- | VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT specifies
-- that descriptor sets can return their individual allocations to
-- the pool, i.e. all of vkAllocateDescriptorSets,
-- vkFreeDescriptorSets, and vkResetDescriptorPool are
-- allowed. Otherwise, descriptor sets allocated from the pool
-- must not be individually freed back to the pool, i.e. only
-- vkAllocateDescriptorSets and vkResetDescriptorPool are
-- allowed.
-- | VkDescriptorPoolResetFlags - Reserved for future use
--
-- Description
--
-- VkDescriptorPoolResetFlags is a bitmask type for setting a
-- mask, but is currently reserved for future use.
--
-- See Also
--
-- vkResetDescriptorPool
newtype VkDescriptorPoolResetFlags
VkDescriptorPoolResetFlags :: VkFlags -> VkDescriptorPoolResetFlags
-- | VkDescriptorSet - Opaque handle to a descriptor set object
--
-- Description
--
-- See Also
--
-- VkCopyDescriptorSet, VkObjectTableDescriptorSetEntryNVX,
-- VkWriteDescriptorSet, vkAllocateDescriptorSets,
-- vkCmdBindDescriptorSets, vkFreeDescriptorSets,
-- vkUpdateDescriptorSetWithTemplate,
-- vkUpdateDescriptorSetWithTemplateKHR
type VkDescriptorSet = Ptr VkDescriptorSet_T
-- | VkDescriptorPool - Opaque handle to a descriptor pool object
--
-- Description
--
-- See Also
--
-- VkDescriptorSetAllocateInfo, vkCreateDescriptorPool,
-- vkDestroyDescriptorPool, vkFreeDescriptorSets,
-- vkResetDescriptorPool
type VkDescriptorPool = Ptr VkDescriptorPool_T
-- | vkCreateDescriptorSetLayout - Create a new descriptor set layout
--
-- Parameters
--
--
-- - device is the logical device that creates the descriptor
-- set layout.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkDescriptorSetLayoutCreateInfo structure specifying the state
-- of the descriptor set layout object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pSetLayout points to a VkDescriptorSetLayout
-- handle in which the resulting descriptor set layout object is
-- returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDescriptorSetLayoutCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pSetLayout must be a valid pointer to a
-- VkDescriptorSetLayout handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorSetLayout,
-- VkDescriptorSetLayoutCreateInfo, VkDevice
vkCreateDescriptorSetLayout :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorSetLayoutCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pSetLayout" ::: Ptr VkDescriptorSetLayout) -> IO VkResult
-- | vkDestroyDescriptorSetLayout - Destroy a descriptor set layout object
--
-- Parameters
--
--
-- - device is the logical device that destroys the descriptor
-- set layout.
--
--
--
-- - descriptorSetLayout is the descriptor set layout to
-- destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- descriptorSetLayout was created, a compatible set of
-- callbacks must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- descriptorSetLayout was created, pAllocator
-- must be NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If descriptorSetLayout is not VK_NULL_HANDLE,
-- descriptorSetLayout must be a valid
-- VkDescriptorSetLayout handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If descriptorSetLayout is a valid handle, it must
-- have been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorSetLayout must be
-- externally synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorSetLayout,
-- VkDevice
vkDestroyDescriptorSetLayout :: ("device" ::: VkDevice) -> ("descriptorSetLayout" ::: VkDescriptorSetLayout) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkCreateDescriptorPool - Creates a descriptor pool object
--
-- Parameters
--
--
-- - device is the logical device that creates the descriptor
-- pool.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkDescriptorPoolCreateInfo structure specifying the state of
-- the descriptor pool object.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pDescriptorPool points to a VkDescriptorPool
-- handle in which the resulting descriptor pool object is returned.
--
--
-- Description
--
-- pAllocator controls host memory allocation as described in
-- the Memory Allocation chapter.
--
-- The created descriptor pool is returned in pDescriptorPool.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDescriptorPoolCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pDescriptorPool must be a valid pointer to a
-- VkDescriptorPool handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorPool,
-- VkDescriptorPoolCreateInfo, VkDevice
vkCreateDescriptorPool :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorPoolCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pDescriptorPool" ::: Ptr VkDescriptorPool) -> IO VkResult
-- | vkDestroyDescriptorPool - Destroy a descriptor pool object
--
-- Parameters
--
--
-- - device is the logical device that destroys the descriptor
-- pool.
--
--
--
-- - descriptorPool is the descriptor pool to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- When a pool is destroyed, all descriptor sets allocated from the pool
-- are implicitly freed and become invalid. Descriptor sets allocated
-- from a given pool do not need to be freed before destroying that
-- descriptor pool.
--
-- Valid Usage
--
--
-- - All submitted commands that refer to descriptorPool (via
-- any allocated descriptor sets) must have completed
-- execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- descriptorPool was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- descriptorPool was created, pAllocator must
-- be NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If descriptorPool is not VK_NULL_HANDLE,
-- descriptorPool must be a valid
-- VkDescriptorPool handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If descriptorPool is a valid handle, it must have
-- been created, allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorPool must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorPool, VkDevice
vkDestroyDescriptorPool :: ("device" ::: VkDevice) -> ("descriptorPool" ::: VkDescriptorPool) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkResetDescriptorPool - Resets a descriptor pool object
--
-- Parameters
--
--
-- - device is the logical device that owns the descriptor
-- pool.
--
--
--
-- - descriptorPool is the descriptor pool to be reset.
-- - flags is reserved for future use.
--
--
-- Description
--
-- Resetting a descriptor pool recycles all of the resources from all of
-- the descriptor sets allocated from the descriptor pool back to the
-- descriptor pool, and the descriptor sets are implicitly freed.
--
-- Valid Usage
--
--
-- - All uses of descriptorPool (via any allocated descriptor
-- sets) must have completed execution
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - descriptorPool must be a valid
-- VkDescriptorPool handle
-- - flags must be 0
-- - descriptorPool must have been created, allocated,
-- or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorPool must be externally
-- synchronized
--
--
--
-- - Host access to any VkDescriptorSet objects allocated from
-- descriptorPool must be externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDescriptorPool, VkDescriptorPoolResetFlags,
-- VkDevice
vkResetDescriptorPool :: ("device" ::: VkDevice) -> ("descriptorPool" ::: VkDescriptorPool) -> ("flags" ::: VkDescriptorPoolResetFlags) -> IO VkResult
-- | vkAllocateDescriptorSets - Allocate one or more descriptor sets
--
-- Parameters
--
--
-- - device is the logical device that owns the descriptor
-- pool.
--
--
--
-- - pAllocateInfo is a pointer to an instance of the
-- VkDescriptorSetAllocateInfo structure describing parameters of
-- the allocation.
-- - pDescriptorSets is a pointer to an array of
-- VkDescriptorSet handles in which the resulting descriptor set
-- objects are returned.
--
--
-- Description
--
-- The allocated descriptor sets are returned in
-- pDescriptorSets.
--
-- When a descriptor set is allocated, the initial state is largely
-- uninitialized and all descriptors are undefined. However, the
-- descriptor set can be bound in a command buffer without causing
-- errors or exceptions. For descriptor set bindings created with the
-- VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT bit set, all
-- descriptors in that binding that are dynamically used must have
-- been populated before the descriptor set is consumed. For
-- descriptor set bindings created without the
-- VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT bit set, all
-- descriptors in that binding that are statically used must have
-- been populated before the descriptor set is consumed. Entries
-- that are not used by a pipeline can have uninitialized
-- descriptors or descriptors of resources that have been destroyed, and
-- executing a draw or dispatch with such a descriptor set bound does not
-- cause undefined behavior. This means applications need not populate
-- unused entries with dummy descriptors.
--
-- If a call to vkAllocateDescriptorSets would cause the total
-- number of descriptor sets allocated from the pool to exceed the value
-- of VkDescriptorPoolCreateInfo::maxSets used to create
-- pAllocateInfo→descriptorPool, then the allocation
-- may fail due to lack of space in the descriptor pool.
-- Similarly, the allocation may fail due to lack of space if the
-- call to vkAllocateDescriptorSets would cause the number of
-- any given descriptor type to exceed the sum of all the
-- descriptorCount members of each element of
-- VkDescriptorPoolCreateInfo::pPoolSizes with a
-- member equal to that type. If the allocation fails due to no
-- more space in the descriptor pool, and not because of system or device
-- memory exhaustion, then VK_ERROR_OUT_OF_POOL_MEMORY
-- must be returned.
--
-- vkAllocateDescriptorSets can be used to create
-- multiple descriptor sets. If the creation of any of those descriptor
-- sets fails, then the implementation must destroy all
-- successfully created descriptor set objects from this command, set all
-- entries of the pDescriptorSets array to VK_NULL_HANDLE
-- and return the error.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pAllocateInfo must be a valid pointer to a valid
-- VkDescriptorSetAllocateInfo structure
-- - pDescriptorSets must be a valid pointer to an
-- array of pAllocateInfo::descriptorSetCount
-- VkDescriptorSet handles
--
--
-- Host Synchronization
--
--
-- - Host access to pAllocateInfo::descriptorPool must
-- be externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDescriptorSet, VkDescriptorSetAllocateInfo,
-- VkDevice
vkAllocateDescriptorSets :: ("device" ::: VkDevice) -> ("pAllocateInfo" ::: Ptr VkDescriptorSetAllocateInfo) -> ("pDescriptorSets" ::: Ptr VkDescriptorSet) -> IO VkResult
-- | vkFreeDescriptorSets - Free one or more descriptor sets
--
-- Parameters
--
--
-- - device is the logical device that owns the descriptor
-- pool.
--
--
--
-- - descriptorPool is the descriptor pool from which the
-- descriptor sets were allocated.
-- - descriptorSetCount is the number of elements in the
-- pDescriptorSets array.
-- - pDescriptorSets is an array of handles to
-- VkDescriptorSet objects.
--
--
-- Description
--
-- After a successful call to vkFreeDescriptorSets, all
-- descriptor sets in pDescriptorSets are invalid.
--
-- Valid Usage
--
--
-- - All submitted commands that refer to any element of
-- pDescriptorSets must have completed execution
--
--
--
-- - pDescriptorSets must be a valid pointer to an
-- array of descriptorSetCount VkDescriptorSet handles,
-- each element of which must either be a valid handle or
-- VK_NULL_HANDLE
-- - Each valid handle in pDescriptorSets must have
-- been allocated from descriptorPool
-- - descriptorPool must have been created with the
-- VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT flag
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - descriptorPool must be a valid
-- VkDescriptorPool handle
-- - descriptorSetCount must be greater than
-- 0
-- - descriptorPool must have been created, allocated,
-- or retrieved from device
-- - Each element of pDescriptorSets that is a valid handle
-- must have been created, allocated, or retrieved from
-- descriptorPool
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorPool must be externally
-- synchronized
--
--
--
-- - Host access to each member of pDescriptorSets must
-- be externally synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDescriptorPool, VkDescriptorSet, VkDevice
vkFreeDescriptorSets :: ("device" ::: VkDevice) -> ("descriptorPool" ::: VkDescriptorPool) -> ("descriptorSetCount" ::: Word32) -> ("pDescriptorSets" ::: Ptr VkDescriptorSet) -> IO VkResult
-- | vkUpdateDescriptorSets - Update the contents of a descriptor set
-- object
--
-- Parameters
--
--
-- - device is the logical device that updates the descriptor
-- sets.
--
--
--
-- - descriptorWriteCount is the number of elements in the
-- pDescriptorWrites array.
-- - pDescriptorWrites is a pointer to an array of
-- VkWriteDescriptorSet structures describing the descriptor sets
-- to write to.
-- - descriptorCopyCount is the number of elements in the
-- pDescriptorCopies array.
-- - pDescriptorCopies is a pointer to an array of
-- VkCopyDescriptorSet structures describing the descriptor sets
-- to copy between.
--
--
-- Description
--
-- The operations described by pDescriptorWrites are performed
-- first, followed by the operations described by
-- pDescriptorCopies. Within each array, the operations are
-- performed in the order they appear in the array.
--
-- Each element in the pDescriptorWrites array describes an
-- operation updating the descriptor set using descriptors for resources
-- specified in the structure.
--
-- Each element in the pDescriptorCopies array is a
-- VkCopyDescriptorSet structure describing an operation copying
-- descriptors between sets.
--
-- If the dstSet member of any element of
-- pDescriptorWrites or pDescriptorCopies is bound,
-- accessed, or modified by any command that was recorded to a command
-- buffer which is currently in the recording or executable state,
-- and any of the descriptor bindings that are updated were not created
-- with the VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT or
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- bits set, that command buffer becomes invalid.
--
-- Valid Usage
--
--
-- - Descriptor bindings updated by this command which were created
-- without the VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- or VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- bits set must not be used by any command that was recorded to a
-- command buffer which is in the pending state.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If descriptorWriteCount is not 0,
-- pDescriptorWrites must be a valid pointer to an array
-- of descriptorWriteCount valid VkWriteDescriptorSet
-- structures
-- - If descriptorCopyCount is not 0,
-- pDescriptorCopies must be a valid pointer to an array
-- of descriptorCopyCount valid VkCopyDescriptorSet
-- structures
--
--
-- Host Synchronization
--
--
-- - Host access to pDescriptorWrites[].dstSet must be
-- externally synchronized
--
--
--
-- - Host access to pDescriptorCopies[].dstSet must be
-- externally synchronized
--
--
-- See Also
--
-- VkCopyDescriptorSet, VkDevice,
-- VkWriteDescriptorSet
vkUpdateDescriptorSets :: ("device" ::: VkDevice) -> ("descriptorWriteCount" ::: Word32) -> ("pDescriptorWrites" ::: Ptr VkWriteDescriptorSet) -> ("descriptorCopyCount" ::: Word32) -> ("pDescriptorCopies" ::: Ptr VkCopyDescriptorSet) -> IO ()
-- | VkDescriptorBufferInfo - Structure specifying descriptor buffer info
--
-- Description
--
-- Note
--
-- When setting range to VK_WHOLE_SIZE, the effective
-- range must not be larger than the maximum range for the
-- descriptor type (maxUniformBufferRange or
-- maxStorageBufferRange). This means that VK_WHOLE_SIZE
-- is not typically useful in the common case where uniform buffer
-- descriptors are suballocated from a buffer that is much larger than
-- maxUniformBufferRange.
--
-- For VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC and
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC descriptor types,
-- offset is the base offset from which the dynamic offset is
-- applied and range is the static size used for all dynamic
-- offsets.
--
-- Valid Usage
--
--
-- - offset must be less than the size of
-- buffer
--
--
--
-- - If range is not equal to VK_WHOLE_SIZE,
-- range must be greater than 0
-- - If range is not equal to VK_WHOLE_SIZE,
-- range must be less than or equal to the size of
-- buffer minus offset
--
--
-- Valid Usage (Implicit)
--
--
-- - buffer must be a valid VkBuffer
-- handle
--
--
-- See Also
--
-- VkBuffer, VkDeviceSize, VkWriteDescriptorSet
data VkDescriptorBufferInfo
VkDescriptorBufferInfo :: VkBuffer -> VkDeviceSize -> VkDeviceSize -> VkDescriptorBufferInfo
-- | buffer is the buffer resource.
[$sel:vkBuffer:VkDescriptorBufferInfo] :: VkDescriptorBufferInfo -> VkBuffer
-- | offset is the offset in bytes from the start of
-- buffer. Access to buffer memory via this descriptor uses
-- addressing that is relative to this starting offset.
[$sel:vkOffset:VkDescriptorBufferInfo] :: VkDescriptorBufferInfo -> VkDeviceSize
-- | range is the size in bytes that is used for this descriptor
-- update, or VK_WHOLE_SIZE to use the range from
-- offset to the end of the buffer.
[$sel:vkRange:VkDescriptorBufferInfo] :: VkDescriptorBufferInfo -> VkDeviceSize
-- | VkDescriptorImageInfo - Structure specifying descriptor image info
--
-- Description
--
-- Members of VkDescriptorImageInfo that are not used in an
-- update (as described above) are ignored.
--
-- Valid Usage
--
--
-- - imageView must not be 2D or 2D array image view
-- created from a 3D image
--
--
--
-- - imageLayout must match the actual
-- VkImageLayout of each subresource accessible from
-- imageView at the time this descriptor is accessed
-- - If sampler is used and enables sampler Y’CBCR
-- conversion:
- The format of the imageView
-- must be the same as the VkFormat of the
-- image
- The aspectMask of the imageView
-- must be VK_IMAGE_ASPECT_COLOR_BIT
- The
-- components.a of the imageView must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
- The
-- components.r of the imageView must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
- The
-- components.g of the imageView must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
- The
-- components.b of the imageView must be
-- VK_COMPONENT_SWIZZLE_IDENTITY
- The pNext
-- chain of the imageView must contain a
-- VkSamplerYcbcrConversionInfo which has a conversion
-- which is an identically defined object to the
-- conversion of the VkSamplerYcbcrConversionInfo which
-- is in the pNext chain of the sampler
-- - If sampler is used and does not enable sampler Y’CBCR
-- conversion and the VkFormat of the image is a
-- multi-planar format, the image must have been created
-- with VK_IMAGE_CREATE_MUTABLE_FORMAT_BIT, and the
-- aspectMask of the imageView must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT or (for three-plane formats only)
-- VK_IMAGE_ASPECT_PLANE_2_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - Both of imageView, and sampler that are valid
-- handles must have been created, allocated, or retrieved from
-- the same VkDevice
--
--
-- See Also
--
-- VkImageLayout, VkImageView, VkSampler,
-- VkWriteDescriptorSet
data VkDescriptorImageInfo
VkDescriptorImageInfo :: VkSampler -> VkImageView -> VkImageLayout -> VkDescriptorImageInfo
-- | sampler is a sampler handle, and is used in descriptor
-- updates for types VK_DESCRIPTOR_TYPE_SAMPLER and
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER if the binding
-- being updated does not use immutable samplers.
[$sel:vkSampler:VkDescriptorImageInfo] :: VkDescriptorImageInfo -> VkSampler
-- | imageView is an image view handle, and is used in descriptor
-- updates for types VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, and
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT.
[$sel:vkImageView:VkDescriptorImageInfo] :: VkDescriptorImageInfo -> VkImageView
-- | imageLayout is the layout that the image subresources
-- accessible from imageView will be in at the time this
-- descriptor is accessed. imageLayout is used in descriptor
-- updates for types VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, and
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT.
[$sel:vkImageLayout:VkDescriptorImageInfo] :: VkDescriptorImageInfo -> VkImageLayout
-- | VkWriteDescriptorSet - Structure specifying the parameters of a
-- descriptor set write operation
--
-- Description
--
-- Only one of pImageInfo, pBufferInfo, or
-- pTexelBufferView members is used according to the descriptor
-- type specified in the descriptorType member of the containing
-- VkWriteDescriptorSet structure, as specified below.
--
-- If the dstBinding has fewer than descriptorCount
-- array elements remaining starting from dstArrayElement, then
-- the remainder will be used to update the subsequent binding -
-- dstBinding+1 starting at array element zero. If a binding has
-- a descriptorCount of zero, it is skipped. This behavior
-- applies recursively, with the update affecting consecutive bindings as
-- needed to update all descriptorCount descriptors.
--
-- Valid Usage
--
--
-- - dstBinding must be less than or equal to the
-- maximum value of binding of all
-- VkDescriptorSetLayoutBinding structures specified when
-- dstSet’s descriptor set layout was created
--
--
--
-- - dstBinding must be a binding with a non-zero
-- descriptorCount
-- - All consecutive bindings updated via a single
-- VkWriteDescriptorSet structure, except those with a
-- descriptorCount of zero, must have identical
-- descriptorType and stageFlags.
-- - All consecutive bindings updated via a single
-- VkWriteDescriptorSet structure, except those with a
-- descriptorCount of zero, must all either use immutable
-- samplers or must all not use immutable samplers.
-- - descriptorType must match the type of
-- dstBinding within dstSet
-- - dstSet must be a valid VkDescriptorSet
-- handle
-- - The sum of dstArrayElement and descriptorCount
-- must be less than or equal to the number of array elements in
-- the descriptor set binding specified by dstBinding, and all
-- applicable consecutive bindings, as described by
-- {html_spec_relative}#descriptorsets-updates-consecutive
-- - If descriptorType is VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, pImageInfo
-- must be a valid pointer to an array of descriptorCount
-- valid VkDescriptorImageInfo structures
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER,
-- pTexelBufferView must be a valid pointer to an array
-- of descriptorCount valid VkBufferView handles
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC,
-- pBufferInfo must be a valid pointer to an array of
-- descriptorCount valid VkDescriptorBufferInfo
-- structures
-- - If descriptorType is VK_DESCRIPTOR_TYPE_SAMPLER
-- or VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, and
-- dstSet was not allocated with a layout that included
-- immutable samplers for dstBinding with
-- descriptorType, the sampler member of each element
-- of pImageInfo must be a valid VkSampler
-- object
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE,
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, the imageView
-- and imageLayout members of each element of
-- pImageInfo must be a valid VkImageView and
-- VkImageLayout, respectively
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, for each descriptor that
-- will be accessed via load or store operations the imageLayout
-- member for corresponding elements of pImageInfo must
-- be VK_IMAGE_LAYOUT_GENERAL
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, the
-- offset member of each element of pBufferInfo
-- must be a multiple of
-- VkPhysicalDeviceLimits::minUniformBufferOffsetAlignment
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, the
-- offset member of each element of pBufferInfo
-- must be a multiple of
-- VkPhysicalDeviceLimits::minStorageBufferOffsetAlignment
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC,
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER, or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, and the
-- buffer member of any element of pBufferInfo is the
-- handle of a non-sparse buffer, then that buffer must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, the
-- buffer member of each element of pBufferInfo
-- must have been created with
-- VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, the
-- buffer member of each element of pBufferInfo
-- must have been created with
-- VK_BUFFER_USAGE_STORAGE_BUFFER_BIT set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, the range
-- member of each element of pBufferInfo, or the effective range
-- if range is VK_WHOLE_SIZE, must be less than
-- or equal to
-- VkPhysicalDeviceLimits::maxUniformBufferRange
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC, the range
-- member of each element of pBufferInfo, or the effective range
-- if range is VK_WHOLE_SIZE, must be less than
-- or equal to
-- VkPhysicalDeviceLimits::maxStorageBufferRange
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER, the
-- VkBuffer that each element of pTexelBufferView was
-- created from must have been created with
-- VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER, the
-- VkBuffer that each element of pTexelBufferView was
-- created from must have been created with
-- VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, the imageView
-- member of each element of pImageInfo must have been
-- created with the identity swizzle
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, the
-- imageView member of each element of pImageInfo
-- must have been created with VK_IMAGE_USAGE_SAMPLED_BIT
-- set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, the
-- imageLayout member of each element of pImageInfo
-- must be VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL,
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT, the imageView
-- member of each element of pImageInfo must have been
-- created with VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT set
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE, the imageView
-- member of each element of pImageInfo must have been
-- created with VK_IMAGE_USAGE_STORAGE_BIT set
-- - All consecutive bindings updated via a single
-- VkWriteDescriptorSet structure, except those with a
-- descriptorCount of zero, must have identical
-- VkDescriptorBindingFlagBitsEXT.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET
--
--
--
-- - pNext must be NULL
-- - descriptorType must be a valid
-- VkDescriptorType value
-- - descriptorCount must be greater than
-- 0
-- - Both of dstSet, and the elements of
-- pTexelBufferView that are valid handles must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkBufferView, VkDescriptorBufferInfo,
-- VkDescriptorImageInfo, VkDescriptorSet,
-- VkDescriptorType, VkStructureType,
-- vkCmdPushDescriptorSetKHR, vkUpdateDescriptorSets
data VkWriteDescriptorSet
VkWriteDescriptorSet :: VkStructureType -> Ptr () -> VkDescriptorSet -> Word32 -> Word32 -> Word32 -> VkDescriptorType -> Ptr VkDescriptorImageInfo -> Ptr VkDescriptorBufferInfo -> Ptr VkBufferView -> VkWriteDescriptorSet
-- | sType is the type of this structure.
[$sel:vkSType:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Ptr ()
-- | dstSet is the destination descriptor set to update.
[$sel:vkDstSet:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> VkDescriptorSet
-- | dstBinding is the descriptor binding within that set.
[$sel:vkDstBinding:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Word32
-- | dstArrayElement is the starting element in that array.
[$sel:vkDstArrayElement:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Word32
-- | descriptorCount is the number of descriptors to update (the
-- number of elements in pImageInfo, pBufferInfo, or
-- pTexelBufferView).
[$sel:vkDescriptorCount:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Word32
-- | descriptorType is a VkDescriptorType specifying the
-- type of each descriptor in pImageInfo, pBufferInfo,
-- or pTexelBufferView, as described below. It must be
-- the same type as that specified in
-- VkDescriptorSetLayoutBinding for dstSet at
-- dstBinding. The type of the descriptor also controls which
-- array the descriptors are taken from.
[$sel:vkDescriptorType:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> VkDescriptorType
-- | pImageInfo points to an array of VkDescriptorImageInfo
-- structures or is ignored, as described below.
[$sel:vkPImageInfo:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Ptr VkDescriptorImageInfo
-- | pBufferInfo points to an array of
-- VkDescriptorBufferInfo structures or is ignored, as described
-- below.
[$sel:vkPBufferInfo:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Ptr VkDescriptorBufferInfo
-- | pTexelBufferView points to an array of VkBufferView
-- handles as described in the Buffer Views section or is ignored,
-- as described below.
[$sel:vkPTexelBufferView:VkWriteDescriptorSet] :: VkWriteDescriptorSet -> Ptr VkBufferView
-- | VkCopyDescriptorSet - Structure specifying a copy descriptor set
-- operation
--
-- Description
--
-- Valid Usage
--
--
-- - srcBinding must be a valid binding within
-- srcSet
--
--
--
-- - The sum of srcArrayElement and descriptorCount
-- must be less than or equal to the number of array elements in
-- the descriptor set binding specified by srcBinding, and all
-- applicable consecutive bindings, as described by
-- {html_spec_relative}#descriptorsets-updates-consecutive
-- - dstBinding must be a valid binding within
-- dstSet
-- - The sum of dstArrayElement and descriptorCount
-- must be less than or equal to the number of array elements in
-- the descriptor set binding specified by dstBinding, and all
-- applicable consecutive bindings, as described by
-- {html_spec_relative}#descriptorsets-updates-consecutive
-- - If srcSet is equal to dstSet, then the source
-- and destination ranges of descriptors must not overlap, where
-- the ranges may include array elements from consecutive bindings
-- as described by
-- {html_spec_relative}#descriptorsets-updates-consecutive
-- - If srcSet’s layout was created with the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- flag set, then dstSet’s layout must also have been
-- created with the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- flag set
-- - If srcSet’s layout was created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- flag set, then dstSet’s layout must also have been
-- created without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- flag set
-- - If the descriptor pool from which srcSet was allocated
-- was created with the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT flag set,
-- then the descriptor pool from which dstSet was allocated
-- must also have been created with the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT flag
-- set
-- - If the descriptor pool from which srcSet was allocated
-- was created without the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT flag set,
-- then the descriptor pool from which dstSet was allocated
-- must also have been created without the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT flag
-- set
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET
--
--
--
-- - pNext must be NULL
-- - srcSet must be a valid VkDescriptorSet
-- handle
-- - dstSet must be a valid VkDescriptorSet
-- handle
-- - Both of dstSet, and srcSet must have been
-- created, allocated, or retrieved from the same VkDevice
--
--
-- See Also
--
-- VkDescriptorSet, VkStructureType,
-- vkUpdateDescriptorSets
data VkCopyDescriptorSet
VkCopyDescriptorSet :: VkStructureType -> Ptr () -> VkDescriptorSet -> Word32 -> Word32 -> VkDescriptorSet -> Word32 -> Word32 -> Word32 -> VkCopyDescriptorSet
-- | sType is the type of this structure.
[$sel:vkSType:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Ptr ()
-- | srcSet, srcBinding, and srcArrayElement are
-- the source set, binding, and array element, respectively.
[$sel:vkSrcSet:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> VkDescriptorSet
[$sel:vkSrcBinding:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Word32
[$sel:vkSrcArrayElement:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Word32
-- | dstSet, dstBinding, and dstArrayElement are
-- the destination set, binding, and array element, respectively.
[$sel:vkDstSet:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> VkDescriptorSet
[$sel:vkDstBinding:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Word32
[$sel:vkDstArrayElement:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Word32
-- | descriptorCount is the number of descriptors to copy from the
-- source to destination. If descriptorCount is greater than the
-- number of remaining array elements in the source or destination
-- binding, those affect consecutive bindings in a manner similar to
-- VkWriteDescriptorSet above.
[$sel:vkDescriptorCount:VkCopyDescriptorSet] :: VkCopyDescriptorSet -> Word32
-- | VkDescriptorSetLayoutBinding - Structure specifying a descriptor set
-- layout binding
--
-- Members
--
--
-- - binding is the binding number of this entry and
-- corresponds to a resource of the same binding number in the shader
-- stages.
--
--
--
-- - descriptorType is a VkDescriptorType specifying
-- which type of resource descriptors are used for this binding.
-- - descriptorCount is the number of descriptors contained in
-- the binding, accessed in a shader as an array. If
-- descriptorCount is zero this binding entry is reserved and
-- the resource must not be accessed from any stage via this
-- binding within any pipeline using the set layout.
-- - stageFlags member is a bitmask of
-- VkShaderStageFlagBits specifying which pipeline shader stages
-- can access a resource for this binding.
-- VK_SHADER_STAGE_ALL is a shorthand specifying that all
-- defined shader stages, including any additional stages defined by
-- extensions, can access the resource.If a shader stage is not
-- included in stageFlags, then a resource must not be
-- accessed from that stage via this binding within any pipeline using
-- the set layout. Other than input attachments which are limited to the
-- fragment shader, there are no limitations on what combinations of
-- stages can use a descriptor binding, and in particular a
-- binding can be used by both graphics stages and the compute
-- stage.
--
--
-- Description
--
--
-- - pImmutableSamplers affects initialization of samplers. If
-- descriptorType specifies a
-- VK_DESCRIPTOR_TYPE_SAMPLER or
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER type descriptor,
-- then pImmutableSamplers can be used to initialize a
-- set of /immutable samplers/. Immutable samplers are permanently bound
-- into the set layout; later binding a sampler into an immutable sampler
-- slot in a descriptor set is not allowed. If
-- pImmutableSamplers is not NULL, then it is
-- considered to be a pointer to an array of sampler handles that will be
-- consumed by the set layout and used for the corresponding binding. If
-- pImmutableSamplers is NULL, then the sampler slots
-- are dynamic and sampler handles must be bound into descriptor
-- sets using this layout. If descriptorType is not one of these
-- descriptor types, then pImmutableSamplers is ignored.
--
--
-- The above layout definition allows the descriptor bindings to be
-- specified sparsely such that not all binding numbers between 0 and the
-- maximum binding number need to be specified in the pBindings
-- array. Bindings that are not specified have a descriptorCount
-- and stageFlags of zero, and the descriptorType is
-- treated as undefined. However, all binding numbers between 0 and the
-- maximum binding number in the
-- VkDescriptorSetLayoutCreateInfo::pBindings array
-- may consume memory in the descriptor set layout even if not all
-- descriptor bindings are used, though it should not consume
-- additional memory from the descriptor pool.
--
-- Note
--
-- The maximum binding number specified should be as compact as
-- possible to avoid wasted memory.
--
-- Valid Usage
--
--
-- - If descriptorType is VK_DESCRIPTOR_TYPE_SAMPLER
-- or VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, and
-- descriptorCount is not 0 and
-- pImmutableSamplers is not NULL,
-- pImmutableSamplers must be a valid pointer to an array
-- of descriptorCount valid VkSampler handles
--
--
--
-- - If descriptorCount is not 0, stageFlags
-- must be a valid combination of VkShaderStageFlagBits
-- values
-- - If descriptorType is
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT and
-- descriptorCount is not 0, then stageFlags
-- must be 0 or
-- VK_SHADER_STAGE_FRAGMENT_BIT
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkDescriptorSetLayoutCreateInfo, VkDescriptorType,
-- VkSampler, VkShaderStageFlags
data VkDescriptorSetLayoutBinding
VkDescriptorSetLayoutBinding :: Word32 -> VkDescriptorType -> Word32 -> VkShaderStageFlags -> Ptr VkSampler -> VkDescriptorSetLayoutBinding
[$sel:vkBinding:VkDescriptorSetLayoutBinding] :: VkDescriptorSetLayoutBinding -> Word32
[$sel:vkDescriptorType:VkDescriptorSetLayoutBinding] :: VkDescriptorSetLayoutBinding -> VkDescriptorType
[$sel:vkDescriptorCount:VkDescriptorSetLayoutBinding] :: VkDescriptorSetLayoutBinding -> Word32
[$sel:vkStageFlags:VkDescriptorSetLayoutBinding] :: VkDescriptorSetLayoutBinding -> VkShaderStageFlags
[$sel:vkPImmutableSamplers:VkDescriptorSetLayoutBinding] :: VkDescriptorSetLayoutBinding -> Ptr VkSampler
-- | VkDescriptorSetLayoutCreateInfo - Structure specifying parameters of a
-- newly created descriptor set layout
--
-- Description
--
-- Valid Usage
--
--
--
--
-- - If flags contains
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR, then
-- all elements of pBindings must not have a
-- descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC
-- - If flags contains
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR, then
-- the total number of elements of all bindings must be less than
-- or equal to
-- VkPhysicalDevicePushDescriptorPropertiesKHR::maxPushDescriptors
-- - If any binding has the
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT bit set,
-- flags must include
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- - If any binding has the
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT bit set, then
-- all bindings must not have descriptorType of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO
--
--
--
--
-- See Also
--
-- VkDescriptorSetLayoutBinding,
-- VkDescriptorSetLayoutCreateFlags, VkStructureType,
-- vkCreateDescriptorSetLayout,
-- vkGetDescriptorSetLayoutSupport,
-- vkGetDescriptorSetLayoutSupportKHR
data VkDescriptorSetLayoutCreateInfo
VkDescriptorSetLayoutCreateInfo :: VkStructureType -> Ptr () -> VkDescriptorSetLayoutCreateFlags -> Word32 -> Ptr VkDescriptorSetLayoutBinding -> VkDescriptorSetLayoutCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetLayoutCreateInfo] :: VkDescriptorSetLayoutCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetLayoutCreateInfo] :: VkDescriptorSetLayoutCreateInfo -> Ptr ()
-- | flags is a bitmask of
-- VkDescriptorSetLayoutCreateFlagBits specifying options for
-- descriptor set layout creation.
[$sel:vkFlags:VkDescriptorSetLayoutCreateInfo] :: VkDescriptorSetLayoutCreateInfo -> VkDescriptorSetLayoutCreateFlags
-- | bindingCount is the number of elements in pBindings.
[$sel:vkBindingCount:VkDescriptorSetLayoutCreateInfo] :: VkDescriptorSetLayoutCreateInfo -> Word32
-- | pBindings is a pointer to an array of
-- VkDescriptorSetLayoutBinding structures.
[$sel:vkPBindings:VkDescriptorSetLayoutCreateInfo] :: VkDescriptorSetLayoutCreateInfo -> Ptr VkDescriptorSetLayoutBinding
-- | VkDescriptorPoolSize - Structure specifying descriptor pool size
--
-- Description
--
-- Valid Usage
--
--
-- - descriptorCount must be greater than
-- 0
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkDescriptorPoolCreateInfo, VkDescriptorType
data VkDescriptorPoolSize
VkDescriptorPoolSize :: VkDescriptorType -> Word32 -> VkDescriptorPoolSize
-- | type is the type of descriptor.
[$sel:vkType:VkDescriptorPoolSize] :: VkDescriptorPoolSize -> VkDescriptorType
-- | descriptorCount is the number of descriptors of that type to
-- allocate.
[$sel:vkDescriptorCount:VkDescriptorPoolSize] :: VkDescriptorPoolSize -> Word32
-- | VkDescriptorPoolCreateInfo - Structure specifying parameters of a
-- newly created descriptor pool
--
-- Description
--
-- If multiple VkDescriptorPoolSize structures appear in the
-- pPoolSizes array then the pool will be created with enough
-- storage for the total number of descriptors of each type.
--
-- Fragmentation of a descriptor pool is possible and may lead to
-- descriptor set allocation failures. A failure due to fragmentation is
-- defined as failing a descriptor set allocation despite the sum of all
-- outstanding descriptor set allocations from the pool plus the
-- requested allocation requiring no more than the total number of
-- descriptors requested at pool creation. Implementations provide
-- certain guarantees of when fragmentation must not cause
-- allocation failure, as described below.
--
-- If a descriptor pool has not had any descriptor sets freed since it
-- was created or most recently reset then fragmentation must not
-- cause an allocation failure (note that this is always the case for a
-- pool created without the
-- VK_DESCRIPTOR_POOL_CREATE_FREE_DESCRIPTOR_SET_BIT bit set).
-- Additionally, if all sets allocated from the pool since it was created
-- or most recently reset use the same number of descriptors (of each
-- type) and the requested allocation also uses that same number of
-- descriptors (of each type), then fragmentation must not cause
-- an allocation failure.
--
-- If an allocation failure occurs due to fragmentation, an application
-- can create an additional descriptor pool to perform further
-- descriptor set allocations.
--
-- If flags has the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT bit set,
-- descriptor pool creation may fail with the error
-- VK_ERROR_FRAGMENTATION_EXT if the total number of descriptors
-- across all pools (including this one) created with this bit set
-- exceeds maxUpdateAfterBindDescriptorsInAllPools, or if
-- fragmentation of the underlying hardware resources occurs.
--
-- Valid Usage
--
--
-- - maxSets must be greater than 0
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be a valid combination of
-- VkDescriptorPoolCreateFlagBits values
-- - pPoolSizes must be a valid pointer to an array of
-- poolSizeCount valid VkDescriptorPoolSize
-- structures
-- - poolSizeCount must be greater than 0
--
--
-- See Also
--
-- VkDescriptorPoolCreateFlags, VkDescriptorPoolSize,
-- VkStructureType, vkCreateDescriptorPool
data VkDescriptorPoolCreateInfo
VkDescriptorPoolCreateInfo :: VkStructureType -> Ptr () -> VkDescriptorPoolCreateFlags -> Word32 -> Word32 -> Ptr VkDescriptorPoolSize -> VkDescriptorPoolCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> Ptr ()
-- | flags is a bitmask of VkDescriptorPoolCreateFlagBits
-- specifying certain supported operations on the pool.
[$sel:vkFlags:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> VkDescriptorPoolCreateFlags
-- | maxSets is the maximum number of descriptor sets that
-- can be allocated from the pool.
[$sel:vkMaxSets:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> Word32
-- | poolSizeCount is the number of elements in
-- pPoolSizes.
[$sel:vkPoolSizeCount:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> Word32
-- | pPoolSizes is a pointer to an array of
-- VkDescriptorPoolSize structures, each containing a descriptor
-- type and number of descriptors of that type to be allocated in the
-- pool.
[$sel:vkPPoolSizes:VkDescriptorPoolCreateInfo] :: VkDescriptorPoolCreateInfo -> Ptr VkDescriptorPoolSize
-- | VkDescriptorSetAllocateInfo - Structure specifying the allocation
-- parameters for descriptor sets
--
-- Description
--
-- Valid Usage
--
--
-- - Each element of pSetLayouts must not have been
-- created with
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
-- set
--
--
--
-- - If any element of pSetLayouts was created with the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set, descriptorPool must have been created with
-- the VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT flag
-- set
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_ALLOCATE_INFO
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of
-- VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
-- - descriptorPool must be a valid
-- VkDescriptorPool handle
-- - pSetLayouts must be a valid pointer to an array of
-- descriptorSetCount valid VkDescriptorSetLayout
-- handles
-- - descriptorSetCount must be greater than
-- 0
-- - Both of descriptorPool, and the elements of
-- pSetLayouts must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- See Also
--
-- VkDescriptorPool, VkDescriptorSetLayout,
-- VkStructureType, vkAllocateDescriptorSets
data VkDescriptorSetAllocateInfo
VkDescriptorSetAllocateInfo :: VkStructureType -> Ptr () -> VkDescriptorPool -> Word32 -> Ptr VkDescriptorSetLayout -> VkDescriptorSetAllocateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetAllocateInfo] :: VkDescriptorSetAllocateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetAllocateInfo] :: VkDescriptorSetAllocateInfo -> Ptr ()
-- | descriptorPool is the pool which the sets will be allocated
-- from.
[$sel:vkDescriptorPool:VkDescriptorSetAllocateInfo] :: VkDescriptorSetAllocateInfo -> VkDescriptorPool
-- | descriptorSetCount determines the number of descriptor sets
-- to be allocated from the pool.
[$sel:vkDescriptorSetCount:VkDescriptorSetAllocateInfo] :: VkDescriptorSetAllocateInfo -> Word32
-- | pSetLayouts is an array of descriptor set layouts, with each
-- member specifying how the corresponding descriptor set is allocated.
[$sel:vkPSetLayouts:VkDescriptorSetAllocateInfo] :: VkDescriptorSetAllocateInfo -> Ptr VkDescriptorSetLayout
-- | VkDescriptorSetLayoutCreateFlags - Bitmask of
-- VkDescriptorSetLayoutCreateFlagBits
--
-- Description
--
-- VkDescriptorSetLayoutCreateFlags is a bitmask type for
-- setting a mask of zero or more
-- VkDescriptorSetLayoutCreateFlagBits.
--
-- See Also
--
-- VkDescriptorSetLayoutCreateFlagBits,
-- VkDescriptorSetLayoutCreateInfo
type VkDescriptorSetLayoutCreateFlags = VkDescriptorSetLayoutCreateFlagBits
-- | VkDescriptorPoolCreateFlags - Bitmask of
-- VkDescriptorPoolCreateFlagBits
--
-- Description
--
-- VkDescriptorPoolCreateFlags is a bitmask type for setting a
-- mask of zero or more VkDescriptorPoolCreateFlagBits.
--
-- See Also
--
-- VkDescriptorPoolCreateFlagBits,
-- VkDescriptorPoolCreateInfo
type VkDescriptorPoolCreateFlags = VkDescriptorPoolCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetAllocateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetAllocateInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolSize
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolSize
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutBinding
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutBinding
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkCopyDescriptorSet
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkCopyDescriptorSet
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkWriteDescriptorSet
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkWriteDescriptorSet
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorImageInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorImageInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorBufferInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorBufferInfo
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance Data.Bits.Bits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetAllocateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolSize
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutBinding
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkCopyDescriptorSet
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkWriteDescriptorSet
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorImageInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorBufferInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance GHC.Read.Read Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolResetFlags
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorPoolCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorSetLayoutCreateFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorType
instance GHC.Read.Read Graphics.Vulkan.Core10.DescriptorSet.VkDescriptorType
module Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing
-- | VkDescriptorBindingFlagBitsEXT - Bitmask specifying descriptor set
-- layout binding properties
--
-- Description
--
--
-- - VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT indicates
-- that if descriptors in this binding are updated between when the
-- descriptor set is bound in a command buffer and when that command
-- buffer is submitted to a queue, then the submission will use the most
-- recently set descriptors for this binding and the updates do not
-- invalidate the command buffer. Descriptor bindings created with this
-- flag are also partially exempt from the external synchronization
-- requirement in vkUpdateDescriptorSetWithTemplateKHR and
-- vkUpdateDescriptorSets. They can be updated concurrently
-- with the set being bound to a command buffer in another thread, but
-- not concurrently with the set being reset or freed.
--
--
--
-- - VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT indicates
-- that descriptors in this binding that are not dynamically used
-- need not contain valid descriptors at the time the descriptors are
-- consumed. A descriptor is dynamically used if any shader invocation
-- executes an instruction that performs any memory access using the
-- descriptor.
-- - VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- indicates that descriptors in this binding can be updated after
-- a command buffer has bound this descriptor set, or while a command
-- buffer that uses this descriptor set is pending execution, as long as
-- the descriptors that are updated are not used by those command
-- buffers. If VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT is
-- also set, then descriptors can be updated as long as they are
-- not dynamically used by any shader invocations. If
-- VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT is not set,
-- then descriptors can be updated as long as they are not
-- statically used by any shader invocations.
-- - VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT
-- indicates that this descriptor binding has a variable size that will
-- be specified when a descriptor set is allocated using this layout. The
-- value of descriptorCount is treated as an upper bound on the
-- size of the binding. This must only be used for the last
-- binding in the descriptor set layout (i.e. the binding with the
-- largest value of binding). For the purposes of counting
-- against limits such as maxDescriptorSet* and
-- maxPerStageDescriptor*, the full value of
-- descriptorCount is counted.
--
--
-- Note
--
-- Note that while
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT and
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- both involve updates to descriptor sets after they are bound,
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT is
-- a weaker requirement since it is only about descriptors that are not
-- used, whereas VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- requires the implementation to observe updates to descriptors that are
-- used.
--
-- See Also
--
-- VkDescriptorBindingFlagsEXT
newtype VkDescriptorBindingFlagBitsEXT
VkDescriptorBindingFlagBitsEXT :: VkFlags -> VkDescriptorBindingFlagBitsEXT
-- |
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- specifies that descriptor sets using this layout must be
-- allocated from a descriptor pool created with the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT bit set.
-- Descriptor set layouts created with this bit set have alternate limits
-- for the maximum number of descriptors per-stage and per-pipeline
-- layout. The non-UpdateAfterBind limits only count descriptors in sets
-- created without this flag. The UpdateAfterBind limits count all
-- descriptors, but the limits may be higher than the
-- non-UpdateAfterBind limits.
-- | VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT specifies
-- that descriptor sets allocated from this pool can include
-- bindings with the
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT bit set. It
-- is valid to allocate descriptor sets that have bindings that don’t set
-- the VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT bit from
-- a pool that has
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT set.
-- | VkPhysicalDeviceDescriptorIndexingFeaturesEXT - Structure describing
-- descriptor indexing features that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT structure
-- describe the following features:
--
-- Description
--
--
-- - shaderInputAttachmentArrayDynamicIndexing indicates
-- whether arrays of input attachments can be indexed by
-- dynamically uniform integer expressions in shader code. If this
-- feature is not enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT must be indexed
-- only by constant integral expressions when aggregated into arrays in
-- shader code. This also indicates whether shader modules can
-- declare the InputAttachmentArrayDynamicIndexingEXT
-- capability.
--
--
--
-- - shaderUniformTexelBufferArrayDynamicIndexing indicates
-- whether arrays of uniform texel buffers can be indexed by
-- dynamically uniform integer expressions in shader code. If this
-- feature is not enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER must be
-- indexed only by constant integral expressions when aggregated into
-- arrays in shader code. This also indicates whether shader modules
-- can declare the
-- UniformTexelBufferArrayDynamicIndexingEXT capability.
-- - shaderStorageTexelBufferArrayDynamicIndexing indicates
-- whether arrays of storage texel buffers can be indexed by
-- dynamically uniform integer expressions in shader code. If this
-- feature is not enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER must be
-- indexed only by constant integral expressions when aggregated into
-- arrays in shader code. This also indicates whether shader modules
-- can declare the
-- StorageTexelBufferArrayDynamicIndexingEXT capability.
-- - shaderUniformBufferArrayNonUniformIndexing indicates
-- whether arrays of uniform buffers can be indexed by non-uniform
-- integer expressions in shader code. If this feature is not enabled,
-- resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC must not be
-- indexed by non-uniform integer expressions when aggregated into arrays
-- in shader code. This also indicates whether shader modules can
-- declare the UniformBufferArrayNonUniformIndexingEXT
-- capability.
-- - shaderSampledImageArrayNonUniformIndexing indicates
-- whether arrays of samplers or sampled images can be indexed by
-- non-uniform integer expressions in shader code. If this feature is not
-- enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, or
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE must not be indexed
-- by non-uniform integer expressions when aggregated into arrays in
-- shader code. This also indicates whether shader modules can
-- declare the SampledImageArrayNonUniformIndexingEXT
-- capability.
-- - shaderStorageBufferArrayNonUniformIndexing indicates
-- whether arrays of storage buffers can be indexed by non-uniform
-- integer expressions in shader code. If this feature is not enabled,
-- resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC must not be
-- indexed by non-uniform integer expressions when aggregated into arrays
-- in shader code. This also indicates whether shader modules can
-- declare the StorageBufferArrayNonUniformIndexingEXT
-- capability.
-- - shaderStorageImageArrayNonUniformIndexing indicates
-- whether arrays of storage images can be indexed by non-uniform
-- integer expressions in shader code. If this feature is not enabled,
-- resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE must not be indexed
-- by non-uniform integer expressions when aggregated into arrays in
-- shader code. This also indicates whether shader modules can
-- declare the StorageImageArrayNonUniformIndexingEXT
-- capability.
-- - shaderInputAttachmentArrayNonUniformIndexing indicates
-- whether arrays of input attachments can be indexed by
-- non-uniform integer expressions in shader code. If this feature is not
-- enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT must not be
-- indexed by non-uniform integer expressions when aggregated into arrays
-- in shader code. This also indicates whether shader modules can
-- declare the InputAttachmentArrayNonUniformIndexingEXT
-- capability.
-- - shaderUniformTexelBufferArrayNonUniformIndexing indicates
-- whether arrays of uniform texel buffers can be indexed by
-- non-uniform integer expressions in shader code. If this feature is not
-- enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER must not be
-- indexed by non-uniform integer expressions when aggregated into arrays
-- in shader code. This also indicates whether shader modules can
-- declare the UniformTexelBufferArrayNonUniformIndexingEXT
-- capability.
-- - shaderStorageTexelBufferArrayNonUniformIndexing indicates
-- whether arrays of storage texel buffers can be indexed by
-- non-uniform integer expressions in shader code. If this feature is not
-- enabled, resources with a descriptor type of
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER must not be
-- indexed by non-uniform integer expressions when aggregated into arrays
-- in shader code. This also indicates whether shader modules can
-- declare the StorageTexelBufferArrayNonUniformIndexingEXT
-- capability.
-- - descriptorBindingUniformBufferUpdateAfterBind indicates
-- whether the implementation supports updating uniform buffer
-- descriptors after a set is bound. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT must
-- not be used with VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER.
-- - descriptorBindingSampledImageUpdateAfterBind indicates
-- whether the implementation supports updating sampled image descriptors
-- after a set is bound. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT must
-- not be used with VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, or
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE.
-- - descriptorBindingStorageImageUpdateAfterBind indicates
-- whether the implementation supports updating storage image descriptors
-- after a set is bound. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT must
-- not be used with VK_DESCRIPTOR_TYPE_STORAGE_IMAGE.
-- - descriptorBindingStorageBufferUpdateAfterBind indicates
-- whether the implementation supports updating storage buffer
-- descriptors after a set is bound. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT must
-- not be used with VK_DESCRIPTOR_TYPE_STORAGE_BUFFER.
-- - descriptorBindingUniformTexelBufferUpdateAfterBind
-- indicates whether the implementation supports updating uniform texel
-- buffer descriptors after a set is bound. If this feature is not
-- enabled, VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- must not be used with
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER.
-- - descriptorBindingStorageTexelBufferUpdateAfterBind
-- indicates whether the implementation supports updating storage texel
-- buffer descriptors after a set is bound. If this feature is not
-- enabled, VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- must not be used with
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER.
-- - descriptorBindingUpdateUnusedWhilePending indicates
-- whether the implementation supports updating descriptors while the set
-- is in use. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- must not be used.
-- - descriptorBindingPartiallyBound indicates whether the
-- implementation supports statically using a descriptor set binding in
-- which some descriptors are not valid. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT must not
-- be used.
-- - descriptorBindingVariableDescriptorCount indicates
-- whether the implementation supports descriptor sets with a
-- variable-sized last binding. If this feature is not enabled,
-- VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT
-- must not be used.
-- - runtimeDescriptorArray indicates whether the
-- implementation supports the SPIR-V RuntimeDescriptorArrayEXT
-- capability. If this feature is not enabled, descriptors must
-- not be declared in runtime arrays.
--
--
-- If the VkPhysicalDeviceDescriptorIndexingFeaturesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceFeatures2KHR, it is filled with values
-- indicating whether each feature is supported.
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT can also
-- be used in the pNext chain of VkDeviceCreateInfo to
-- enable features.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_FEATURES_EXT
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceDescriptorIndexingFeaturesEXT
VkPhysicalDeviceDescriptorIndexingFeaturesEXT :: VkStructureType -> Ptr () -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkPhysicalDeviceDescriptorIndexingFeaturesEXT
[$sel:vkSType:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> Ptr ()
[$sel:vkShaderInputAttachmentArrayDynamicIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderUniformTexelBufferArrayDynamicIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderStorageTexelBufferArrayDynamicIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderUniformBufferArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderSampledImageArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderStorageBufferArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderStorageImageArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderInputAttachmentArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderUniformTexelBufferArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkShaderStorageTexelBufferArrayNonUniformIndexing:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingUniformBufferUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingSampledImageUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingStorageImageUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingStorageBufferUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingUniformTexelBufferUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingStorageTexelBufferUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingUpdateUnusedWhilePending:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingPartiallyBound:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkDescriptorBindingVariableDescriptorCount:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
[$sel:vkRuntimeDescriptorArray:VkPhysicalDeviceDescriptorIndexingFeaturesEXT] :: VkPhysicalDeviceDescriptorIndexingFeaturesEXT -> VkBool32
-- | VkPhysicalDeviceDescriptorIndexingPropertiesEXT - Structure describing
-- descriptor indexing properties that can be supported by an
-- implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDeviceDescriptorIndexingPropertiesEXT structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxUpdateAfterBindDescriptorsInAllPools is the maximum
-- number of descriptors (summed over all descriptor types) that
-- can be created across all pools that are created with the
-- VK_DESCRIPTOR_POOL_CREATE_UPDATE_AFTER_BIND_BIT_EXT bit set.
-- Pool creation may fail when this limit is exceeded, or when the
-- space this limit represents can’t satisfy a pool creation due to
-- fragmentation.
--
--
--
-- - shaderUniformBufferArrayNonUniformIndexingNative is a
-- boolean value indicating whether uniform buffer descriptors natively
-- support nonuniform indexing. If this is VK_FALSE, then a
-- single dynamic instance of an instruction that nonuniformly indexes an
-- array of uniform buffers may execute multiple times in order to
-- access all the descriptors.
-- - shaderSampledImageArrayNonUniformIndexingNative is a
-- boolean value indicating whether sampler and image descriptors
-- natively support nonuniform indexing. If this is VK_FALSE,
-- then a single dynamic instance of an instruction that nonuniformly
-- indexes an array of samplers or images may execute multiple
-- times in order to access all the descriptors.
-- - shaderStorageBufferArrayNonUniformIndexingNative is a
-- boolean value indicating whether storage buffer descriptors natively
-- support nonuniform indexing. If this is VK_FALSE, then a
-- single dynamic instance of an instruction that nonuniformly indexes an
-- array of storage buffers may execute multiple times in order to
-- access all the descriptors.
-- - shaderStorageImageArrayNonUniformIndexingNative is a
-- boolean value indicating whether storage image descriptors natively
-- support nonuniform indexing. If this is VK_FALSE, then a
-- single dynamic instance of an instruction that nonuniformly indexes an
-- array of storage images may execute multiple times in order to
-- access all the descriptors.
-- - shaderInputAttachmentArrayNonUniformIndexingNative is a
-- boolean value indicating whether input attachment descriptors natively
-- support nonuniform indexing. If this is VK_FALSE, then a
-- single dynamic instance of an instruction that nonuniformly indexes an
-- array of input attachments may execute multiple times in order
-- to access all the descriptors.
-- - robustBufferAccessUpdateAfterBind is a boolean value
-- indicating whether robustBufferAccess can be enabled in
-- a device simultaneously with
-- descriptorBindingUniformBufferUpdateAfterBind,
-- descriptorBindingStorageBufferUpdateAfterBind,
-- descriptorBindingUniformTexelBufferUpdateAfterBind, and/or
-- descriptorBindingStorageTexelBufferUpdateAfterBind. If this
-- is VK_FALSE, then either robustBufferAccess
-- must be disabled or all of these update-after-bind features
-- must be disabled.
-- - quadDivergentImplicitLod is a boolean value indicating
-- whether implicit level of detail calculations for image operations
-- have well-defined results when the image and/or sampler objects used
-- for the instruction are not uniform within a quad. See Derivative
-- Image Operations.
-- - maxPerStageDescriptorUpdateAfterBindSamplers is similar
-- to maxPerStageDescriptorSamplers but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageDescriptorUpdateAfterBindUniformBuffers is
-- similar to maxPerStageDescriptorUniformBuffers but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageDescriptorUpdateAfterBindStorageBuffers is
-- similar to maxPerStageDescriptorStorageBuffers but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageDescriptorUpdateAfterBindSampledImages is
-- similar to maxPerStageDescriptorSampledImages but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageDescriptorUpdateAfterBindStorageImages is
-- similar to maxPerStageDescriptorStorageImages but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageDescriptorUpdateAfterBindInputAttachments is
-- similar to maxPerStageDescriptorInputAttachments but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxPerStageUpdateAfterBindResources is similar to
-- maxPerStageResources but counts descriptors from descriptor
-- sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindSamplers is similar to
-- maxDescriptorSetSamplers but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindUniformBuffers is similar
-- to maxDescriptorSetUniformBuffers but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindUniformBuffersDynamic is
-- similar to maxDescriptorSetUniformBuffersDynamic but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindStorageBuffers is similar
-- to maxDescriptorSetStorageBuffers but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindStorageBuffersDynamic is
-- similar to maxDescriptorSetStorageBuffersDynamic but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindSampledImages is similar
-- to maxDescriptorSetSampledImages but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindStorageImages is similar
-- to maxDescriptorSetStorageImages but counts descriptors from
-- descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
-- - maxDescriptorSetUpdateAfterBindInputAttachments is
-- similar to maxDescriptorSetInputAttachments but counts
-- descriptors from descriptor sets created with or without the
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT_EXT
-- bit set.
--
--
-- If the VkPhysicalDeviceDescriptorIndexingPropertiesEXT
-- structure is included in the pNext chain of
-- VkPhysicalDeviceProperties2KHR, it is filled with the
-- implementation-dependent limits.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DESCRIPTOR_INDEXING_PROPERTIES_EXT
--
--
-- See Also
--
-- VkBool32, VkStructureType
data VkPhysicalDeviceDescriptorIndexingPropertiesEXT
VkPhysicalDeviceDescriptorIndexingPropertiesEXT :: VkStructureType -> Ptr () -> Word32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> VkBool32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> VkPhysicalDeviceDescriptorIndexingPropertiesEXT
[$sel:vkSType:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Ptr ()
[$sel:vkMaxUpdateAfterBindDescriptorsInAllPools:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkShaderUniformBufferArrayNonUniformIndexingNative:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkShaderSampledImageArrayNonUniformIndexingNative:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkShaderStorageBufferArrayNonUniformIndexingNative:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkShaderStorageImageArrayNonUniformIndexingNative:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkShaderInputAttachmentArrayNonUniformIndexingNative:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkRobustBufferAccessUpdateAfterBind:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkQuadDivergentImplicitLod:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> VkBool32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindSamplers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindUniformBuffers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindStorageBuffers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindSampledImages:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindStorageImages:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageDescriptorUpdateAfterBindInputAttachments:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxPerStageUpdateAfterBindResources:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindSamplers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindUniformBuffers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindUniformBuffersDynamic:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindStorageBuffers:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindStorageBuffersDynamic:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindSampledImages:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindStorageImages:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
[$sel:vkMaxDescriptorSetUpdateAfterBindInputAttachments:VkPhysicalDeviceDescriptorIndexingPropertiesEXT] :: VkPhysicalDeviceDescriptorIndexingPropertiesEXT -> Word32
-- | VkDescriptorSetLayoutBindingFlagsCreateInfoEXT - Structure specifying
-- creation flags for descriptor set layout bindings
--
-- Description
--
-- If bindingCount is zero or if this structure is not in the
-- pNext chain, the VkDescriptorBindingFlagsEXT for each
-- descriptor set layout binding is considered to be zero. Otherwise, the
-- descriptor set layout binding at
-- VkDescriptorSetLayoutCreateInfo::pBindings[i] uses the
-- flags in pBindingFlags[i].
--
-- Valid Usage
--
--
--
--
-- - If VkDescriptorSetLayoutCreateInfo::flags includes
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR, then
-- all elements of pBindingFlags must not include
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT,
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT, or
-- VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT
-- - If an element of pBindingFlags includes
-- VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT, then
-- all other elements of
-- VkDescriptorSetLayoutCreateInfo::pBindings must
-- have a smaller value of binding
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingUniformBufferUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingSampledImageUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, or
-- VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingStorageImageUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingStorageBufferUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingUniformTexelBufferUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingStorageTexelBufferUpdateAfterBind
-- is not enabled, all bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - All bindings with descriptor type
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT,
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC, or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC must not use
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingUpdateUnusedWhilePending
-- is not enabled, all elements of pBindingFlags must not
-- include
-- VK_DESCRIPTOR_BINDING_UPDATE_UNUSED_WHILE_PENDING_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingPartiallyBound
-- is not enabled, all elements of pBindingFlags must not
-- include VK_DESCRIPTOR_BINDING_PARTIALLY_BOUND_BIT_EXT
-- - If
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingVariableDescriptorCount
-- is not enabled, all elements of pBindingFlags must not
-- include
-- VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT
-- - If an element of pBindingFlags includes
-- VK_DESCRIPTOR_BINDING_VARIABLE_DESCRIPTOR_COUNT_BIT_EXT, that
-- element’s descriptorType must not be
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_BINDING_FLAGS_CREATE_INFO_EXT
--
--
--
-- - If bindingCount is not 0, pBindingFlags
-- must be a valid pointer to an array of bindingCount
-- valid combinations of VkDescriptorBindingFlagBitsEXT
-- values
-- - Each element of pBindingFlags must not be
-- 0
--
--
-- See Also
--
-- VkDescriptorBindingFlagsEXT, VkStructureType
data VkDescriptorSetLayoutBindingFlagsCreateInfoEXT
VkDescriptorSetLayoutBindingFlagsCreateInfoEXT :: VkStructureType -> Ptr () -> Word32 -> Ptr VkDescriptorBindingFlagsEXT -> VkDescriptorSetLayoutBindingFlagsCreateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetLayoutBindingFlagsCreateInfoEXT] :: VkDescriptorSetLayoutBindingFlagsCreateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetLayoutBindingFlagsCreateInfoEXT] :: VkDescriptorSetLayoutBindingFlagsCreateInfoEXT -> Ptr ()
-- | bindingCount is zero or the number of elements in
-- pBindingFlags.
[$sel:vkBindingCount:VkDescriptorSetLayoutBindingFlagsCreateInfoEXT] :: VkDescriptorSetLayoutBindingFlagsCreateInfoEXT -> Word32
-- | pBindingFlags is a pointer to an array of
-- VkDescriptorBindingFlagsEXT bitfields, one for each descriptor
-- set layout binding.
[$sel:vkPBindingFlags:VkDescriptorSetLayoutBindingFlagsCreateInfoEXT] :: VkDescriptorSetLayoutBindingFlagsCreateInfoEXT -> Ptr VkDescriptorBindingFlagsEXT
-- | VkDescriptorSetVariableDescriptorCountAllocateInfoEXT - Structure
-- specifying additional allocation parameters for descriptor sets
--
-- Description
--
-- If descriptorSetCount is zero or this structure is not
-- included in the pNext chain, then the variable lengths are
-- considered to be zero. Otherwise, pDescriptorCounts[i] is the
-- number of descriptors in the variable count descriptor binding in the
-- corresponding descriptor set layout. If
-- VkDescriptorSetAllocateInfo::pSetLayouts[i] does not
-- include a variable count descriptor binding, then
-- pDescriptorCounts[i] is ignored.
--
-- Valid Usage
--
--
--
--
-- - If VkDescriptorSetAllocateInfo::pSetLayouts[i] has
-- a variable descriptor count binding, then
-- pDescriptorCounts[i] must be less than or equal to the
-- descriptor count specified for that binding when the descriptor set
-- layout was created.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_ALLOCATE_INFO_EXT
--
--
--
-- - If descriptorSetCount is not 0,
-- pDescriptorCounts must be a valid pointer to an array
-- of descriptorSetCount uint32_t values
--
--
-- See Also
--
-- VkStructureType
data VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
VkDescriptorSetVariableDescriptorCountAllocateInfoEXT :: VkStructureType -> Ptr () -> Word32 -> Ptr Word32 -> VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetVariableDescriptorCountAllocateInfoEXT] :: VkDescriptorSetVariableDescriptorCountAllocateInfoEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetVariableDescriptorCountAllocateInfoEXT] :: VkDescriptorSetVariableDescriptorCountAllocateInfoEXT -> Ptr ()
-- | descriptorSetCount is zero or the number of elements in
-- pDescriptorCounts.
[$sel:vkDescriptorSetCount:VkDescriptorSetVariableDescriptorCountAllocateInfoEXT] :: VkDescriptorSetVariableDescriptorCountAllocateInfoEXT -> Word32
-- | pDescriptorCounts is an array of descriptor counts, with each
-- member specifying the number of descriptors in a variable descriptor
-- count binding in the corresponding descriptor set being allocated.
[$sel:vkPDescriptorCounts:VkDescriptorSetVariableDescriptorCountAllocateInfoEXT] :: VkDescriptorSetVariableDescriptorCountAllocateInfoEXT -> Ptr Word32
-- | VkDescriptorSetVariableDescriptorCountLayoutSupportEXT - Structure
-- returning information about whether a descriptor set layout can be
-- supported
--
-- Description
--
-- If the create info includes a variable-sized descriptor, then
-- supported is determined assuming the requested size of the
-- variable-sized descriptor, and maxVariableDescriptorCount is
-- set to the maximum size of that descriptor that can be
-- successfully created (which is greater than or equal to the requested
-- size passed in). If the create info does not include a variable-sized
-- descriptor or if the
-- VkPhysicalDeviceDescriptorIndexingFeaturesEXT::descriptorBindingVariableDescriptorCount
-- feature is not enabled, then maxVariableDescriptorCount is
-- set to zero. For the purposes of this command, a variable-sized
-- descriptor binding with a descriptorCount of zero is treated
-- as if the descriptorCount is one, and thus the binding is not
-- ignored and the maximum descriptor count will be returned. If the
-- layout is not supported, then the value written to
-- maxVariableDescriptorCount is undefined.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_VARIABLE_DESCRIPTOR_COUNT_LAYOUT_SUPPORT_EXT
--
--
-- See Also
--
-- VkStructureType
data VkDescriptorSetVariableDescriptorCountLayoutSupportEXT
VkDescriptorSetVariableDescriptorCountLayoutSupportEXT :: VkStructureType -> Ptr () -> Word32 -> VkDescriptorSetVariableDescriptorCountLayoutSupportEXT
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetVariableDescriptorCountLayoutSupportEXT] :: VkDescriptorSetVariableDescriptorCountLayoutSupportEXT -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetVariableDescriptorCountLayoutSupportEXT] :: VkDescriptorSetVariableDescriptorCountLayoutSupportEXT -> Ptr ()
-- | maxVariableDescriptorCount indicates the maximum number of
-- descriptors supported in the highest numbered binding of the layout,
-- if that binding is variable-sized.
[$sel:vkMaxVariableDescriptorCount:VkDescriptorSetVariableDescriptorCountLayoutSupportEXT] :: VkDescriptorSetVariableDescriptorCountLayoutSupportEXT -> Word32
type VkDescriptorBindingFlagsEXT = VkDescriptorBindingFlagBitsEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetLayoutBindingFlagsCreateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetLayoutBindingFlagsCreateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountLayoutSupportEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountLayoutSupportEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingPropertiesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingPropertiesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingFeaturesEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingFeaturesEXT
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetLayoutBindingFlagsCreateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountLayoutSupportEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorSetVariableDescriptorCountAllocateInfoEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingPropertiesEXT
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkPhysicalDeviceDescriptorIndexingFeaturesEXT
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_EXT_descriptor_indexing.VkDescriptorBindingFlagBitsEXT
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3
-- | vkGetDescriptorSetLayoutSupport - Query whether a descriptor set
-- layout can be created
--
-- Parameters
--
--
-- - device is the logical device that would create the
-- descriptor set layout.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkDescriptorSetLayoutCreateInfo structure specifying the state
-- of the descriptor set layout object.
-- - pSupport points to a VkDescriptorSetLayoutSupport
-- structure in which information about support for the descriptor set
-- layout object is returned.
--
--
-- Description
--
-- Some implementations have limitations on what fits in a descriptor set
-- which are not easily expressible in terms of existing limits like
-- maxDescriptorSet*, for example if all descriptor types share
-- a limited space in memory but each descriptor is a different size or
-- alignment. This command returns information about whether a descriptor
-- set satisfies this limit. If the descriptor set layout satisfies the
-- VkPhysicalDeviceMaintenance3Properties::maxPerSetDescriptors
-- limit, this command is guaranteed to return VK_TRUE in
-- VkDescriptorSetLayoutSupport::supported. If the
-- descriptor set layout exceeds the
-- VkPhysicalDeviceMaintenance3Properties::maxPerSetDescriptors
-- limit, whether the descriptor set layout is supported is
-- implementation-dependent and may depend on whether the
-- descriptor sizes and alignments cause the layout to exceed an internal
-- limit.
--
-- This command does not consider other limits such as
-- maxPerStageDescriptor*, and so a descriptor set layout that
-- is supported according to this command must still satisfy the
-- pipeline layout limits such as maxPerStageDescriptor* in
-- order to be used in a pipeline layout.
--
-- Note
--
-- This is a VkDevice query rather than
-- VkPhysicalDevice because the answer may depend on
-- enabled features.
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDescriptorSetLayoutCreateInfo structure
-- - pSupport must be a valid pointer to a
-- VkDescriptorSetLayoutSupport structure
--
--
-- See Also
--
-- VkDescriptorSetLayoutCreateInfo,
-- VkDescriptorSetLayoutSupport, VkDevice
vkGetDescriptorSetLayoutSupport :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorSetLayoutCreateInfo) -> ("pSupport" ::: Ptr VkDescriptorSetLayoutSupport) -> IO ()
-- | VkPhysicalDeviceMaintenance3Properties - Structure describing
-- descriptor set properties
--
-- Members
--
-- The members of the VkPhysicalDeviceMaintenance3Properties
-- structure describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxPerSetDescriptors is a maximum number of descriptors
-- (summed over all descriptor types) in a single descriptor set that is
-- guaranteed to satisfy any implementation-dependent constraints on the
-- size of a descriptor set itself. Applications can query whether
-- a descriptor set that goes beyond this limit is supported using
-- vkGetDescriptorSetLayoutSupport.
--
--
--
-- - maxMemoryAllocationSize is the maximum size of a memory
-- allocation that can be created, even if there is more space
-- available in the heap.
--
--
-- If the VkPhysicalDeviceMaintenance3Properties structure is
-- included in the pNext chain of
-- VkPhysicalDeviceProperties2, it is filled with the
-- implementation-dependent limits.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_MAINTENANCE_3_PROPERTIES
--
--
-- See Also
--
-- VkDeviceSize, VkStructureType
data VkPhysicalDeviceMaintenance3Properties
VkPhysicalDeviceMaintenance3Properties :: VkStructureType -> Ptr () -> Word32 -> VkDeviceSize -> VkPhysicalDeviceMaintenance3Properties
[$sel:vkSType:VkPhysicalDeviceMaintenance3Properties] :: VkPhysicalDeviceMaintenance3Properties -> VkStructureType
[$sel:vkPNext:VkPhysicalDeviceMaintenance3Properties] :: VkPhysicalDeviceMaintenance3Properties -> Ptr ()
[$sel:vkMaxPerSetDescriptors:VkPhysicalDeviceMaintenance3Properties] :: VkPhysicalDeviceMaintenance3Properties -> Word32
[$sel:vkMaxMemoryAllocationSize:VkPhysicalDeviceMaintenance3Properties] :: VkPhysicalDeviceMaintenance3Properties -> VkDeviceSize
-- | VkDescriptorSetLayoutSupport - Structure returning information about
-- whether a descriptor set layout can be supported
--
-- Description
--
-- supported is set to VK_TRUE if the descriptor set
-- can be created, or else is set to VK_FALSE.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_SUPPORT
--
--
--
--
-- See Also
--
-- VkBool32, VkStructureType,
-- vkGetDescriptorSetLayoutSupport,
-- vkGetDescriptorSetLayoutSupportKHR
data VkDescriptorSetLayoutSupport
VkDescriptorSetLayoutSupport :: VkStructureType -> Ptr () -> VkBool32 -> VkDescriptorSetLayoutSupport
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorSetLayoutSupport] :: VkDescriptorSetLayoutSupport -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorSetLayoutSupport] :: VkDescriptorSetLayoutSupport -> Ptr ()
-- | supported specifies whether the descriptor set layout
-- can be created.
[$sel:vkSupported:VkDescriptorSetLayoutSupport] :: VkDescriptorSetLayoutSupport -> VkBool32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkDescriptorSetLayoutSupport
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkDescriptorSetLayoutSupport
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkPhysicalDeviceMaintenance3Properties
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkPhysicalDeviceMaintenance3Properties
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkDescriptorSetLayoutSupport
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_maintenance3.VkPhysicalDeviceMaintenance3Properties
module Graphics.Vulkan.Extensions.VK_KHR_maintenance3
vkGetDescriptorSetLayoutSupportKHR :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorSetLayoutCreateInfo) -> ("pSupport" ::: Ptr VkDescriptorSetLayoutSupport) -> IO ()
type VkPhysicalDeviceMaintenance3PropertiesKHR = VkPhysicalDeviceMaintenance3Properties
type VkDescriptorSetLayoutSupportKHR = VkDescriptorSetLayoutSupport
module Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template
-- | VkDescriptorUpdateTemplateType - Indicates the valid usage of the
-- descriptor update template
--
-- See Also
--
-- VkDescriptorUpdateTemplateCreateInfo
newtype VkDescriptorUpdateTemplateType
VkDescriptorUpdateTemplateType :: Int32 -> VkDescriptorUpdateTemplateType
-- | VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET specifies
-- that the descriptor update template will be used for descriptor set
-- updates only.
-- | VkDescriptorUpdateTemplateCreateFlags - Reserved for future use
--
-- Description
--
-- VkDescriptorUpdateTemplateCreateFlags is a bitmask type for
-- setting a mask, but is currently reserved for future use.
--
-- See Also
--
-- VkDescriptorUpdateTemplateCreateInfo
newtype VkDescriptorUpdateTemplateCreateFlags
VkDescriptorUpdateTemplateCreateFlags :: VkFlags -> VkDescriptorUpdateTemplateCreateFlags
-- | VkDescriptorUpdateTemplate - Opaque handle to a descriptor update
-- template
--
-- Description
--
-- See Also
--
-- vkCmdPushDescriptorSetWithTemplateKHR,
-- vkCreateDescriptorUpdateTemplate,
-- vkCreateDescriptorUpdateTemplateKHR,
-- vkDestroyDescriptorUpdateTemplate,
-- vkDestroyDescriptorUpdateTemplateKHR,
-- vkUpdateDescriptorSetWithTemplate,
-- vkUpdateDescriptorSetWithTemplateKHR
type VkDescriptorUpdateTemplate = Ptr VkDescriptorUpdateTemplate_T
-- | vkCreateDescriptorUpdateTemplate - Create a new descriptor update
-- template
--
-- Parameters
--
--
-- - device is the logical device that creates the descriptor
-- update template.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkDescriptorUpdateTemplateCreateInfo structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pDescriptorUpdateTemplate must be a valid pointer
-- to a VkDescriptorUpdateTemplate handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorUpdateTemplate,
-- VkDescriptorUpdateTemplateCreateInfo, VkDevice
vkCreateDescriptorUpdateTemplate :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorUpdateTemplateCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pDescriptorUpdateTemplate" ::: Ptr VkDescriptorUpdateTemplate) -> IO VkResult
-- | vkDestroyDescriptorUpdateTemplate - Destroy a descriptor update
-- template object
--
-- Parameters
--
--
-- - device is the logical device that has been used to create
-- the descriptor update template
--
--
--
-- - descriptorUpdateTemplate is the descriptor update
-- template to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - If VkAllocationCallbacks were provided when
-- descriptorSetLayout was created, a compatible set of
-- callbacks must be provided here
--
--
--
-- - If no VkAllocationCallbacks were provided when
-- descriptorSetLayout was created, pAllocator
-- must be NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - If descriptorUpdateTemplate is not VK_NULL_HANDLE,
-- descriptorUpdateTemplate must be a valid
-- VkDescriptorUpdateTemplate handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - If descriptorUpdateTemplate is a valid handle, it
-- must have been created, allocated, or retrieved from
-- device
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorUpdateTemplate must be
-- externally synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDescriptorUpdateTemplate,
-- VkDevice
vkDestroyDescriptorUpdateTemplate :: ("device" ::: VkDevice) -> ("descriptorUpdateTemplate" ::: VkDescriptorUpdateTemplate) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkUpdateDescriptorSetWithTemplate - Update the contents of a
-- descriptor set object using an update template
--
-- Parameters
--
--
-- - device is the logical device that updates the descriptor
-- sets.
--
--
--
-- - descriptorSet is the descriptor set to update
-- - descriptorUpdateTemplate is the
-- VkDescriptorUpdateTemplate which specifies the update mapping
-- between pData and the descriptor set to update.
-- - pData is a pointer to memory which contains one or more
-- structures of VkDescriptorImageInfo,
-- VkDescriptorBufferInfo, or VkBufferView used to write
-- the descriptors.
--
--
-- Description
--
-- Valid Usage
--
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - descriptorSet must be a valid
-- VkDescriptorSet handle
-- - descriptorUpdateTemplate must be a valid
-- VkDescriptorUpdateTemplate handle
-- - descriptorUpdateTemplate must have been created,
-- allocated, or retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to descriptorSet must be externally
-- synchronized
--
--
-- API example.
--
--
-- struct AppBufferView {
-- VkBufferView bufferView;
-- uint32_t applicationRelatedInformation;
-- };
--
-- struct AppDataStructure
-- {
-- VkDescriptorImageInfo imageInfo; // a single image info
-- VkDescriptorBufferInfo bufferInfoArray[3]; // 3 buffer infos in an array
-- AppBufferView bufferView[2]; // An application defined structure containing a bufferView
-- // ... some more application related data
-- };
--
-- const VkDescriptorUpdateTemplateEntry descriptorUpdateTemplateEntries[] =
-- {
-- // binding to a single image descriptor
-- {
-- 0, // binding
-- 0, // dstArrayElement
-- 1, // descriptorCount
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, // descriptorType
-- offsetof(AppDataStructure, imageInfo), // offset
-- 0 // stride is not required if descriptorCount is 1.
-- },
--
-- // binding to an array of buffer descriptors
-- {
-- 0, // binding
-- 0, // dstArrayElement
-- 3, // descriptorCount
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER, // descriptorType
-- offsetof(AppDataStructure, bufferInfoArray), // offset
-- sizeof(VkDescriptorBufferInfo) // stride, descriptor buffer infos are compact
-- },
--
-- // binding to an array of buffer views
-- {
-- 0, // binding
-- 3, // dstArrayElement
-- 1, // descriptorCount
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER, // descriptorType
-- offsetof(AppDataStructure, bufferView), // offset
-- sizeof(AppBufferView) // stride, bufferViews do not have to be compact
-- },
-- };
--
-- // create an descriptor update template for descriptor set updates
-- const VkDescriptorUpdateTemplateCreateInfo createInfo =
-- {
-- VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO, // sType
-- NULL, // pNext
-- 0, // flags
-- 3, // descriptorUpdateEntryCount
-- descriptorUpdateTemplateEntries, // pDescriptorUpdateEntries
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET, // templateType
-- myLayout, // descriptorSetLayout
-- 0, // pipelineBindPoint, ignored by given templateType
-- 0, // pipelineLayout, ignored by given templateType
-- 0, // set, ignored by given templateType
-- };
--
-- VkDescriptorUpdateTemplate myDescriptorUpdateTemplate;
-- myResult = vkCreateDescriptorUpdateTemplate(
-- myDevice,
-- &createInfo,
-- NULL,
-- &myDescriptorUpdateTemplate);
-- }
--
--
-- AppDataStructure appData;
--
-- // fill appData here or cache it in your engine
-- vkUpdateDescriptorSetWithTemplate(myDevice, myDescriptorSet, myDescriptorUpdateTemplate, &appData);
--
--
-- See Also
--
-- VkDescriptorSet, VkDescriptorUpdateTemplate,
-- VkDevice
vkUpdateDescriptorSetWithTemplate :: ("device" ::: VkDevice) -> ("descriptorSet" ::: VkDescriptorSet) -> ("descriptorUpdateTemplate" ::: VkDescriptorUpdateTemplate) -> ("pData" ::: Ptr ()) -> IO ()
-- | VkDescriptorUpdateTemplateEntry - Describes a single descriptor update
-- of the descriptor update template
--
-- Members
--
--
-- - dstBinding is the descriptor binding to update when using
-- this descriptor update template.
--
--
--
--
-- Description
--
-- Valid Usage
--
--
-- - dstBinding must be a valid binding in the
-- descriptor set layout implicitly specified when using a descriptor
-- update template to update descriptors.
--
--
--
-- - dstArrayElement and descriptorCount must
-- 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
-- {html_spec_relative}#descriptorsets-updates-consecutive
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkDescriptorType, VkDescriptorUpdateTemplateCreateInfo
data VkDescriptorUpdateTemplateEntry
VkDescriptorUpdateTemplateEntry :: Word32 -> Word32 -> Word32 -> VkDescriptorType -> CSize -> CSize -> VkDescriptorUpdateTemplateEntry
[$sel:vkDstBinding:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> Word32
[$sel:vkDstArrayElement:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> Word32
[$sel:vkDescriptorCount:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> Word32
[$sel:vkDescriptorType:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> VkDescriptorType
[$sel:vkOffset:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> CSize
[$sel:vkStride:VkDescriptorUpdateTemplateEntry] :: VkDescriptorUpdateTemplateEntry -> CSize
-- | VkDescriptorUpdateTemplateCreateInfo - Structure specifying parameters
-- of a newly created descriptor update template
--
-- Description
--
-- Valid Usage
--
--
-- - If templateType is
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET,
-- descriptorSetLayout must be a valid
-- VkDescriptorSetLayout handle
--
--
--
-- - If templateType is
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR,
-- pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - If templateType is
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR,
-- pipelineLayout must be a valid
-- VkPipelineLayout handle
-- - If templateType is
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR,
-- set must be the unique set number in the pipeline
-- layout that uses a descriptor set layout that was created with
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO
--
--
--
-- - pNext must be NULL
-- - flags must be 0
-- - pDescriptorUpdateEntries must be a valid pointer
-- to an array of descriptorUpdateEntryCount valid
-- VkDescriptorUpdateTemplateEntry structures
-- - templateType must be a valid
-- VkDescriptorUpdateTemplateType value
-- - If descriptorSetLayout is not VK_NULL_HANDLE,
-- descriptorSetLayout must be a valid
-- VkDescriptorSetLayout handle
-- - descriptorUpdateEntryCount must be greater than
-- 0
-- - Both of descriptorSetLayout, and pipelineLayout
-- that are valid handles must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- See Also
--
-- VkDescriptorSetLayout,
-- VkDescriptorUpdateTemplateCreateFlags,
-- VkDescriptorUpdateTemplateEntry,
-- VkDescriptorUpdateTemplateType, VkPipelineBindPoint,
-- VkPipelineLayout, VkStructureType,
-- vkCreateDescriptorUpdateTemplate,
-- vkCreateDescriptorUpdateTemplateKHR
data VkDescriptorUpdateTemplateCreateInfo
VkDescriptorUpdateTemplateCreateInfo :: VkStructureType -> Ptr () -> VkDescriptorUpdateTemplateCreateFlags -> Word32 -> Ptr VkDescriptorUpdateTemplateEntry -> VkDescriptorUpdateTemplateType -> VkDescriptorSetLayout -> VkPipelineBindPoint -> VkPipelineLayout -> Word32 -> VkDescriptorUpdateTemplateCreateInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> Ptr ()
-- | flags is reserved for future use.
[$sel:vkFlags:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkDescriptorUpdateTemplateCreateFlags
-- | descriptorUpdateEntryCount is the number of elements in the
-- pDescriptorUpdateEntries array.
[$sel:vkDescriptorUpdateEntryCount:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> Word32
-- | pDescriptorUpdateEntries is a pointer to an array of
-- VkDescriptorUpdateTemplateEntry structures describing the
-- descriptors to be updated by the descriptor update template.
[$sel:vkPDescriptorUpdateEntries:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> Ptr VkDescriptorUpdateTemplateEntry
-- | templateType Specifies the type of the descriptor update
-- template. If set to
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET it
-- can only be used to update descriptor sets with a fixed
-- descriptorSetLayout. If set to
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR it
-- can only be used to push descriptor sets using the provided
-- pipelineBindPoint, pipelineLayout, and set
-- number.
[$sel:vkTemplateType:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkDescriptorUpdateTemplateType
-- | descriptorSetLayout is the descriptor set layout the
-- parameter update template will be used with. All descriptor sets which
-- are going to be updated through the newly created descriptor update
-- template must be created with this layout.
-- descriptorSetLayout is the descriptor set layout used to
-- build the descriptor update template. All descriptor sets which are
-- going to be updated through the newly created descriptor update
-- template must be created with a layout that matches (is the
-- same as, or defined identically to) this layout. This parameter is
-- ignored if templateType is not
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_DESCRIPTOR_SET.
[$sel:vkDescriptorSetLayout:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkDescriptorSetLayout
-- | pipelineBindPoint is a VkPipelineBindPoint indicating
-- whether the descriptors will be used by graphics pipelines or compute
-- pipelines. This parameter is ignored if templateType is not
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR
[$sel:vkPipelineBindPoint:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkPipelineBindPoint
-- | pipelineLayout is a VkPipelineLayout object used to
-- program the bindings. This parameter is ignored if
-- templateType is not
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR
[$sel:vkPipelineLayout:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> VkPipelineLayout
-- | set is the set number of the descriptor set in the pipeline
-- layout that will be updated. This parameter is ignored if
-- templateType is not
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR
[$sel:vkSet:VkDescriptorUpdateTemplateCreateInfo] :: VkDescriptorUpdateTemplateCreateInfo -> Word32
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateInfo
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateEntry
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateEntry
instance Data.Bits.FiniteBits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance Data.Bits.Bits Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateType
instance GHC.Classes.Ord Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateType
instance GHC.Classes.Eq Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateType
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateEntry
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateCreateFlags
instance GHC.Show.Show Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateType
instance GHC.Read.Read Graphics.Vulkan.Core11.Promoted_from_VK_KHR_descriptor_update_template.VkDescriptorUpdateTemplateType
module Graphics.Vulkan.Extensions.VK_KHR_push_descriptor
-- | VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR
-- specifies that the descriptor update template will be used for push
-- descriptor updates only.
-- | VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
-- specifies that descriptor sets must not be allocated using this
-- layout, and descriptors are instead pushed by
-- vkCmdPushDescriptorSetKHR.
-- | vkCmdPushDescriptorSetKHR - Pushes descriptor updates into a command
-- buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer that the descriptors
-- will be recorded in.
--
--
--
-- - pipelineBindPoint is a VkPipelineBindPoint
-- indicating whether the descriptors will be used by graphics pipelines
-- or compute pipelines. There is a separate set of push descriptor
-- bindings for each of graphics and compute, so binding one does not
-- disturb the other.
-- - layout is a VkPipelineLayout object used to
-- program the bindings.
-- - set is the set number of the descriptor set in the
-- pipeline layout that will be updated.
-- - descriptorWriteCount is the number of elements in the
-- pDescriptorWrites array.
-- - pDescriptorWrites is a pointer to an array of
-- VkWriteDescriptorSet structures describing the descriptors to
-- be updated.
--
--
-- Description
--
-- Push descriptors are a small bank of descriptors whose storage
-- is internally managed by the command buffer rather than being written
-- into a descriptor set and later bound to a command buffer. Push
-- descriptors allow for incremental updates of descriptors without
-- managing the lifetime of descriptor sets.
--
-- When a command buffer begins recording, all push descriptors have
-- undefined contents. Push descriptors can be updated
-- incrementally and cause shaders to use the updated descriptors for
-- subsequent rendering commands (either compute or graphics, according
-- to the pipelineBindPoint) until the descriptor is
-- overwritten, or else until the set is disturbed as described in
-- Pipeline Layout Compatibility. When the set is disturbed or
-- push descriptors with a different descriptor set layout are set, all
-- push descriptors become invalid.
--
-- Valid descriptors must be pushed for all bindings that any
-- shaders in a pipeline access, at the time that a draw or dispatch
-- command is recorded to execute using that pipeline. This includes
-- immutable sampler descriptors, which must be pushed before they
-- are accessed by a pipeline. However, if none of the shaders in a
-- pipeline statically use certain bindings in the push descriptor set,
-- then those descriptors need not be valid.
--
-- Push descriptors do not use dynamic offsets. Instead, the
-- corresponding non-dynamic descriptor types can be used and the
-- offset member of VkDescriptorBufferInfo can be
-- changed each time the descriptor is written.
--
-- Each element of pDescriptorWrites is interpreted as in
-- VkWriteDescriptorSet, except the dstSet member is
-- ignored.
--
-- To push an immutable sampler, use a VkWriteDescriptorSet with
-- dstBinding and dstArrayElement selecting the
-- immutable sampler’s binding. If the descriptor type is
-- VK_DESCRIPTOR_TYPE_SAMPLER, the pImageInfo parameter
-- is ignored and the immutable sampler is taken from the push descriptor
-- set layout in the pipeline layout. If the descriptor type is
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, the
-- sampler member of the pImageInfo parameter is
-- ignored and the immutable sampler is taken from the push descriptor
-- set layout in the pipeline layout.
--
-- Valid Usage
--
--
-- - pipelineBindPoint must be supported by the
-- commandBuffer’s parent VkCommandPool’s queue
-- family
--
--
--
-- - set must be less than
-- VkPipelineLayoutCreateInfo::setLayoutCount provided
-- when layout was created
-- - set must be the unique set number in the pipeline
-- layout that uses a descriptor set layout that was created with
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - layout must be a valid VkPipelineLayout
-- handle
-- - pDescriptorWrites must be a valid pointer to an
-- array of descriptorWriteCount valid
-- VkWriteDescriptorSet structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - descriptorWriteCount must be greater than
-- 0
-- - Both of commandBuffer, and layout must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkPipelineBindPoint,
-- VkPipelineLayout, VkWriteDescriptorSet
vkCmdPushDescriptorSetKHR :: ("commandBuffer" ::: VkCommandBuffer) -> ("pipelineBindPoint" ::: VkPipelineBindPoint) -> ("layout" ::: VkPipelineLayout) -> ("set" ::: Word32) -> ("descriptorWriteCount" ::: Word32) -> ("pDescriptorWrites" ::: Ptr VkWriteDescriptorSet) -> IO ()
-- | vkCmdPushDescriptorSetWithTemplateKHR - Pushes descriptor updates into
-- a command buffer using a descriptor update template
--
-- Parameters
--
--
-- - commandBuffer is the command buffer that the descriptors
-- will be recorded in.
--
--
--
-- - descriptorUpdateTemplate A descriptor update template
-- which defines how to interpret the descriptor information in
-- pData.
-- - layout is a VkPipelineLayout object used to
-- program the bindings. It must be compatible with the layout
-- used to create the descriptorUpdateTemplate handle.
-- - set is the set number of the descriptor set in the
-- pipeline layout that will be updated. This must be the same
-- number used to create the descriptorUpdateTemplate
-- handle.
-- - pData Points to memory which contains the descriptors for
-- the templated update.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The pipelineBindPoint specified during the creation of the
-- descriptor update template must be supported by the
-- commandBuffer’s parent VkCommandPool’s queue
-- family
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - descriptorUpdateTemplate must be a valid
-- VkDescriptorUpdateTemplate handle
-- - layout must be a valid VkPipelineLayout
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - Each of commandBuffer, descriptorUpdateTemplate,
-- and layout must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- API example.
--
--
-- struct AppBufferView {
-- VkBufferView bufferView;
-- uint32_t applicationRelatedInformation;
-- };
--
-- struct AppDataStructure
-- {
-- VkDescriptorImageInfo imageInfo; // a single image info
-- // ... some more application related data
-- };
--
-- const VkDescriptorUpdateTemplateEntry descriptorUpdateTemplateEntries[] =
-- {
-- // binding to a single image descriptor
-- {
-- 0, // binding
-- 0, // dstArrayElement
-- 1, // descriptorCount
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER, // descriptorType
-- offsetof(AppDataStructure, imageInfo), // offset
-- 0 // stride is not required if descriptorCount is 1.
-- }
--
-- };
--
-- // create an descriptor update template for descriptor set updates
-- const VkDescriptorUpdateTemplateCreateInfo createInfo =
-- {
-- VK_STRUCTURE_TYPE_DESCRIPTOR_UPDATE_TEMPLATE_CREATE_INFO, // sType
-- NULL, // pNext
-- 0, // flags
-- 1, // descriptorUpdateEntryCount
-- descriptorUpdateTemplateEntries, // pDescriptorUpdateEntries
-- VK_DESCRIPTOR_UPDATE_TEMPLATE_TYPE_PUSH_DESCRIPTORS_KHR, // templateType
-- 0, // descriptorSetLayout, ignored by given templateType
-- VK_PIPELINE_BIND_POINT_GRAPHICS, // pipelineBindPoint
-- myPipelineLayout, // pipelineLayout
-- 0, // set
-- };
--
-- VkDescriptorUpdateTemplate myDescriptorUpdateTemplate;
-- myResult = vkCreateDescriptorUpdateTemplate(
-- myDevice,
-- &createInfo,
-- NULL,
-- &myDescriptorUpdateTemplate);
-- }
--
-- AppDataStructure appData;
-- // fill appData here or cache it in your engine
-- vkCmdPushDescriptorSetWithTemplateKHR(myCmdBuffer, myDescriptorUpdateTemplate, myPipelineLayout, 0,&appData);
--
--
-- See Also
--
-- VkCommandBuffer, VkDescriptorUpdateTemplate,
-- VkPipelineLayout
vkCmdPushDescriptorSetWithTemplateKHR :: ("commandBuffer" ::: VkCommandBuffer) -> ("descriptorUpdateTemplate" ::: VkDescriptorUpdateTemplate) -> ("layout" ::: VkPipelineLayout) -> ("set" ::: Word32) -> ("pData" ::: Ptr ()) -> IO ()
-- | VkPhysicalDevicePushDescriptorPropertiesKHR - Structure describing
-- push descriptor limits that can be supported by an implementation
--
-- Members
--
-- The members of the
-- VkPhysicalDevicePushDescriptorPropertiesKHR structure
-- describe the following implementation-dependent limits:
--
-- Description
--
--
-- - maxPushDescriptors is the maximum number of descriptors
-- that can be used in a descriptor set created with
-- VK_DESCRIPTOR_SET_LAYOUT_CREATE_PUSH_DESCRIPTOR_BIT_KHR
-- set.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PUSH_DESCRIPTOR_PROPERTIES_KHR
--
--
-- See Also
--
-- VkStructureType
data VkPhysicalDevicePushDescriptorPropertiesKHR
VkPhysicalDevicePushDescriptorPropertiesKHR :: VkStructureType -> Ptr () -> Word32 -> VkPhysicalDevicePushDescriptorPropertiesKHR
[$sel:vkSType:VkPhysicalDevicePushDescriptorPropertiesKHR] :: VkPhysicalDevicePushDescriptorPropertiesKHR -> VkStructureType
[$sel:vkPNext:VkPhysicalDevicePushDescriptorPropertiesKHR] :: VkPhysicalDevicePushDescriptorPropertiesKHR -> Ptr ()
[$sel:vkMaxPushDescriptors:VkPhysicalDevicePushDescriptorPropertiesKHR] :: VkPhysicalDevicePushDescriptorPropertiesKHR -> Word32
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_KHR_push_descriptor.VkPhysicalDevicePushDescriptorPropertiesKHR
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_KHR_push_descriptor.VkPhysicalDevicePushDescriptorPropertiesKHR
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_KHR_push_descriptor.VkPhysicalDevicePushDescriptorPropertiesKHR
module Graphics.Vulkan.Extensions.VK_KHR_descriptor_update_template
vkCreateDescriptorUpdateTemplateKHR :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkDescriptorUpdateTemplateCreateInfo) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pDescriptorUpdateTemplate" ::: Ptr VkDescriptorUpdateTemplate) -> IO VkResult
vkDestroyDescriptorUpdateTemplateKHR :: ("device" ::: VkDevice) -> ("descriptorUpdateTemplate" ::: VkDescriptorUpdateTemplate) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
vkUpdateDescriptorSetWithTemplateKHR :: ("device" ::: VkDevice) -> ("descriptorSet" ::: VkDescriptorSet) -> ("descriptorUpdateTemplate" ::: VkDescriptorUpdateTemplate) -> ("pData" ::: Ptr ()) -> IO ()
type VkDescriptorUpdateTemplateTypeKHR = VkDescriptorUpdateTemplateType
type VkDescriptorUpdateTemplateCreateFlagsKHR = VkDescriptorUpdateTemplateCreateFlags
type VkDescriptorUpdateTemplateKHR = VkDescriptorUpdateTemplate
type VkDescriptorUpdateTemplateEntryKHR = VkDescriptorUpdateTemplateEntry
type VkDescriptorUpdateTemplateCreateInfoKHR = VkDescriptorUpdateTemplateCreateInfo
module Graphics.Vulkan.Core11
module Graphics.Vulkan.Core10.CommandBufferBuilding
-- | VkIndexType - Type of index buffer indices
--
-- See Also
--
-- VkObjectTableIndexBufferEntryNVX, vkCmdBindIndexBuffer
newtype VkIndexType
VkIndexType :: Int32 -> VkIndexType
-- | VK_INDEX_TYPE_UINT16 specifies that indices are 16-bit
-- unsigned integer values.
-- | VK_INDEX_TYPE_UINT32 specifies that indices are 32-bit
-- unsigned integer values.
-- | VkSubpassContents - Specify how commands in the first subpass of a
-- render pass are provided
--
-- See Also
--
-- vkCmdBeginRenderPass, vkCmdNextSubpass
newtype VkSubpassContents
VkSubpassContents :: Int32 -> VkSubpassContents
-- | VK_SUBPASS_CONTENTS_INLINE specifies that the contents of the
-- subpass will be recorded inline in the primary command buffer, and
-- secondary command buffers must not be executed within the
-- subpass.
-- | VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS specifies that
-- the contents are recorded in secondary command buffers that will be
-- called from the primary command buffer, and
-- vkCmdExecuteCommands is the only valid command on the command
-- buffer until vkCmdNextSubpass or vkCmdEndRenderPass.
-- | VkStencilFaceFlagBits - Bitmask specifying sets of stencil state for
-- which to update the compare mask
--
-- See Also
--
-- VkStencilFaceFlags
newtype VkStencilFaceFlagBits
VkStencilFaceFlagBits :: VkFlags -> VkStencilFaceFlagBits
-- | VK_STENCIL_FACE_FRONT_BIT specifies that only the front set
-- of stencil state is updated.
-- | VK_STENCIL_FACE_BACK_BIT specifies that only the back set of
-- stencil state is updated.
-- | VK_STENCIL_FRONT_AND_BACK is the combination of
-- VK_STENCIL_FACE_FRONT_BIT and
-- VK_STENCIL_FACE_BACK_BIT, and specifies that both sets of
-- stencil state are updated.
-- | vkCmdBindPipeline - Bind a pipeline object to a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer that the pipeline
-- will be bound to.
--
--
--
-- - pipelineBindPoint is a VkPipelineBindPoint value
-- specifying whether to bind to the compute or graphics bind point.
-- Binding one does not disturb the other.
-- - pipeline is the pipeline to be bound.
--
--
-- Description
--
-- Once bound, a pipeline binding affects subsequent graphics or compute
-- commands in the command buffer until a different pipeline is bound to
-- the bind point. The pipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE controls the behavior of
-- vkCmdDispatch and vkCmdDispatchIndirect. The pipeline
-- bound to VK_PIPELINE_BIND_POINT_GRAPHICS controls the
-- behavior of all drawing commands. No other commands are
-- affected by the pipeline state.
--
-- Valid Usage
--
--
-- - If pipelineBindPoint is
-- VK_PIPELINE_BIND_POINT_COMPUTE, the VkCommandPool
-- that commandBuffer was allocated from must support
-- compute operations
--
--
--
-- - If pipelineBindPoint is
-- VK_PIPELINE_BIND_POINT_GRAPHICS, the VkCommandPool
-- that commandBuffer was allocated from must support
-- graphics operations
-- - If pipelineBindPoint is
-- VK_PIPELINE_BIND_POINT_COMPUTE, pipeline must
-- be a compute pipeline
-- - If pipelineBindPoint is
-- VK_PIPELINE_BIND_POINT_GRAPHICS, pipeline
-- must be a graphics pipeline
-- - If the variable multisample rate feature is not supported,
-- pipeline 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 must match that set in
-- the previous pipeline
-- - If
-- VkPhysicalDeviceSampleLocationsPropertiesEXT::variableSampleLocations
-- is VK_FALSE, and pipeline is a graphics pipeline
-- created with a VkPipelineSampleLocationsStateCreateInfoEXT
-- structure having its sampleLocationsEnable member set to
-- VK_TRUE but without
-- VK_DYNAMIC_STATE_SAMPLE_LOCATIONS_EXT enabled then the
-- current render pass instance must have been begun by specifying
-- a VkRenderPassSampleLocationsBeginInfoEXT structure whose
-- pPostSubpassSampleLocations member contains an element with a
-- subpassIndex matching the current subpass index and the
-- sampleLocationsInfo member of that element must match
-- the sampleLocationsInfo specified in
-- VkPipelineSampleLocationsStateCreateInfoEXT when the pipeline
-- was created
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - pipeline must be a valid VkPipeline
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - Both of commandBuffer, and pipeline must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkPipeline, VkPipelineBindPoint
vkCmdBindPipeline :: ("commandBuffer" ::: VkCommandBuffer) -> ("pipelineBindPoint" ::: VkPipelineBindPoint) -> ("pipeline" ::: VkPipeline) -> IO ()
-- | vkCmdSetViewport - Set the viewport on a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - firstViewport is the index of the first viewport whose
-- parameters are updated by the command.
-- - viewportCount is the number of viewports whose parameters
-- are updated by the command.
-- - pViewports is a pointer to an array of VkViewport
-- structures specifying viewport parameters.
--
--
-- Description
--
-- The viewport parameters taken from element i of pViewports
-- replace the current state for the viewport index
-- firstViewport + i, for i in [0, viewportCount).
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_VIEWPORT dynamic state enabled
--
--
--
-- - firstViewport must be less than
-- VkPhysicalDeviceLimits::maxViewports
-- - The sum of firstViewport and viewportCount
-- must be between 1 and
-- VkPhysicalDeviceLimits::maxViewports, inclusive
-- - If the multiple viewports feature is not enabled,
-- firstViewport must be 0
-- - If the multiple viewports feature is not enabled,
-- viewportCount must be 1
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pViewports must be a valid pointer to an array of
-- viewportCount VkViewport structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - viewportCount must be greater than 0
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkViewport
vkCmdSetViewport :: ("commandBuffer" ::: VkCommandBuffer) -> ("firstViewport" ::: Word32) -> ("viewportCount" ::: Word32) -> ("pViewports" ::: Ptr VkViewport) -> IO ()
-- | vkCmdSetScissor - Set the dynamic scissor rectangles on a command
-- buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - firstScissor is the index of the first scissor whose
-- state is updated by the command.
-- - scissorCount is the number of scissors whose rectangles
-- are updated by the command.
-- - pScissors is a pointer to an array of VkRect2D
-- structures defining scissor rectangles.
--
--
-- Description
--
-- The scissor rectangles taken from element i of pScissors
-- replace the current state for the scissor index firstScissor
-- + i, for i in [0, scissorCount).
--
-- Each scissor rectangle is described by a VkRect2D structure,
-- with the offset.x and offset.y values determining
-- the upper left corner of the scissor rectangle, and the
-- extent.width and extent.height values determining
-- the size in pixels.
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_SCISSOR dynamic state enabled
--
--
--
-- - firstScissor must be less than
-- VkPhysicalDeviceLimits::maxViewports
-- - The sum of firstScissor and scissorCount
-- must be between 1 and
-- VkPhysicalDeviceLimits::maxViewports, inclusive
-- - If the multiple viewports feature is not enabled,
-- firstScissor must be 0
-- - If the multiple viewports feature is not enabled,
-- scissorCount must be 1
-- - The x and y members of offset
-- must be greater than or equal to 0
-- - Evaluation of (offset.x + extent.width)
-- must not cause a signed integer addition overflow
-- - Evaluation of (offset.y + extent.height)
-- must not cause a signed integer addition overflow
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pScissors must be a valid pointer to an array of
-- scissorCount VkRect2D structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - scissorCount must be greater than 0
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkRect2D
vkCmdSetScissor :: ("commandBuffer" ::: VkCommandBuffer) -> ("firstScissor" ::: Word32) -> ("scissorCount" ::: Word32) -> ("pScissors" ::: Ptr VkRect2D) -> IO ()
-- | vkCmdSetLineWidth - Set the dynamic line width state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - lineWidth is the width of rasterized line segments.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_LINE_WIDTH dynamic state enabled
--
--
--
-- - If the wide lines feature is not enabled,
-- lineWidth must be 1.0
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdSetLineWidth :: ("commandBuffer" ::: VkCommandBuffer) -> ("lineWidth" ::: CFloat) -> IO ()
-- | vkCmdSetDepthBias - Set the depth bias dynamic state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - depthBiasConstantFactor is a scalar factor controlling
-- the constant depth value added to each fragment.
-- - depthBiasClamp is the maximum (or minimum) depth bias of
-- a fragment.
-- - depthBiasSlopeFactor is a scalar factor applied to a
-- fragment’s slope in depth bias calculations.
--
--
-- Description
--
-- If depthBiasEnable is VK_FALSE, no depth bias is
-- applied and the fragment’s depth values are unchanged.
--
-- depthBiasSlopeFactor scales the maximum depth slope of the
-- polygon, and depthBiasConstantFactor scales an
-- implementation-dependent constant that relates to the usable
-- resolution of the depth buffer. The resulting values are summed to
-- produce the depth bias value which is then clamped to a minimum or
-- maximum value specified by depthBiasClamp.
-- depthBiasSlopeFactor, depthBiasConstantFactor, and
-- depthBiasClamp can each be positive, negative, or
-- zero.
--
-- The maximum depth slope m of a triangle is
--
-- \[m = \sqrt{ \left({{\partial z_f} \over {\partial x_f}}\right)^2 +
-- \left({{\partial z_f} \over {\partial y_f}}\right)^2}\]
--
-- where (xf, yf, zf) is a point on the triangle. m may be
-- approximated as
--
-- \[m = \max\left( \left| { {\partial z_f} \over {\partial x_f} }
-- \right|, \left| { {\partial z_f} \over {\partial y_f} } \right|
-- \right).\]
--
-- The minimum resolvable difference r is an implementation-dependent
-- parameter that depends on the depth buffer representation. It is the
-- smallest difference in framebuffer coordinate z values that is
-- guaranteed to remain distinct throughout polygon rasterization and in
-- the depth buffer. All pairs of fragments generated by the
-- rasterization of two polygons with otherwise identical vertices, but
-- zf values that differ by $r$, will have distinct depth
-- values.
--
-- For fixed-point depth buffer representations, r is constant throughout
-- the range of the entire depth buffer. For floating-point depth
-- buffers, there is no single minimum resolvable difference. In this
-- case, the minimum resolvable difference for a given polygon is
-- dependent on the maximum exponent, e, in the range of z values spanned
-- by the primitive. If n is the number of bits in the floating-point
-- mantissa, the minimum resolvable difference, r, for the given
-- primitive is defined as
--
--
--
-- If a triangle is rasterized using the
-- VK_POLYGON_MODE_FILL_RECTANGLE_NV polygon mode, then this
-- minimum resolvable difference may not be resolvable for samples
-- outside of the triangle, where the depth is extrapolated.
--
-- If no depth buffer is present, r is undefined.
--
-- The bias value o for a polygon is
--
-- \[o = \begin{cases} m \times depthBiasSlopeFactor + r \times
-- depthBiasConstantFactor & depthBiasClamp = 0\ or\ NaN \\ \min(m
-- \times depthBiasSlopeFactor + r \times depthBiasConstantFactor,
-- depthBiasClamp) & depthBiasClamp > 0 \\ \max(m \times
-- depthBiasSlopeFactor + r \times depthBiasConstantFactor,
-- depthBiasClamp) & depthBiasClamp < 0 \\ \end{cases}\]
--
-- m is computed as described above. If the depth buffer uses a
-- fixed-point representation, m is a function of depth values in the
-- range [0,1], and o is applied to depth values in the same range.
--
-- For fixed-point depth buffers, fragment depth values are always
-- limited to the range [0,1] by clamping after depth bias addition is
-- performed. Unless the
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled, fragment depth values are clamped even when the
-- depth buffer uses a floating-point representation.
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_DEPTH_BIAS dynamic state enabled
--
--
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdSetDepthBias :: ("commandBuffer" ::: VkCommandBuffer) -> ("depthBiasConstantFactor" ::: CFloat) -> ("depthBiasClamp" ::: CFloat) -> ("depthBiasSlopeFactor" ::: CFloat) -> IO ()
-- | vkCmdSetBlendConstants - Set the values of blend constants
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - blendConstants is an array of four values specifying the
-- R, G, B, and A components of the blend constant color used in
-- blending, depending on the blend factor.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_BLEND_CONSTANTS dynamic state enabled
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdSetBlendConstants :: ("commandBuffer" ::: VkCommandBuffer) -> ("blendConstants" ::: Ptr CFloat) -> IO ()
-- | vkCmdSetDepthBounds - Set the depth bounds test values for a command
-- buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - minDepthBounds is the lower bound of the range of depth
-- values used in the depth bounds test.
-- - maxDepthBounds is the upper bound of the range.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_DEPTH_BOUNDS dynamic state enabled
--
--
--
-- - Unless the
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled minDepthBounds must be between
-- 0.0 and 1.0, inclusive
-- - Unless the
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled maxDepthBounds must be between
-- 0.0 and 1.0, inclusive
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdSetDepthBounds :: ("commandBuffer" ::: VkCommandBuffer) -> ("minDepthBounds" ::: CFloat) -> ("maxDepthBounds" ::: CFloat) -> IO ()
-- | vkCmdSetStencilCompareMask - Set the stencil compare mask dynamic
-- state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - faceMask is a bitmask of VkStencilFaceFlagBits
-- specifying the set of stencil state for which to update the compare
-- mask.
-- - compareMask is the new value to use as the stencil
-- compare mask.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK dynamic state
-- enabled
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - faceMask must be a valid combination of
-- VkStencilFaceFlagBits values
-- - faceMask must not be 0
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkStencilFaceFlags
vkCmdSetStencilCompareMask :: ("commandBuffer" ::: VkCommandBuffer) -> ("faceMask" ::: VkStencilFaceFlags) -> ("compareMask" ::: Word32) -> IO ()
-- | vkCmdSetStencilWriteMask - Set the stencil write mask dynamic state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - faceMask is a bitmask of VkStencilFaceFlagBits
-- specifying the set of stencil state for which to update the write
-- mask, as described above for vkCmdSetStencilCompareMask.
-- - writeMask is the new value to use as the stencil write
-- mask.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_STENCIL_WRITE_MASK dynamic state
-- enabled
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - faceMask must be a valid combination of
-- VkStencilFaceFlagBits values
-- - faceMask must not be 0
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkStencilFaceFlags
vkCmdSetStencilWriteMask :: ("commandBuffer" ::: VkCommandBuffer) -> ("faceMask" ::: VkStencilFaceFlags) -> ("writeMask" ::: Word32) -> IO ()
-- | vkCmdSetStencilReference - Set the stencil reference dynamic state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - faceMask is a bitmask of VkStencilFaceFlagBits
-- specifying the set of stencil state for which to update the reference
-- value, as described above for vkCmdSetStencilCompareMask.
-- - reference is the new value to use as the stencil
-- reference value.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The bound graphics pipeline must have been created with the
-- VK_DYNAMIC_STATE_STENCIL_REFERENCE dynamic state enabled
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - faceMask must be a valid combination of
-- VkStencilFaceFlagBits values
-- - faceMask must not be 0
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkStencilFaceFlags
vkCmdSetStencilReference :: ("commandBuffer" ::: VkCommandBuffer) -> ("faceMask" ::: VkStencilFaceFlags) -> ("reference" ::: Word32) -> IO ()
-- | vkCmdBindDescriptorSets - Binds descriptor sets to a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer that the descriptor
-- sets will be bound to.
--
--
--
-- - pipelineBindPoint is a VkPipelineBindPoint
-- indicating whether the descriptors will be used by graphics pipelines
-- or compute pipelines. There is a separate set of bind points for each
-- of graphics and compute, so binding one does not disturb the
-- other.
-- - layout is a VkPipelineLayout object used to
-- program the bindings.
-- - firstSet is the set number of the first descriptor set to
-- be bound.
-- - descriptorSetCount is the number of elements in the
-- pDescriptorSets array.
-- - pDescriptorSets is an array of handles to
-- VkDescriptorSet objects describing the descriptor sets to
-- write to.
-- - dynamicOffsetCount is the number of dynamic offsets in
-- the pDynamicOffsets array.
-- - pDynamicOffsets is a pointer to an array of
-- uint32_t values specifying dynamic offsets.
--
--
-- Description
--
-- vkCmdBindDescriptorSets causes the sets numbered
-- [firstSet.. firstSet+descriptorSetCount-1]
-- to use the bindings stored in
-- pDescriptorSets[0..descriptorSetCount-1] for
-- subsequent rendering commands (either compute or graphics, according
-- to the pipelineBindPoint). Any bindings that were previously
-- applied via these sets are no longer valid.
--
-- Once bound, a descriptor set affects rendering of subsequent graphics
-- or compute commands in the command buffer until a different set is
-- bound to the same set number, or else until the set is disturbed as
-- described in Pipeline Layout Compatibility.
--
-- A compatible descriptor set must be bound for all set numbers
-- that any shaders in a pipeline access, at the time that a draw or
-- dispatch command is recorded to execute using that pipeline. However,
-- if none of the shaders in a pipeline statically use any bindings with
-- a particular set number, then no descriptor set need be bound for that
-- set number, even if the pipeline layout includes a non-trivial
-- descriptor set layout for that set number.
--
-- If any of the sets being bound include dynamic uniform or storage
-- buffers, then pDynamicOffsets includes one element for each
-- array element in each dynamic descriptor type binding in each set.
-- Values are taken from pDynamicOffsets in an order such that
-- all entries for set N come before set N+1; within a set, entries are
-- ordered by the binding numbers in the descriptor set layouts; and
-- within a binding array, elements are in order.
-- dynamicOffsetCount must equal the total number of
-- dynamic descriptors in the sets being bound.
--
-- The effective offset used for dynamic uniform and storage buffer
-- bindings is the sum of the relative offset taken from
-- pDynamicOffsets, and the base address of the buffer plus base
-- offset in the descriptor set. The length of the dynamic uniform and
-- storage buffer bindings is the buffer range as specified in the
-- descriptor set.
--
-- Each of the pDescriptorSets must be compatible with
-- the pipeline layout specified by layout. The layout used to
-- program the bindings must also be compatible with the pipeline
-- used in subsequent graphics or compute commands, as defined in the
-- Pipeline Layout Compatibility section.
--
-- The descriptor set contents bound by a call to
-- vkCmdBindDescriptorSets may be consumed at the
-- following times:
--
--
-- - For descriptor bindings created with the
-- VK_DESCRIPTOR_BINDING_UPDATE_AFTER_BIND_BIT_EXT bit set, the
-- contents may be consumed when the command buffer is submitted
-- to a queue, or during shader execution of the resulting draws and
-- dispatches, or any time in between. Otherwise,
-- - during host execution of the command, or during shader execution
-- of the resulting draws and dispatches, or any time in between.
--
--
-- Thus, the contents of a descriptor set binding must not be
-- altered (overwritten by an update command, or freed) between the first
-- point in time that it may be consumed, and and when the command
-- completes executing on the queue.
--
-- The contents of pDynamicOffsets are consumed immediately
-- during execution of vkCmdBindDescriptorSets. Once all pending
-- uses have completed, it is legal to update and reuse a descriptor set.
--
-- Valid Usage
--
--
-- - Each element of pDescriptorSets must have been
-- allocated with a VkDescriptorSetLayout that matches (is the
-- same as, or identically defined as) the VkDescriptorSetLayout
-- at set n in layout, where n is the sum of
-- firstSet and the index into pDescriptorSets
--
--
--
-- - dynamicOffsetCount must be equal to the total
-- number of dynamic descriptors in pDescriptorSets
-- - The sum of firstSet and descriptorSetCount
-- must be less than or equal to
-- VkPipelineLayoutCreateInfo::setLayoutCount provided
-- when layout was created
-- - pipelineBindPoint must be supported by the
-- commandBuffer’s parent VkCommandPool’s queue
-- family
-- - Each element of pDynamicOffsets must satisfy the
-- required alignment for the corresponding descriptor binding’s
-- descriptor type
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - layout must be a valid VkPipelineLayout
-- handle
-- - pDescriptorSets must be a valid pointer to an
-- array of descriptorSetCount valid VkDescriptorSet
-- handles
-- - If dynamicOffsetCount is not 0,
-- pDynamicOffsets must be a valid pointer to an array of
-- dynamicOffsetCount uint32_t values
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - descriptorSetCount must be greater than
-- 0
-- - Each of commandBuffer, layout, and the elements
-- of pDescriptorSets must have been created, allocated,
-- or retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkDescriptorSet,
-- VkPipelineBindPoint, VkPipelineLayout
vkCmdBindDescriptorSets :: ("commandBuffer" ::: VkCommandBuffer) -> ("pipelineBindPoint" ::: VkPipelineBindPoint) -> ("layout" ::: VkPipelineLayout) -> ("firstSet" ::: Word32) -> ("descriptorSetCount" ::: Word32) -> ("pDescriptorSets" ::: Ptr VkDescriptorSet) -> ("dynamicOffsetCount" ::: Word32) -> ("pDynamicOffsets" ::: Ptr Word32) -> IO ()
-- | vkCmdBindIndexBuffer - Bind an index buffer to a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - buffer is the buffer being bound.
-- - offset is the starting offset in bytes within
-- buffer used in index buffer address calculations.
-- - indexType is a VkIndexType value specifying
-- whether indices are treated as 16 bits or 32 bits.
--
--
-- Description
--
-- Valid Usage
--
--
-- - offset must be less than the size of
-- buffer
--
--
--
-- - The sum of offset and the address of the range of
-- VkDeviceMemory object that is backing buffer,
-- must be a multiple of the type indicated by
-- indexType
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDEX_BUFFER_BIT flag
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - indexType must be a valid VkIndexType
-- value
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - Both of buffer, and commandBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize,
-- VkIndexType
vkCmdBindIndexBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> ("indexType" ::: VkIndexType) -> IO ()
-- | vkCmdBindVertexBuffers - Bind vertex buffers to a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - firstBinding is the index of the first vertex input
-- binding whose state is updated by the command.
-- - bindingCount is the number of vertex input bindings whose
-- state is updated by the command.
-- - pBuffers is a pointer to an array of buffer handles.
-- - pOffsets is a pointer to an array of buffer offsets.
--
--
-- Description
--
-- The values taken from elements i of pBuffers and
-- pOffsets replace the current state for the vertex input
-- binding firstBinding + i, for i in [0,
-- bindingCount). The vertex input binding is updated to start
-- at the offset indicated by pOffsets[i] from the start of the
-- buffer pBuffers[i]. All vertex input attributes that use each
-- of these bindings will use these updated addresses in their address
-- calculations for subsequent draw commands.
--
-- Valid Usage
--
--
-- - firstBinding must be less than
-- VkPhysicalDeviceLimits::maxVertexInputBindings
--
--
--
-- - The sum of firstBinding and bindingCount
-- must be less than or equal to
-- VkPhysicalDeviceLimits::maxVertexInputBindings
-- - All elements of pOffsets must be less than the
-- size of the corresponding element in pBuffers
-- - All elements of pBuffers must have been created
-- with the VK_BUFFER_USAGE_VERTEX_BUFFER_BIT flag
-- - Each element of pBuffers that is non-sparse must
-- be bound completely and contiguously to a single
-- VkDeviceMemory object
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pBuffers must be a valid pointer to an array of
-- bindingCount valid VkBuffer handles
-- - pOffsets must be a valid pointer to an array of
-- bindingCount VkDeviceSize values
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - bindingCount must be greater than 0
-- - Both of commandBuffer, and the elements of
-- pBuffers must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdBindVertexBuffers :: ("commandBuffer" ::: VkCommandBuffer) -> ("firstBinding" ::: Word32) -> ("bindingCount" ::: Word32) -> ("pBuffers" ::: Ptr VkBuffer) -> ("pOffsets" ::: Ptr VkDeviceSize) -> IO ()
-- | vkCmdDraw - Draw primitives
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - vertexCount is the number of vertices to draw.
-- - instanceCount is the number of instances to draw.
-- - firstVertex is the index of the first vertex to
-- draw.
-- - firstInstance is the instance ID of the first instance to
-- draw.
--
--
-- Description
--
-- When the command is executed, primitives are assembled using the
-- current primitive topology and vertexCount consecutive vertex
-- indices with the first vertexIndex value equal to
-- firstVertex. The primitives are drawn instanceCount
-- times with instanceIndex starting with firstInstance
-- and increasing sequentially for each instance. The assembled
-- primitives execute the bound graphics pipeline.
--
-- Valid Usage
--
--
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
--
--
--
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - For a given vertex buffer binding, any attribute data fetched
-- must be entirely contained within the corresponding vertex
-- buffer binding, as described in
-- {html_spec_relative}#fxvertex-input
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdDraw :: ("commandBuffer" ::: VkCommandBuffer) -> ("vertexCount" ::: Word32) -> ("instanceCount" ::: Word32) -> ("firstVertex" ::: Word32) -> ("firstInstance" ::: Word32) -> IO ()
-- | vkCmdDrawIndexed - Issue an indexed draw into a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - indexCount is the number of vertices to draw.
-- - instanceCount is the number of instances to draw.
-- - firstIndex is the base index within the index
-- buffer.
-- - vertexOffset is the value added to the vertex index
-- before indexing into the vertex buffer.
-- - firstInstance is the instance ID of the first instance to
-- draw.
--
--
-- Description
--
-- When the command is executed, primitives are assembled using the
-- current primitive topology and indexCount vertices whose
-- indices are retrieved from the index buffer. The index buffer is
-- treated as an array of tightly packed unsigned integers of size
-- defined by the vkCmdBindIndexBuffer::indexType
-- parameter with which the buffer was bound.
--
-- The first vertex index is at an offset of firstIndex *
-- indexSize + offset within the bound index buffer,
-- where offset is the offset specified by
-- vkCmdBindIndexBuffer and indexSize is the byte size
-- of the type specified by indexType. Subsequent index values
-- are retrieved from consecutive locations in the index buffer. Indices
-- are first compared to the primitive restart value, then zero extended
-- to 32 bits (if the indexType is
-- VK_INDEX_TYPE_UINT16) and have vertexOffset added to
-- them, before being supplied as the vertexIndex value.
--
-- The primitives are drawn instanceCount times with
-- instanceIndex starting with firstInstance and
-- increasing sequentially for each instance. The assembled primitives
-- execute the bound graphics pipeline.
--
-- Valid Usage
--
--
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
--
--
--
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - For a given vertex buffer binding, any attribute data fetched
-- must be entirely contained within the corresponding vertex
-- buffer binding, as described in
-- {html_spec_relative}#fxvertex-input
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - (indexSize * (firstIndex + indexCount)
-- + offset) must be less than or equal to the size of
-- the bound index buffer, with indexSize being based on the type
-- specified by indexType, where the index buffer,
-- indexType, and offset are specified via
-- vkCmdBindIndexBuffer
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdDrawIndexed :: ("commandBuffer" ::: VkCommandBuffer) -> ("indexCount" ::: Word32) -> ("instanceCount" ::: Word32) -> ("firstIndex" ::: Word32) -> ("vertexOffset" ::: Int32) -> ("firstInstance" ::: Word32) -> IO ()
-- | vkCmdDrawIndirect - Issue an indirect draw into a command buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - buffer is the buffer containing draw parameters.
-- - offset is the byte offset into buffer where
-- parameters begin.
-- - drawCount is the number of draws to execute, and
-- can be zero.
-- - stride is the byte stride between successive sets of draw
-- parameters.
--
--
-- Description
--
-- vkCmdDrawIndirect behaves similarly to vkCmdDraw
-- except that the parameters are read by the device from a buffer during
-- execution. drawCount draws are executed by the command, with
-- parameters taken from buffer starting at offset and
-- increasing by stride bytes for each successive draw. The
-- parameters of each draw are encoded in an array of
-- VkDrawIndirectCommand structures. If drawCount is less
-- than or equal to one, stride is ignored.
--
-- Valid Usage
--
--
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
--
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - offset must be a multiple of 4
-- - If drawCount is greater than 1, stride
-- must be a multiple of 4 and must be greater
-- than or equal to sizeof(VkDrawIndirectCommand)
-- - If the multi-draw indirect feature is not enabled,
-- drawCount must be 0 or 1
-- - If the drawIndirectFirstInstance feature is not enabled,
-- all the firstInstance members of the
-- VkDrawIndirectCommand structures accessed by this command
-- must be 0
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - If drawCount is equal to 1, (offset +
-- sizeof(VkDrawIndirectCommand)) must be less
-- than or equal to the size of buffer
-- - If drawCount is greater than 1, (stride
-- × (drawCount - 1) + offset +
-- sizeof(VkDrawIndirectCommand)) must be less
-- than or equal to the size of buffer
-- - drawCount must be less than or equal to
-- VkPhysicalDeviceLimits::maxDrawIndirectCount
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - Both of buffer, and commandBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdDrawIndirect :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> ("drawCount" ::: Word32) -> ("stride" ::: Word32) -> IO ()
-- | vkCmdDrawIndexedIndirect - Perform an indexed indirect draw
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - buffer is the buffer containing draw parameters.
-- - offset is the byte offset into buffer where
-- parameters begin.
-- - drawCount is the number of draws to execute, and
-- can be zero.
-- - stride is the byte stride between successive sets of draw
-- parameters.
--
--
-- Description
--
-- vkCmdDrawIndexedIndirect behaves similarly to
-- vkCmdDrawIndexed except that the parameters are read by the
-- device from a buffer during execution. drawCount draws are
-- executed by the command, with parameters taken from buffer
-- starting at offset and increasing by stride bytes
-- for each successive draw. The parameters of each draw are encoded in
-- an array of VkDrawIndexedIndirectCommand structures. If
-- drawCount is less than or equal to one, stride is
-- ignored.
--
-- Valid Usage
--
--
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
--
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - offset must be a multiple of 4
-- - If drawCount is greater than 1, stride
-- must be a multiple of 4 and must be greater
-- than or equal to
-- sizeof(VkDrawIndexedIndirectCommand)
-- - If the multi-draw indirect feature is not enabled,
-- drawCount must be 0 or 1
-- - If the drawIndirectFirstInstance feature is not enabled,
-- all the firstInstance members of the
-- VkDrawIndexedIndirectCommand structures accessed by this
-- command must be 0
-- - The current render pass must be compatible with the
-- renderPass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - The subpass index of the current render pass must be equal
-- to the subpass member of the
-- VkGraphicsPipelineCreateInfo structure specified when
-- creating the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS.
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_GRAPHICS,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_GRAPHICS, with a
-- VkPipelineLayout that is compatible for push constants, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - All vertex input bindings accessed via vertex input variables
-- declared in the vertex shader entry point’s interface must have
-- valid buffers bound
-- - A valid graphics pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_GRAPHICS
-- - If the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS requires any dynamic state,
-- that state must have been set on the current command
-- buffer
-- - If drawCount is equal to 1, (offset +
-- sizeof(VkDrawIndexedIndirectCommand)) must be
-- less than or equal to the size of buffer
-- - If drawCount is greater than 1, (stride
-- × (drawCount - 1) + offset +
-- sizeof(VkDrawIndexedIndirectCommand)) must be
-- less than or equal to the size of buffer
-- - drawCount must be less than or equal to
-- VkPhysicalDeviceLimits::maxDrawIndirectCount
-- - Every input attachment used by the current subpass must be
-- bound to the pipeline via a descriptor set
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used to sample from any
-- VkImage with a VkImageView of the type
-- VK_IMAGE_VIEW_TYPE_3D, VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS uses unnormalized
-- coordinates, it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_GRAPHICS accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Image subresources used as attachments in the current render pass
-- must not be accessed in any way other than as an attachment by
-- this command.
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
-- - If the draw is recorded in a render pass instance with multiview
-- enabled, the maximum instance index must be less than or equal
-- to
-- VkPhysicalDeviceMultiviewProperties::maxMultiviewInstanceIndex.
-- - If the bound graphics pipeline was created with
-- VkPipelineSampleLocationsStateCreateInfoEXT::sampleLocationsEnable
-- set to VK_TRUE and the current subpass has a depth/stencil
-- attachment, then that attachment must have been created with
-- the VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT
-- bit set
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - Both of buffer, and commandBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdDrawIndexedIndirect :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> ("drawCount" ::: Word32) -> ("stride" ::: Word32) -> IO ()
-- | vkCmdDispatch - Dispatch compute work items
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - groupCountX is the number of local workgroups to dispatch
-- in the X dimension.
-- - groupCountY is the number of local workgroups to dispatch
-- in the Y dimension.
-- - groupCountZ is the number of local workgroups to dispatch
-- in the Z dimension.
--
--
-- Description
--
-- When the command is executed, a global workgroup consisting of
-- groupCountX × groupCountY × groupCountZ local workgroups is assembled.
--
-- Valid Usage
--
--
-- - groupCountX must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[0]
--
--
--
-- - groupCountY must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[1]
-- - groupCountZ must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[2]
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_COMPUTE,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_COMPUTE, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - A valid compute pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_COMPUTE
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_COMPUTE,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_COMPUTE, with a
-- VkPipelineLayout that is compatible for push constants with
-- the one used to create the current VkPipeline, as described
-- in {html_spec_relative}#descriptorsets-compatibility
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used to sample from any VkImage with a
-- VkImageView of the type VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support compute operations
-- - This command must only be called outside of a render pass
-- instance
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Compute | Compute |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdDispatch :: ("commandBuffer" ::: VkCommandBuffer) -> ("groupCountX" ::: Word32) -> ("groupCountY" ::: Word32) -> ("groupCountZ" ::: Word32) -> IO ()
-- | vkCmdDispatchIndirect - Dispatch compute work items using indirect
-- parameters
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - buffer is the buffer containing dispatch parameters.
-- - offset is the byte offset into buffer where
-- parameters begin.
--
--
-- Description
--
-- vkCmdDispatchIndirect behaves similarly to
-- vkCmdDispatch except that the parameters are read by the device
-- from a buffer during execution. The parameters of the dispatch are
-- encoded in a VkDispatchIndirectCommand structure taken from
-- buffer starting at offset.
--
-- Valid Usage
--
--
-- - If buffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
--
-- - For each set n that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_COMPUTE,
-- a descriptor set must have been bound to n at
-- VK_PIPELINE_BIND_POINT_COMPUTE, with a
-- VkPipelineLayout that is compatible for set n, with
-- the VkPipelineLayout used to create the current
-- VkPipeline, as described in
-- {html_spec_relative}#descriptorsets-compatibility
-- - Descriptors in each bound descriptor set, specified via
-- vkCmdBindDescriptorSets, must be valid if they are
-- statically used by the bound VkPipeline object, specified via
-- vkCmdBindPipeline
-- - A valid compute pipeline must be bound to the current
-- command buffer with VK_PIPELINE_BIND_POINT_COMPUTE
-- - buffer must have been created with the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set
-- - offset must be a multiple of 4
-- - The sum of offset and the size of
-- VkDispatchIndirectCommand must be less than or equal
-- to the size of buffer
-- - For each push constant that is statically used by the
-- VkPipeline bound to VK_PIPELINE_BIND_POINT_COMPUTE,
-- a push constant value must have been set for
-- VK_PIPELINE_BIND_POINT_COMPUTE, with a
-- VkPipelineLayout that is compatible for push constants with
-- the one used to create the current VkPipeline, as described
-- in {html_spec_relative}#descriptorsets-compatibility
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used to sample from any VkImage with a
-- VkImageView of the type VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE,
-- VK_IMAGE_VIEW_TYPE_1D_ARRAY,
-- VK_IMAGE_VIEW_TYPE_2D_ARRAY or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- with ImplicitLod, Dref or Proj in their
-- name, in any shader stage
-- - If any VkSampler object that is accessed from a shader by
-- the VkPipeline bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE uses unnormalized coordinates,
-- it must not be used with any of the SPIR-V
-- OpImageSample* or OpImageSparseSample* instructions
-- that includes a LOD bias or any offset values, in any shader
-- stage
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE accesses a uniform buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - If the robust buffer access feature is not enabled, and any
-- shader stage in the VkPipeline object bound to
-- VK_PIPELINE_BIND_POINT_COMPUTE accesses a storage buffer, it
-- must not access values outside of the range of that buffer
-- specified in the bound descriptor set
-- - Any VkImageView being sampled with
-- VK_FILTER_LINEAR as a result of this command must be
-- of a format which supports linear filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- be of a format which supports cubic filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - Any VkImageView being sampled with
-- VK_FILTER_CUBIC_IMG as a result of this command must
-- not have a VkImageViewType of VK_IMAGE_VIEW_TYPE_3D,
-- VK_IMAGE_VIEW_TYPE_CUBE, or
-- VK_IMAGE_VIEW_TYPE_CUBE_ARRAY
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support compute operations
-- - This command must only be called outside of a render pass
-- instance
-- - Both of buffer, and commandBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Compute | Compute |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdDispatchIndirect :: ("commandBuffer" ::: VkCommandBuffer) -> ("buffer" ::: VkBuffer) -> ("offset" ::: VkDeviceSize) -> IO ()
-- | vkCmdCopyBuffer - Copy data between buffer regions
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcBuffer is the source buffer.
-- - dstBuffer is the destination buffer.
-- - regionCount is the number of regions to copy.
-- - pRegions is a pointer to an array of VkBufferCopy
-- structures specifying the regions to copy.
--
--
-- Description
--
-- Each region in pRegions is copied from the source buffer to
-- the same region of the destination buffer. srcBuffer and
-- dstBuffer can be the same buffer or alias the same
-- memory, but the result is undefined if the copy regions overlap in
-- memory.
--
-- Valid Usage
--
--
-- - The size member of each element of pRegions
-- must be greater than 0
--
--
--
-- - The srcOffset member of each element of pRegions
-- must be less than the size of srcBuffer
-- - The dstOffset member of each element of pRegions
-- must be less than the size of dstBuffer
-- - The size member of each element of pRegions
-- must be less than or equal to the size of srcBuffer
-- minus srcOffset
-- - The size member of each element of pRegions
-- must be less than or equal to the size of dstBuffer
-- minus dstOffset
-- - The union of the source regions, and the union of the destination
-- regions, specified by the elements of pRegions, must
-- not overlap in memory
-- - srcBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_SRC_BIT usage flag
-- - If srcBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcBuffer must be a valid VkBuffer
-- handle
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - pRegions must be a valid pointer to an array of
-- regionCount VkBufferCopy structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstBuffer, and
-- srcBuffer must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkBufferCopy, VkCommandBuffer
vkCmdCopyBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcBuffer" ::: VkBuffer) -> ("dstBuffer" ::: VkBuffer) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkBufferCopy) -> IO ()
-- | vkCmdCopyImage - Copy data between images
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcImage is the source image.
-- - srcImageLayout is the current layout of the source image
-- subresource.
-- - dstImage is the destination image.
-- - dstImageLayout is the current layout of the destination
-- image subresource.
-- - regionCount is the number of regions to copy.
-- - pRegions is a pointer to an array of VkImageCopy
-- structures specifying the regions to copy.
--
--
-- Description
--
-- Each region in pRegions is copied from the source image to
-- the same region of the destination image. srcImage and
-- dstImage can be the same image or alias the same
-- memory.
--
-- The formats of srcImage and dstImage must be
-- compatible. Formats are considered compatible if their element size is
-- the same between both formats. For example,
-- VK_FORMAT_R8G8B8A8_UNORM is compatible with
-- VK_FORMAT_R32_UINT because both texels are 4 bytes in size.
-- Depth/stencil formats must match exactly.
--
-- If the format of srcImage or dstImage is a
-- multi-planar image format, regions of each plane to be copied
-- must be specified separately using the srcSubresource
-- and dstSubresource members of the VkImageCopy
-- structure. In this case, the aspectMask of the
-- srcSubresource or dstSubresource that refers to the
-- multi-planar image must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT. For the purposes of
-- vkCmdCopyImage, each plane of a multi-planar image is treated
-- as having the format listed in
-- {html_spec_relative}#features-formats-compatible-planes for the
-- plane identified by the aspectMask of the corresponding
-- subresource. This applies both to VkFormat and to coordinates
-- used in the copy, which correspond to texels in the plane
-- rather than how these texels map to coordinates in the image as a
-- whole.
--
-- Note
--
-- For example, the VK_IMAGE_ASPECT_PLANE_1_BIT plane of a
-- VK_FORMAT_G8_B8R8_2PLANE_420_UNORM image is compatible with
-- an image of format VK_FORMAT_R8G8_UNORM and (less usefully)
-- with the VK_IMAGE_ASPECT_PLANE_0_BIT plane of an image of
-- format VK_FORMAT_G10X6_B10X6_R10X6_3PLANE_420_UNORM_3PACK16,
-- as each texel is 2 bytes in size.
--
-- vkCmdCopyImage allows copying between size-compatible
-- compressed and uncompressed internal formats. Formats are
-- size-compatible if the element size of the uncompressed format is
-- equal to the element size (compressed texel block size) of the
-- compressed format. Such a copy does not perform on-the-fly compression
-- or decompression. When copying from an uncompressed format to a
-- compressed format, each texel of uncompressed data of the source image
-- is copied as a raw value to the corresponding compressed texel block
-- of the destination image. When copying from a compressed format to an
-- uncompressed format, each compressed texel block of the source image
-- is copied as a raw value to the corresponding texel of uncompressed
-- data in the destination image. Thus, for example, it is legal to copy
-- between a 128-bit uncompressed format and a compressed format which
-- has a 128-bit sized compressed texel block representing 4×4 texels
-- (using 8 bits per texel), or between a 64-bit uncompressed format and
-- a compressed format which has a 64-bit sized compressed texel block
-- representing 4×4 texels (using 4 bits per texel).
--
-- When copying between compressed and uncompressed formats the
-- extent members represent the texel dimensions of the source
-- image and not the destination. When copying from a compressed image to
-- an uncompressed image the image texel dimensions written to the
-- uncompressed image will be source extent divided by the compressed
-- texel block dimensions. When copying from an uncompressed image to a
-- compressed image the image texel dimensions written to the compressed
-- image will be the source extent multiplied by the compressed texel
-- block dimensions. In both cases the number of bytes read and the
-- number of bytes written will be identical.
--
-- Copying to or from block-compressed images is typically done in
-- multiples of the compressed texel block size. For this reason the
-- extent must be a multiple of the compressed texel
-- block dimension. There is one exception to this rule which is
-- required to handle compressed images created with dimensions
-- that are not a multiple of the compressed texel block dimensions: if
-- the srcImage is compressed, then:
--
--
-- - If extent.width is not a multiple of the compressed texel
-- block width, then (extent.width + srcOffset.x)
-- must equal the image subresource width.
-- - If extent.height is not a multiple of the compressed
-- texel block height, then (extent.height +
-- srcOffset.y) must equal the image subresource
-- height.
-- - If extent.depth is not a multiple of the compressed texel
-- block depth, then (extent.depth + srcOffset.z)
-- must equal the image subresource depth.
--
--
-- Similarly, if the dstImage is compressed, then:
--
--
-- - If extent.width is not a multiple of the compressed texel
-- block width, then (extent.width + dstOffset.x)
-- must equal the image subresource width.
-- - If extent.height is not a multiple of the compressed
-- texel block height, then (extent.height +
-- dstOffset.y) must equal the image subresource
-- height.
-- - If extent.depth is not a multiple of the compressed texel
-- block depth, then (extent.depth + dstOffset.z)
-- must equal the image subresource depth.
--
--
-- This allows the last compressed texel block of the image in each
-- non-multiple dimension to be included as a source or destination of
-- the copy.
--
-- “_422” image formats that are not multi-planar are
-- treated as having a 2×1 compressed texel block for the purposes of
-- these rules.
--
-- vkCmdCopyImage can be used to copy image data between
-- multisample images, but both images must have the same number
-- of samples.
--
-- Valid Usage
--
--
-- - The source region specified by each element of pRegions
-- must be a region that is contained within srcImage if
-- the srcImage’s VkFormat is not a multi-planar
-- format, and must be a region that is contained within the
-- plane being copied if the srcImage’s VkFormat is a
-- multi-planar format
--
--
--
-- - The destination region specified by each element of
-- pRegions must be a region that is contained within
-- dstImage if the dstImage’s VkFormat is not a
-- multi-planar format, and must be a region that is
-- contained within the plane being copied to if the dstImage’s
-- VkFormat is a multi-planar format
-- - The union of all source regions, and the union of all destination
-- regions, specified by the elements of pRegions, must
-- not overlap in memory
-- - srcImage must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_SRC_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - srcImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT usage flag
-- - If srcImage is non-sparse then the image or
-- disjoint plane to be copied must be bound completely and
-- contiguously to a single VkDeviceMemory object
-- - srcImageLayout must specify the layout of the
-- image subresources of srcImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - srcImageLayout must be
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL,
-- VK_IMAGE_LAYOUT_GENERAL, or
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR
-- - dstImage must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_DST_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - dstImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstImage is non-sparse then the image or
-- disjoint plane that is the destination of the copy must
-- be bound completely and contiguously to a single
-- VkDeviceMemory object
-- - dstImageLayout must specify the layout of the
-- image subresources of dstImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - dstImageLayout must be
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
-- VK_IMAGE_LAYOUT_GENERAL, or
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR
-- - If the VkFormat of each of srcImage and
-- dstImage is not a multi-planar format, the
-- VkFormat of each of srcImage and dstImage
-- must be compatible, as defined below
-- - In a copy to or from a plane of a multi-planar image, the
-- VkFormat of the image and plane must be compatible
-- according to the description of compatible planes for the plane
-- being copied
-- - When a copy is performed to or from an image with a
-- multi-planar format, the aspectMask of the
-- srcSubresource and/or dstSubresource that refers to
-- the multi-planar image must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT (with
-- VK_IMAGE_ASPECT_PLANE_2_BIT valid only for a VkFormat
-- with three planes)
-- - The sample count of srcImage and dstImage
-- must match
-- - The srcSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when srcImage was
-- created
-- - The dstSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when dstImage was
-- created
-- - The srcSubresource.baseArrayLayer +
-- srcSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- srcImage was created
-- - The dstSubresource.baseArrayLayer +
-- dstSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- dstImage was created
-- - The srcOffset and and extent members of each
-- element of pRegions must respect the image transfer
-- granularity requirements of commandBuffer’s command pool’s
-- queue family, as described in VkQueueFamilyProperties
-- - The dstOffset and and extent members of each
-- element of pRegions must respect the image transfer
-- granularity requirements of commandBuffer’s command pool’s
-- queue family, as described in VkQueueFamilyProperties
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcImage must be a valid VkImage
-- handle
-- - srcImageLayout must be a valid
-- VkImageLayout value
-- - dstImage must be a valid VkImage
-- handle
-- - dstImageLayout must be a valid
-- VkImageLayout value
-- - pRegions must be a valid pointer to an array of
-- regionCount valid VkImageCopy structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstImage, and
-- srcImage must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkImage, VkImageCopy,
-- VkImageLayout
vkCmdCopyImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcImage" ::: VkImage) -> ("srcImageLayout" ::: VkImageLayout) -> ("dstImage" ::: VkImage) -> ("dstImageLayout" ::: VkImageLayout) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkImageCopy) -> IO ()
-- | vkCmdBlitImage - Copy regions of an image, potentially performing
-- format conversion,
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcImage is the source image.
-- - srcImageLayout is the layout of the source image
-- subresources for the blit.
-- - dstImage is the destination image.
-- - dstImageLayout is the layout of the destination image
-- subresources for the blit.
-- - regionCount is the number of regions to blit.
-- - pRegions is a pointer to an array of VkImageBlit
-- structures specifying the regions to blit.
-- - filter is a VkFilter specifying the filter to
-- apply if the blits require scaling.
--
--
-- Description
--
-- vkCmdBlitImage must not be used for multisampled
-- source or destination images. Use vkCmdResolveImage for this
-- purpose.
--
-- As the sizes of the source and destination extents can differ
-- in any dimension, texels in the source extent are scaled and filtered
-- to the destination extent. Scaling occurs via the following
-- operations:
--
--
-- - For each destination texel, the integer coordinate of that texel
-- is converted to an unnormalized texture coordinate, using the
-- effective inverse of the equations described in unnormalized to
-- integer conversion:
- ubase = i + ½
- vbase = j +
-- ½
- wbase = k + ½
-- - These base coordinates are then offset by the first destination
-- offset:
- uoffset = ubase - xdst0
- voffset = vbase -
-- ydst0
- woffset = wbase - zdst0
- aoffset = a -
-- baseArrayCountdst
-- - The scale is determined from the source and destination regions,
-- and applied to the offset coordinates:
- scale_u = (xsrc1 -
-- xsrc0) / (xdst1 - xdst0)
- scale_v = (ysrc1 - ysrc0) / (ydst1 -
-- ydst0)
- scale_w = (zsrc1 - zsrc0) / (zdst1 -
-- zdst0)
- uscaled = uoffset * scaleu
- vscaled = voffset *
-- scalev
- wscaled = woffset * scalew
-- - Finally the source offset is added to the scaled coordinates, to
-- determine the final unnormalized coordinates used to sample from
-- srcImage:
- u = uscaled + xsrc0
- v = vscaled +
-- ysrc0
- w = wscaled + zsrc0
- q =
-- mipLevel
- a = aoffset +
-- baseArrayCountsrc
--
--
-- These coordinates are used to sample from the source image, as
-- described in Image Operations chapter, with the filter mode
-- equal to that of filter, a mipmap mode of
-- VK_SAMPLER_MIPMAP_MODE_NEAREST and an address mode of
-- VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE. Implementations
-- must clamp at the edge of the source image, and may
-- additionally clamp to the edge of the source region.
--
-- Note
--
-- Due to allowable rounding errors in the generation of the source
-- texture coordinates, it is not always possible to guarantee exactly
-- which source texels will be sampled for a given blit. As rounding
-- errors are implementation dependent, the exact results of a blitting
-- operation are also implementation dependent.
--
-- Blits are done layer by layer starting with the
-- baseArrayLayer member of srcSubresource for the
-- source and dstSubresource for the destination.
-- layerCount layers are blitted to the destination image.
--
-- 3D textures are blitted slice by slice. Slices in the source region
-- bounded by srcOffsets[0].z and
-- srcOffsets[1].z are copied to slices in the
-- destination region bounded by dstOffsets[0].z and
-- dstOffsets[1].z. For each destination slice, a
-- source z coordinate is linearly interpolated between
-- srcOffsets[0].z and
-- srcOffsets[1].z. If the filter parameter is
-- VK_FILTER_LINEAR then the value sampled from the source image
-- is taken by doing linear filtering using the interpolated z
-- coordinate. If filter parameter is VK_FILTER_NEAREST
-- then value sampled from the source image is taken from the single
-- nearest slice (with undefined rounding mode).
--
-- The following filtering and conversion rules apply:
--
--
-- - Integer formats can only be converted to other integer
-- formats with the same signedness.
-- - No format conversion is supported between depth/stencil images.
-- The formats must match.
-- - Format conversions on unorm, snorm, unscaled and packed float
-- formats of the copied aspect of the image are performed by first
-- converting the pixels to float values.
-- - For sRGB source formats, nonlinear RGB values are converted to
-- linear representation prior to filtering.
-- - After filtering, the float values are first clamped and then cast
-- to the destination image format. In case of sRGB destination format,
-- linear RGB values are converted to nonlinear representation before
-- writing the pixel to the image.
--
--
-- Signed and unsigned integers are converted by first clamping to the
-- representable range of the destination format, then casting the value.
--
-- Valid Usage
--
--
-- - The source region specified by each element of pRegions
-- must be a region that is contained within
-- srcImage
--
--
--
-- - The destination region specified by each element of
-- pRegions must be a region that is contained within
-- dstImage
-- - The union of all destination regions, specified by the elements of
-- pRegions, must not overlap in memory with any texel
-- that may be sampled during the blit operation
-- - srcImage must use a format that supports
-- VK_FORMAT_FEATURE_BLIT_SRC_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - srcImage must not use a format listed in
-- {html_spec_relative}#features-formats-requiring-sampler-ycbcr-conversion
-- - srcImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT usage flag
-- - If srcImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - srcImageLayout must specify the layout of the
-- image subresources of srcImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - srcImageLayout must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - dstImage must use a format that supports
-- VK_FORMAT_FEATURE_BLIT_DST_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - dstImage must not use a format listed in
-- {html_spec_relative}#features-formats-requiring-sampler-ycbcr-conversion
-- - dstImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstImageLayout must specify the layout of the
-- image subresources of dstImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - dstImageLayout must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - The sample count of srcImage and dstImage
-- must both be equal to VK_SAMPLE_COUNT_1_BIT
-- - If either of srcImage or dstImage was created
-- with a signed integer VkFormat, the other must also have
-- been created with a signed integer VkFormat
-- - If either of srcImage or dstImage was created
-- with an unsigned integer VkFormat, the other must also
-- have been created with an unsigned integer VkFormat
-- - If either of srcImage or dstImage was created
-- with a depth/stencil format, the other must have exactly the
-- same format
-- - If srcImage was created with a depth/stencil format,
-- filter must be VK_FILTER_NEAREST
-- - srcImage must have been created with a
-- samples value of VK_SAMPLE_COUNT_1_BIT
-- - dstImage must have been created with a
-- samples value of VK_SAMPLE_COUNT_1_BIT
-- - If filter is VK_FILTER_LINEAR, srcImage
-- must be of a format which supports linear filtering, as
-- specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If filter is VK_FILTER_CUBIC_IMG,
-- srcImage must be of a format which supports cubic
-- filtering, as specified by the
-- VK_FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_CUBIC_BIT_IMG flag in
-- VkFormatProperties::linearTilingFeatures (for a
-- linear image) or
-- VkFormatProperties::optimalTilingFeatures(for an
-- optimally tiled image) returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If filter is VK_FILTER_CUBIC_IMG,
-- srcImage must have a VkImageType of
-- VK_IMAGE_TYPE_3D
-- - The srcSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when srcImage was
-- created
-- - The dstSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when dstImage was
-- created
-- - The srcSubresource.baseArrayLayer +
-- srcSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- srcImage was created
-- - The dstSubresource.baseArrayLayer +
-- dstSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- dstImage was created
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcImage must be a valid VkImage
-- handle
-- - srcImageLayout must be a valid
-- VkImageLayout value
-- - dstImage must be a valid VkImage
-- handle
-- - dstImageLayout must be a valid
-- VkImageLayout value
-- - pRegions must be a valid pointer to an array of
-- regionCount valid VkImageBlit structures
-- - filter must be a valid VkFilter value
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstImage, and
-- srcImage must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Transfer |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkFilter, VkImage,
-- VkImageBlit, VkImageLayout
vkCmdBlitImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcImage" ::: VkImage) -> ("srcImageLayout" ::: VkImageLayout) -> ("dstImage" ::: VkImage) -> ("dstImageLayout" ::: VkImageLayout) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkImageBlit) -> ("filter" ::: VkFilter) -> IO ()
-- | vkCmdCopyBufferToImage - Copy data from a buffer into an image
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcBuffer is the source buffer.
-- - dstImage is the destination image.
-- - dstImageLayout is the layout of the destination image
-- subresources for the copy.
-- - regionCount is the number of regions to copy.
-- - pRegions is a pointer to an array of
-- VkBufferImageCopy structures specifying the regions to
-- copy.
--
--
-- Description
--
-- Each region in pRegions is copied from the specified region
-- of the source buffer to the specified region of the destination image.
--
-- If the format of dstImage is a multi-planar image
-- format), regions of each plane to be a target of a copy
-- must be specified separately using the pRegions member
-- of the VkBufferImageCopy structure. In this case, the
-- aspectMask of imageSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT. For the purposes of
-- vkCmdCopyBufferToImage, each plane of a multi-planar image is
-- treated as having the format listed in
-- {html_spec_relative}#features-formats-compatible-planes for the
-- plane identified by the aspectMask of the corresponding
-- subresource. This applies both to VkFormat and to coordinates
-- used in the copy, which correspond to texels in the plane
-- rather than how these texels map to coordinates in the image as a
-- whole.
--
-- Valid Usage
--
--
-- - The buffer region specified by each element of pRegions
-- must be a region that is contained within
-- srcBuffer
--
--
--
-- - The image region specified by each element of pRegions
-- must be a region that is contained within dstImage if
-- the dstImage’s VkFormat is not a multi-planar
-- format, and must be a region that is contained within the
-- plane being copied to if the dstImage’s VkFormat is a
-- multi-planar format
-- - The union of all source regions, and the union of all destination
-- regions, specified by the elements of pRegions, must
-- not overlap in memory
-- - srcBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_SRC_BIT usage flag
-- - dstImage must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_DST_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If srcBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstImage must have a sample count equal to
-- VK_SAMPLE_COUNT_1_BIT
-- - dstImageLayout must specify the layout of the
-- image subresources of dstImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - dstImageLayout must be
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
-- VK_IMAGE_LAYOUT_GENERAL, or
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR
-- - The imageSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when dstImage was
-- created
-- - The imageSubresource.baseArrayLayer +
-- imageSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- dstImage was created
-- - The imageOffset and and imageExtent members of
-- each element of pRegions must respect the image
-- transfer granularity requirements of commandBuffer’s command
-- pool’s queue family, as described in
-- VkQueueFamilyProperties
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcBuffer must be a valid VkBuffer
-- handle
-- - dstImage must be a valid VkImage
-- handle
-- - dstImageLayout must be a valid
-- VkImageLayout value
-- - pRegions must be a valid pointer to an array of
-- regionCount valid VkBufferImageCopy structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstImage, and
-- srcBuffer must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkBufferImageCopy, VkCommandBuffer,
-- VkImage, VkImageLayout
vkCmdCopyBufferToImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcBuffer" ::: VkBuffer) -> ("dstImage" ::: VkImage) -> ("dstImageLayout" ::: VkImageLayout) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkBufferImageCopy) -> IO ()
-- | vkCmdCopyImageToBuffer - Copy image data into a buffer
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcImage is the source image.
-- - srcImageLayout is the layout of the source image
-- subresources for the copy.
-- - dstBuffer is the destination buffer.
-- - regionCount is the number of regions to copy.
-- - pRegions is a pointer to an array of
-- VkBufferImageCopy structures specifying the regions to
-- copy.
--
--
-- Description
--
-- Each region in pRegions is copied from the specified region
-- of the source image to the specified region of the destination buffer.
--
-- If the VkFormat of srcImage is a multi-planar image
-- format, regions of each plane to be a source of a copy must
-- be specified separately using the pRegions member of the
-- VkBufferImageCopy structure. In this case, the
-- aspectMask of imageSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT. For the purposes of
-- vkCmdCopyBufferToImage, each plane of a multi-planar image is
-- treated as having the format listed in
-- {html_spec_relative}#features-formats-compatible-planes for the
-- plane identified by the aspectMask of the corresponding
-- subresource. This applies both to VkFormat and to coordinates
-- used in the copy, which correspond to texels in the plane
-- rather than how these texels map to coordinates in the image as a
-- whole.
--
-- Valid Usage
--
--
-- - The image region specified by each element of pRegions
-- must be a region that is contained within srcImage if
-- the srcImage’s VkFormat is not a multi-planar
-- format, and must be a region that is contained within the
-- plane being copied if the srcImage’s VkFormat is a
-- multi-planar format
--
--
--
-- - The buffer region specified by each element of pRegions
-- must be a region that is contained within
-- dstBuffer
-- - The union of all source regions, and the union of all destination
-- regions, specified by the elements of pRegions, must
-- not overlap in memory
-- - srcImage must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_SRC_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
-- - srcImage must have been created with
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT usage flag
-- - If srcImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - srcImage must have a sample count equal to
-- VK_SAMPLE_COUNT_1_BIT
-- - srcImageLayout must specify the layout of the
-- image subresources of srcImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - srcImageLayout must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - The imageSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when srcImage was
-- created
-- - The imageSubresource.baseArrayLayer +
-- imageSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- srcImage was created
-- - The imageOffset and and imageExtent members of
-- each element of pRegions must respect the image
-- transfer granularity requirements of commandBuffer’s command
-- pool’s queue family, as described in
-- VkQueueFamilyProperties
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcImage must be a valid VkImage
-- handle
-- - srcImageLayout must be a valid
-- VkImageLayout value
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - pRegions must be a valid pointer to an array of
-- regionCount valid VkBufferImageCopy structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstBuffer, and
-- srcImage must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkBufferImageCopy, VkCommandBuffer,
-- VkImage, VkImageLayout
vkCmdCopyImageToBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcImage" ::: VkImage) -> ("srcImageLayout" ::: VkImageLayout) -> ("dstBuffer" ::: VkBuffer) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkBufferImageCopy) -> IO ()
-- | vkCmdUpdateBuffer - Update a buffer’s contents from host memory
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - dstBuffer is a handle to the buffer to be updated.
-- - dstOffset is the byte offset into the buffer to start
-- updating, and must be a multiple of 4.
-- - dataSize is the number of bytes to update, and
-- must be a multiple of 4.
-- - pData is a pointer to the source data for the buffer
-- update, and must be at least dataSize bytes in
-- size.
--
--
-- Description
--
-- dataSize must be less than or equal to 65536 bytes.
-- For larger updates, applications can use buffer to buffer
-- copies.
--
-- Note
--
-- Buffer updates performed with vkCmdUpdateBuffer first copy
-- the data into command buffer memory when the command is recorded
-- (which requires additional storage and may incur an additional
-- allocation), and then copy the data from the command buffer into
-- dstBuffer when the command is executed on a device.
--
-- The additional cost of this functionality compared to buffer to
-- buffer copies means it is only recommended for very small amounts
-- of data, and is why it is limited to only 65536 bytes.
--
-- Applications can work around this by issuing multiple
-- vkCmdUpdateBuffer commands to different ranges of the same
-- buffer, but it is strongly recommended that they should not.
--
-- The source data is copied from the user pointer to the command buffer
-- when the command is called.
--
-- vkCmdUpdateBuffer is only allowed outside of a render pass.
-- This command is treated as “transfer” operation, for the purposes of
-- synchronization barriers. The
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT must be specified in
-- usage of VkBufferCreateInfo in order for the buffer to
-- be compatible with vkCmdUpdateBuffer.
--
-- Valid Usage
--
--
-- - dstOffset must be less than the size of
-- dstBuffer
--
--
--
-- - dataSize must be less than or equal to the size of
-- dstBuffer minus dstOffset
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstOffset must be a multiple of 4
-- - dataSize must be less than or equal to
-- 65536
-- - dataSize must be a multiple of 4
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - pData must be a valid pointer to an array of
-- dataSize bytes
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - dataSize must be greater than 0
-- - Both of commandBuffer, and dstBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdUpdateBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("dstBuffer" ::: VkBuffer) -> ("dstOffset" ::: VkDeviceSize) -> ("dataSize" ::: VkDeviceSize) -> ("pData" ::: Ptr ()) -> IO ()
-- | vkCmdFillBuffer - Fill a region of a buffer with a fixed value
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - dstBuffer is the buffer to be filled.
-- - dstOffset is the byte offset into the buffer at which to
-- start filling, and must be a multiple of 4.
-- - size is the number of bytes to fill, and must be
-- either a multiple of 4, or VK_WHOLE_SIZE to fill the range
-- from offset to the end of the buffer. If
-- VK_WHOLE_SIZE is used and the remaining size of the buffer is
-- not a multiple of 4, then the nearest smaller multiple is used.
-- - data is the 4-byte word written repeatedly to the buffer
-- to fill size bytes of data. The data word is written to
-- memory according to the host endianness.
--
--
-- Description
--
-- vkCmdFillBuffer is treated as “transfer” operation for the
-- purposes of synchronization barriers. The
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT must be specified in
-- usage of VkBufferCreateInfo in order for the buffer
-- to be compatible with vkCmdFillBuffer.
--
-- Valid Usage
--
--
-- - dstOffset must be less than the size of
-- dstBuffer
--
--
--
-- - dstOffset must be a multiple of 4
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be greater than 0
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be less than or equal to the size of
-- dstBuffer minus dstOffset
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be a multiple of 4
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - Both of commandBuffer, and dstBuffer must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize
vkCmdFillBuffer :: ("commandBuffer" ::: VkCommandBuffer) -> ("dstBuffer" ::: VkBuffer) -> ("dstOffset" ::: VkDeviceSize) -> ("size" ::: VkDeviceSize) -> ("data" ::: Word32) -> IO ()
-- | vkCmdClearColorImage - Clear regions of a color image
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - image is the image to be cleared.
-- - imageLayout specifies the current layout of the image
-- subresource ranges to be cleared, and must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_GENERAL or
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL.
-- - pColor is a pointer to a VkClearColorValue
-- structure that contains the values the image subresource ranges will
-- be cleared to (see {html_spec_relative}#clears-values
-- below).
-- - rangeCount is the number of image subresource range
-- structures in pRanges.
-- - pRanges points to an array of
-- VkImageSubresourceRange structures that describe a range of
-- mipmap levels, array layers, and aspects to be cleared, as described
-- in Image Views. The aspectMask of all image
-- subresource ranges must only include
-- VK_IMAGE_ASPECT_COLOR_BIT.
--
--
-- Description
--
-- Each specified range in pRanges is cleared to the value
-- specified by pColor.
--
-- Valid Usage
--
--
-- - image must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_DST_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
--
--
--
-- - image must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
-- - image must not use a format listed in
-- {html_spec_relative}#features-formats-requiring-sampler-ycbcr-conversion
-- - If image is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - imageLayout must specify the layout of the image
-- subresource ranges of image specified in pRanges at
-- the time this command is executed on a VkDevice
-- - imageLayout must be
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL,
-- VK_IMAGE_LAYOUT_GENERAL, or
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR
-- - The VkImageSubresourceRange::baseMipLevel members
-- of the elements of the pRanges array must each be less
-- than the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - For each VkImageSubresourceRange element of
-- pRanges, if the levelCount member is not
-- VK_REMAINING_MIP_LEVELS, then baseMipLevel +
-- levelCount must be less than the mipLevels
-- specified in VkImageCreateInfo when image was
-- created
-- - The VkImageSubresourceRange::baseArrayLayer
-- members of the elements of the pRanges array must each
-- be less than the arrayLayers specified in
-- VkImageCreateInfo when image was created
-- - For each VkImageSubresourceRange element of
-- pRanges, if the layerCount member is not
-- VK_REMAINING_ARRAY_LAYERS, then baseArrayLayer +
-- layerCount must be less than the arrayLayers
-- specified in VkImageCreateInfo when image was
-- created
-- - image must not have a compressed or depth/stencil
-- format
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - image must be a valid VkImage handle
-- - imageLayout must be a valid VkImageLayout
-- value
-- - pColor must be a valid pointer to a valid
-- VkClearColorValue union
-- - pRanges must be a valid pointer to an array of
-- rangeCount valid VkImageSubresourceRange
-- structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - rangeCount must be greater than 0
-- - Both of commandBuffer, and image must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Transfer |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkClearColorValue, VkCommandBuffer, VkImage,
-- VkImageLayout, VkImageSubresourceRange
vkCmdClearColorImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("image" ::: VkImage) -> ("imageLayout" ::: VkImageLayout) -> ("pColor" ::: Ptr VkClearColorValue) -> ("rangeCount" ::: Word32) -> ("pRanges" ::: Ptr VkImageSubresourceRange) -> IO ()
-- | vkCmdClearDepthStencilImage - Fill regions of a combined depth/stencil
-- image
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - image is the image to be cleared.
-- - imageLayout specifies the current layout of the image
-- subresource ranges to be cleared, and must be
-- VK_IMAGE_LAYOUT_GENERAL or
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL.
-- - pDepthStencil is a pointer to a
-- VkClearDepthStencilValue structure that contains the values the
-- depth and stencil image subresource ranges will be cleared to (see
-- {html_spec_relative}#clears-values below).
-- - rangeCount is the number of image subresource range
-- structures in pRanges.
-- - pRanges points to an array of
-- VkImageSubresourceRange structures that describe a range of
-- mipmap levels, array layers, and aspects to be cleared, as described
-- in Image Views. The aspectMask of each image
-- subresource range in pRanges can include
-- VK_IMAGE_ASPECT_DEPTH_BIT if the image format has a depth
-- component, and VK_IMAGE_ASPECT_STENCIL_BIT if the image
-- format has a stencil component. pDepthStencil is a pointer to
-- a VkClearDepthStencilValue structure that contains the values
-- the image subresource ranges will be cleared to (see
-- {html_spec_relative}#clears-values below).
--
--
-- Description
--
-- Valid Usage
--
--
-- - image must use a format that supports
-- VK_FORMAT_FEATURE_TRANSFER_DST_BIT, which is indicated by
-- VkFormatProperties::linearTilingFeatures (for
-- linearly tiled images) or
-- VkFormatProperties::optimalTilingFeatures (for
-- optimally tiled images) - as returned by
-- vkGetPhysicalDeviceFormatProperties
--
--
--
-- - image must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT usage flag
-- - If image is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - imageLayout must specify the layout of the image
-- subresource ranges of image specified in pRanges at
-- the time this command is executed on a VkDevice
-- - imageLayout must be either of
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - The VkImageSubresourceRange::baseMipLevel members
-- of the elements of the pRanges array must each be less
-- than the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - For each VkImageSubresourceRange element of
-- pRanges, if the levelCount member is not
-- VK_REMAINING_MIP_LEVELS, then baseMipLevel +
-- levelCount must be less than the mipLevels
-- specified in VkImageCreateInfo when image was
-- created
-- - The VkImageSubresourceRange::baseArrayLayer
-- members of the elements of the pRanges array must each
-- be less than the arrayLayers specified in
-- VkImageCreateInfo when image was created
-- - For each VkImageSubresourceRange element of
-- pRanges, if the layerCount member is not
-- VK_REMAINING_ARRAY_LAYERS, then baseArrayLayer +
-- layerCount must be less than the arrayLayers
-- specified in VkImageCreateInfo when image was
-- created
-- - image must have a depth/stencil format
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - image must be a valid VkImage handle
-- - imageLayout must be a valid VkImageLayout
-- value
-- - pDepthStencil must be a valid pointer to a valid
-- VkClearDepthStencilValue structure
-- - pRanges must be a valid pointer to an array of
-- rangeCount valid VkImageSubresourceRange
-- structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called outside of a render pass
-- instance
-- - rangeCount must be greater than 0
-- - Both of commandBuffer, and image must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Transfer |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkClearDepthStencilValue, VkCommandBuffer,
-- VkImage, VkImageLayout, VkImageSubresourceRange
vkCmdClearDepthStencilImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("image" ::: VkImage) -> ("imageLayout" ::: VkImageLayout) -> ("pDepthStencil" ::: Ptr VkClearDepthStencilValue) -> ("rangeCount" ::: Word32) -> ("pRanges" ::: Ptr VkImageSubresourceRange) -> IO ()
-- | vkCmdClearAttachments - Clear regions within bound framebuffer
-- attachments
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - attachmentCount is the number of entries in the
-- pAttachments array.
-- - pAttachments is a pointer to an array of
-- VkClearAttachment structures defining the attachments to clear
-- and the clear values to use.
-- - rectCount is the number of entries in the pRects
-- array.
-- - pRects points to an array of VkClearRect
-- structures defining regions within each selected attachment to
-- clear.
--
--
-- Description
--
-- vkCmdClearAttachments can clear multiple regions of
-- each attachment used in the current subpass of a render pass instance.
-- This command must be called only inside a render pass instance,
-- and implicitly selects the images to clear based on the current
-- framebuffer attachments and the command parameters.
--
-- Valid Usage
--
--
-- - If the aspectMask member of any element of
-- pAttachments contains VK_IMAGE_ASPECT_COLOR_BIT, the
-- colorAttachment member of that element must refer to a
-- valid color attachment in the current subpass
--
--
--
-- - The rectangular region specified by each element of
-- pRects must be contained within the render area of the
-- current render pass instance
-- - The layers specified by each element of pRects
-- must be contained within every attachment that
-- pAttachments refers to
-- - If the render pass instance this is recorded in uses multiview,
-- then baseArrayLayer must be zero and
-- layerCount must be one.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pAttachments must be a valid pointer to an array
-- of attachmentCount valid VkClearAttachment
-- structures
-- - pRects must be a valid pointer to an array of
-- rectCount VkClearRect structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - attachmentCount must be greater than
-- 0
-- - rectCount must be greater than 0
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkClearAttachment, VkClearRect, VkCommandBuffer
vkCmdClearAttachments :: ("commandBuffer" ::: VkCommandBuffer) -> ("attachmentCount" ::: Word32) -> ("pAttachments" ::: Ptr VkClearAttachment) -> ("rectCount" ::: Word32) -> ("pRects" ::: Ptr VkClearRect) -> IO ()
-- | vkCmdResolveImage - Resolve regions of an image
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - srcImage is the source image.
-- - srcImageLayout is the layout of the source image
-- subresources for the resolve.
-- - dstImage is the destination image.
-- - dstImageLayout is the layout of the destination image
-- subresources for the resolve.
-- - regionCount is the number of regions to resolve.
-- - pRegions is a pointer to an array of
-- VkImageResolve structures specifying the regions to
-- resolve.
--
--
-- Description
--
-- During the resolve the samples corresponding to each pixel location in
-- the source are converted to a single sample before being written to
-- the destination. If the source formats are floating-point or
-- normalized types, the sample values for each pixel are resolved in an
-- implementation-dependent manner. If the source formats are integer
-- types, a single sample’s value is selected for each pixel.
--
-- srcOffset and dstOffset select the initial
-- x, y, and z offsets in texels of the
-- sub-regions of the source and destination image data. extent
-- is the size in texels of the source image to resolve in
-- width, height and depth.
--
-- Resolves are done layer by layer starting with baseArrayLayer
-- member of srcSubresource for the source and
-- dstSubresource for the destination. layerCount
-- layers are resolved to the destination image.
--
-- Valid Usage
--
--
-- - The source region specified by each element of pRegions
-- must be a region that is contained within
-- srcImage
--
--
--
-- - The destination region specified by each element of
-- pRegions must be a region that is contained within
-- dstImage
-- - The union of all source regions, and the union of all destination
-- regions, specified by the elements of pRegions, must
-- not overlap in memory
-- - If srcImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - srcImage must have a sample count equal to any
-- valid sample count value other than
-- VK_SAMPLE_COUNT_1_BIT
-- - If dstImage is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - dstImage must have a sample count equal to
-- VK_SAMPLE_COUNT_1_BIT
-- - srcImageLayout must specify the layout of the
-- image subresources of srcImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - srcImageLayout must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - dstImageLayout must specify the layout of the
-- image subresources of dstImage specified in pRegions
-- at the time this command is executed on a VkDevice
-- - dstImageLayout must be
-- VK_IMAGE_LAYOUT_SHARED_PRESENT_KHR,
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL or
-- VK_IMAGE_LAYOUT_GENERAL
-- - If dstImage was created with tiling equal to
-- VK_IMAGE_TILING_LINEAR, dstImage must have
-- been created with a format that supports being a color
-- attachment, as specified by the
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT flag in
-- VkFormatProperties::linearTilingFeatures returned by
-- vkGetPhysicalDeviceFormatProperties
-- - If dstImage was created with tiling equal to
-- VK_IMAGE_TILING_OPTIMAL, dstImage must have
-- been created with a format that supports being a color
-- attachment, as specified by the
-- VK_FORMAT_FEATURE_COLOR_ATTACHMENT_BIT flag in
-- VkFormatProperties::optimalTilingFeatures returned
-- by vkGetPhysicalDeviceFormatProperties
-- - srcImage and dstImage must have been
-- created with the same image format
-- - The srcSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when srcImage was
-- created
-- - The dstSubresource.mipLevel member of each element of
-- pRegions must be less than the mipLevels
-- specified in VkImageCreateInfo when dstImage was
-- created
-- - The srcSubresource.baseArrayLayer +
-- srcSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- srcImage was created
-- - The dstSubresource.baseArrayLayer +
-- dstSubresource.layerCount of each element of
-- pRegions must be less than or equal to the
-- arrayLayers specified in VkImageCreateInfo when
-- dstImage was created
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcImage must be a valid VkImage
-- handle
-- - srcImageLayout must be a valid
-- VkImageLayout value
-- - dstImage must be a valid VkImage
-- handle
-- - dstImageLayout must be a valid
-- VkImageLayout value
-- - pRegions must be a valid pointer to an array of
-- regionCount valid VkImageResolve structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called outside of a render pass
-- instance
-- - regionCount must be greater than 0
-- - Each of commandBuffer, dstImage, and
-- srcImage must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Transfer |
-- | Secondary | | | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkImage, VkImageLayout,
-- VkImageResolve
vkCmdResolveImage :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcImage" ::: VkImage) -> ("srcImageLayout" ::: VkImageLayout) -> ("dstImage" ::: VkImage) -> ("dstImageLayout" ::: VkImageLayout) -> ("regionCount" ::: Word32) -> ("pRegions" ::: Ptr VkImageResolve) -> IO ()
-- | vkCmdSetEvent - Set an event object to signaled state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - event is the event that will be signaled.
-- - stageMask specifies the source stage mask used to
-- determine when the event is signaled.
--
--
-- Description
--
-- When vkCmdSetEvent is submitted to a queue, it defines an
-- execution dependency on commands that were submitted before it, and
-- defines an event signal operation which sets the event to the signaled
-- state.
--
-- The first synchronization scope includes all commands that
-- occur earlier in submission order. The synchronization scope is
-- limited to operations on the pipeline stages determined by the
-- source stage mask specified by stageMask.
--
-- The second synchronization scope includes only the event signal
-- operation.
--
-- If event is already in the signaled state when
-- vkCmdSetEvent is executed on the device, then
-- vkCmdSetEvent has no effect, no event signal operation occurs,
-- and no execution dependency is generated.
--
-- Valid Usage
--
--
-- - stageMask must not include
-- VK_PIPELINE_STAGE_HOST_BIT
--
--
--
-- - If the geometry shaders feature is not enabled,
-- stageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- stageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - commandBuffer’s current device mask must include
-- exactly one physical device.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - event must be a valid VkEvent handle
-- - stageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - stageMask must not be 0
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - Both of commandBuffer, and event must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkEvent, VkPipelineStageFlags
vkCmdSetEvent :: ("commandBuffer" ::: VkCommandBuffer) -> ("event" ::: VkEvent) -> ("stageMask" ::: VkPipelineStageFlags) -> IO ()
-- | vkCmdResetEvent - Reset an event object to non-signaled state
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
--
-- Description
--
-- When vkCmdResetEvent is submitted to a queue, it defines an
-- execution dependency on commands that were submitted before it, and
-- defines an event unsignal operation which resets the event to the
-- unsignaled state.
--
-- The first synchronization scope includes all commands that
-- occur earlier in submission order. The synchronization scope is
-- limited to operations on the pipeline stages determined by the
-- source stage mask specified by stageMask.
--
-- The second synchronization scope includes only the event
-- unsignal operation.
--
-- If event is already in the unsignaled state when
-- vkCmdResetEvent is executed on the device, then
-- vkCmdResetEvent has no effect, no event unsignal operation
-- occurs, and no execution dependency is generated.
--
-- Valid Usage
--
--
-- - stageMask must not include
-- VK_PIPELINE_STAGE_HOST_BIT
--
--
--
-- - If the geometry shaders feature is not enabled,
-- stageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- stageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - When this command executes, event must not be
-- waited on by a vkCmdWaitEvents command that is currently
-- executing
-- - commandBuffer’s current device mask must include
-- exactly one physical device.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - event must be a valid VkEvent handle
-- - stageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - stageMask must not be 0
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - Both of commandBuffer, and event must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkEvent, VkPipelineStageFlags
vkCmdResetEvent :: ("commandBuffer" ::: VkCommandBuffer) -> ("event" ::: VkEvent) -> ("stageMask" ::: VkPipelineStageFlags) -> IO ()
-- | vkCmdWaitEvents - Wait for one or more events and insert a set of
-- memory
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
-- - eventCount is the length of the pEvents
-- array.
-- - pEvents is an array of event object handles to wait
-- on.
-- - srcStageMask is a bitmask of
-- VkPipelineStageFlagBits specifying the source stage
-- mask.
-- - dstStageMask is a bitmask of
-- VkPipelineStageFlagBits specifying the destination stage
-- mask.
-- - memoryBarrierCount is the length of the
-- pMemoryBarriers array.
-- - pMemoryBarriers is a pointer to an array of
-- VkMemoryBarrier structures.
-- - bufferMemoryBarrierCount is the length of the
-- pBufferMemoryBarriers array.
-- - pBufferMemoryBarriers is a pointer to an array of
-- VkBufferMemoryBarrier structures.
-- - imageMemoryBarrierCount is the length of the
-- pImageMemoryBarriers array.
-- - pImageMemoryBarriers is a pointer to an array of
-- VkImageMemoryBarrier structures.
--
--
-- Description
--
-- When vkCmdWaitEvents is submitted to a queue, it defines a
-- memory dependency between prior event signal operations on the same
-- queue or the host, and subsequent commands. vkCmdWaitEvents
-- must not be used to wait on event signal operations occuring on
-- other queues.
--
-- The first synchronization scope only includes event signal operations
-- that operate on members of pEvents, and the operations that
-- happened-before the event signal operations. Event signal operations
-- performed by vkCmdSetEvent that occur earlier in submission
-- order are included in the first synchronization scope, if the
-- logically latest pipeline stage in their stageMask
-- parameter is logically earlier than or equal to the
-- logically latest pipeline stage in srcStageMask. Event
-- signal operations performed by vkSetEvent are only included in
-- the first synchronization scope if VK_PIPELINE_STAGE_HOST_BIT
-- is included in srcStageMask.
--
-- The second synchronization scope includes all commands that
-- occur later in submission order. The second synchronization
-- scope is limited to operations on the pipeline stages determined by
-- the destination stage mask specified by dstStageMask.
--
-- The first access scope is limited to access in the pipeline
-- stages determined by the source stage mask specified by
-- srcStageMask. Within that, the first access scope only
-- includes the first access scopes defined by elements of the
-- pMemoryBarriers, pBufferMemoryBarriers and
-- pImageMemoryBarriers arrays, which each define a set of
-- memory barriers. If no memory barriers are specified, then the
-- first access scope includes no accesses.
--
-- The second access scope is limited to access in the pipeline
-- stages determined by the destination stage mask specified by
-- dstStageMask. Within that, the second access scope only
-- includes the second access scopes defined by elements of the
-- pMemoryBarriers, pBufferMemoryBarriers and
-- pImageMemoryBarriers arrays, which each define a set of
-- memory barriers. If no memory barriers are specified, then the
-- second access scope includes no accesses.
--
-- Note
--
-- vkCmdWaitEvents is used with vkCmdSetEvent to define a
-- memory dependency between two sets of action commands, roughly in the
-- same way as pipeline barriers, but split into two commands such that
-- work between the two may execute unhindered.
--
-- Note
--
-- Applications should be careful to avoid race conditions when
-- using events. There is no direct ordering guarantee between a
-- vkCmdResetEvent command and a vkCmdWaitEvents command
-- submitted after it, so some other execution dependency must be
-- included between these commands (e.g. a semaphore).
--
-- Valid Usage
--
--
-- - srcStageMask must be the bitwise OR of the
-- stageMask parameter used in previous calls to
-- vkCmdSetEvent with any of the members of pEvents and
-- VK_PIPELINE_STAGE_HOST_BIT if any of the members of
-- pEvents was set using vkSetEvent
--
--
--
-- - If the geometry shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the geometry shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - If pEvents includes one or more events that will be
-- signaled by vkSetEvent after commandBuffer has been
-- submitted to a queue, then vkCmdWaitEvents must not be
-- called inside a render pass instance
-- - Any pipeline stage included in srcStageMask or
-- dstStageMask must be supported by the capabilities of
-- the queue family specified by the queueFamilyIndex member of
-- the VkCommandPoolCreateInfo structure that was used to create
-- the VkCommandPool that commandBuffer was allocated
-- from, as specified in the table of supported pipeline
-- stages.
-- - Each element of pMemoryBarriers,
-- pBufferMemoryBarriers or pImageMemoryBarriers
-- must not have any access flag included in its
-- srcAccessMask member if that bit is not supported by any of
-- the pipeline stages in srcStageMask, as specified in the
-- table of supported access types.
-- - Each element of pMemoryBarriers,
-- pBufferMemoryBarriers or pImageMemoryBarriers
-- must not have any access flag included in its
-- dstAccessMask member if that bit is not supported by any of
-- the pipeline stages in dstStageMask, as specified in the
-- table of supported access types.
-- - commandBuffer’s current device mask must include
-- exactly one physical device.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pEvents must be a valid pointer to an array of
-- eventCount valid VkEvent handles
-- - srcStageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - srcStageMask must not be 0
-- - dstStageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - dstStageMask must not be 0
-- - If memoryBarrierCount is not 0,
-- pMemoryBarriers must be a valid pointer to an array of
-- memoryBarrierCount valid VkMemoryBarrier
-- structures
-- - If bufferMemoryBarrierCount is not 0,
-- pBufferMemoryBarriers must be a valid pointer to an
-- array of bufferMemoryBarrierCount valid
-- VkBufferMemoryBarrier structures
-- - If imageMemoryBarrierCount is not 0,
-- pImageMemoryBarriers must be a valid pointer to an
-- array of imageMemoryBarrierCount valid
-- VkImageMemoryBarrier structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - eventCount must be greater than 0
-- - Both of commandBuffer, and the elements of
-- pEvents must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBufferMemoryBarrier, VkCommandBuffer, VkEvent,
-- VkImageMemoryBarrier, VkMemoryBarrier,
-- VkPipelineStageFlags
vkCmdWaitEvents :: ("commandBuffer" ::: VkCommandBuffer) -> ("eventCount" ::: Word32) -> ("pEvents" ::: Ptr VkEvent) -> ("srcStageMask" ::: VkPipelineStageFlags) -> ("dstStageMask" ::: VkPipelineStageFlags) -> ("memoryBarrierCount" ::: Word32) -> ("pMemoryBarriers" ::: Ptr VkMemoryBarrier) -> ("bufferMemoryBarrierCount" ::: Word32) -> ("pBufferMemoryBarriers" ::: Ptr VkBufferMemoryBarrier) -> ("imageMemoryBarrierCount" ::: Word32) -> ("pImageMemoryBarriers" ::: Ptr VkImageMemoryBarrier) -> IO ()
-- | vkCmdPipelineBarrier - Insert a memory dependency
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command is recorded.
--
--
--
--
-- Description
--
-- When vkCmdPipelineBarrier is submitted to a queue, it defines a
-- memory dependency between commands that were submitted before it, and
-- those submitted after it.
--
-- If vkCmdPipelineBarrier was recorded outside a render pass
-- instance, the first synchronization scope includes all commands
-- that occur earlier in submission order. If
-- vkCmdPipelineBarrier was recorded inside a render pass
-- instance, the first synchronization scope includes only commands that
-- occur earlier in submission order within the same subpass. In
-- either case, the first synchronization scope is limited to operations
-- on the pipeline stages determined by the source stage mask
-- specified by srcStageMask.
--
-- If vkCmdPipelineBarrier was recorded outside a render pass
-- instance, the second synchronization scope includes all
-- commands that occur later in submission order. If
-- vkCmdPipelineBarrier was recorded inside a render pass
-- instance, the second synchronization scope includes only commands that
-- occur later in submission order within the same subpass. In
-- either case, the second synchronization scope is limited to operations
-- on the pipeline stages determined by the destination stage mask
-- specified by dstStageMask.
--
-- The first access scope is limited to access in the pipeline
-- stages determined by the source stage mask specified by
-- srcStageMask. Within that, the first access scope only
-- includes the first access scopes defined by elements of the
-- pMemoryBarriers, pBufferMemoryBarriers and
-- pImageMemoryBarriers arrays, which each define a set of
-- memory barriers. If no memory barriers are specified, then the
-- first access scope includes no accesses.
--
-- The second access scope is limited to access in the pipeline
-- stages determined by the destination stage mask specified by
-- dstStageMask. Within that, the second access scope only
-- includes the second access scopes defined by elements of the
-- pMemoryBarriers, pBufferMemoryBarriers and
-- pImageMemoryBarriers arrays, which each define a set of
-- memory barriers. If no memory barriers are specified, then the
-- second access scope includes no accesses.
--
-- If dependencyFlags includes
-- VK_DEPENDENCY_BY_REGION_BIT, then any dependency between
-- framebuffer-space pipeline stages is framebuffer-local -
-- otherwise it is framebuffer-global.
--
-- Valid Usage
--
--
-- - If the geometry shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
--
--
--
-- - If the geometry shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_GEOMETRY_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- srcStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - If the tessellation shaders feature is not enabled,
-- dstStageMask must not contain
-- VK_PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT or
-- VK_PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the render pass must have been created with a
-- VkSubpassDependency instance in pDependencies that
-- expresses a dependency from the current subpass to itself.
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, srcStageMask must contain a subset of the
-- bit values in the srcStageMask member of that instance of
-- VkSubpassDependency
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, dstStageMask must contain a subset of the
-- bit values in the dstStageMask member of that instance of
-- VkSubpassDependency
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the srcAccessMask of any element of
-- pMemoryBarriers or pImageMemoryBarriers must
-- contain a subset of the bit values the srcAccessMask member
-- of that instance of VkSubpassDependency
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the dstAccessMask of any element of
-- pMemoryBarriers or pImageMemoryBarriers must
-- contain a subset of the bit values the dstAccessMask member
-- of that instance of VkSubpassDependency
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, dependencyFlags must be equal to the
-- dependencyFlags member of that instance of
-- VkSubpassDependency
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, bufferMemoryBarrierCount must be
-- 0
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the image member of any element of
-- pImageMemoryBarriers must be equal to one of the
-- elements of pAttachments that the current
-- framebuffer was created with, that is also referred to by one
-- of the elements of the pColorAttachments,
-- pResolveAttachments or pDepthStencilAttachment
-- members of the VkSubpassDescription instance that the current
-- subpass was created with
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the oldLayout and newLayout members of any
-- element of pImageMemoryBarriers must be equal to the
-- layout member of an element of the
-- pColorAttachments, pResolveAttachments or
-- pDepthStencilAttachment members of the
-- VkSubpassDescription instance that the current subpass was
-- created with, that refers to the same image
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the oldLayout and newLayout members of an
-- element of pImageMemoryBarriers must be equal
-- - If vkCmdPipelineBarrier is called within a render pass
-- instance, the srcQueueFamilyIndex and
-- dstQueueFamilyIndex members of any element of
-- pImageMemoryBarriers must be
-- VK_QUEUE_FAMILY_IGNORED
-- - Any pipeline stage included in srcStageMask or
-- dstStageMask must be supported by the capabilities of
-- the queue family specified by the queueFamilyIndex member of
-- the VkCommandPoolCreateInfo structure that was used to create
-- the VkCommandPool that commandBuffer was allocated
-- from, as specified in the table of supported pipeline
-- stages.
-- - Each element of pMemoryBarriers,
-- pBufferMemoryBarriers and pImageMemoryBarriers
-- must not have any access flag included in its
-- srcAccessMask member if that bit is not supported by any of
-- the pipeline stages in srcStageMask, as specified in the
-- table of supported access types.
-- - Each element of pMemoryBarriers,
-- pBufferMemoryBarriers and pImageMemoryBarriers
-- must not have any access flag included in its
-- dstAccessMask member if that bit is not supported by any of
-- the pipeline stages in dstStageMask, as specified in the
-- table of supported access types.
-- - If vkCmdPipelineBarrier is called outside of a render
-- pass instance, dependencyFlags must not include
-- VK_DEPENDENCY_VIEW_LOCAL_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - srcStageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - srcStageMask must not be 0
-- - dstStageMask must be a valid combination of
-- VkPipelineStageFlagBits values
-- - dstStageMask must not be 0
-- - dependencyFlags must be a valid combination of
-- VkDependencyFlagBits values
-- - If memoryBarrierCount is not 0,
-- pMemoryBarriers must be a valid pointer to an array of
-- memoryBarrierCount valid VkMemoryBarrier
-- structures
-- - If bufferMemoryBarrierCount is not 0,
-- pBufferMemoryBarriers must be a valid pointer to an
-- array of bufferMemoryBarrierCount valid
-- VkBufferMemoryBarrier structures
-- - If imageMemoryBarrierCount is not 0,
-- pImageMemoryBarriers must be a valid pointer to an
-- array of imageMemoryBarrierCount valid
-- VkImageMemoryBarrier structures
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Transfer | |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBufferMemoryBarrier, VkCommandBuffer,
-- VkDependencyFlags, VkImageMemoryBarrier,
-- VkMemoryBarrier, VkPipelineStageFlags
vkCmdPipelineBarrier :: ("commandBuffer" ::: VkCommandBuffer) -> ("srcStageMask" ::: VkPipelineStageFlags) -> ("dstStageMask" ::: VkPipelineStageFlags) -> ("dependencyFlags" ::: VkDependencyFlags) -> ("memoryBarrierCount" ::: Word32) -> ("pMemoryBarriers" ::: Ptr VkMemoryBarrier) -> ("bufferMemoryBarrierCount" ::: Word32) -> ("pBufferMemoryBarriers" ::: Ptr VkBufferMemoryBarrier) -> ("imageMemoryBarrierCount" ::: Word32) -> ("pImageMemoryBarriers" ::: Ptr VkImageMemoryBarrier) -> IO ()
-- | vkCmdBeginQuery - Begin a query
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which this
-- command will be recorded.
--
--
--
-- - queryPool is the query pool that will manage the results
-- of the query.
-- - query is the query index within the query pool that will
-- contain the results.
-- - flags is a bitmask of VkQueryControlFlagBits
-- specifying constraints on the types of queries that can be
-- performed.
--
--
-- Description
--
-- If the queryType of the pool is
-- VK_QUERY_TYPE_OCCLUSION and flags contains
-- VK_QUERY_CONTROL_PRECISE_BIT, an implementation must
-- return a result that matches the actual number of samples passed. This
-- is described in more detail in Occlusion Queries.
--
-- After beginning a query, that query is considered active within
-- the command buffer it was called in until that same query is ended.
-- Queries active in a primary command buffer when secondary command
-- buffers are executed are considered active for those secondary command
-- buffers.
--
-- Valid Usage
--
--
-- - queryPool must have been created with a
-- queryType that differs from that of any queries that are
-- active within commandBuffer
--
--
--
-- - All queries used by the command must be unavailable
-- - If the precise occlusion queries feature is not enabled, or
-- the queryType used to create queryPool was not
-- VK_QUERY_TYPE_OCCLUSION, flags must not
-- contain VK_QUERY_CONTROL_PRECISE_BIT
-- - query must be less than the number of queries in
-- queryPool
-- - If the queryType used to create queryPool was
-- VK_QUERY_TYPE_OCCLUSION, the VkCommandPool that
-- commandBuffer was allocated from must support graphics
-- operations
-- - If the queryType used to create queryPool was
-- VK_QUERY_TYPE_PIPELINE_STATISTICS and any of the
-- pipelineStatistics indicate graphics operations, the
-- VkCommandPool that commandBuffer was allocated from
-- must support graphics operations
-- - If the queryType used to create queryPool was
-- VK_QUERY_TYPE_PIPELINE_STATISTICS and any of the
-- pipelineStatistics indicate compute operations, the
-- VkCommandPool that commandBuffer was allocated from
-- must support compute operations
-- - If vkCmdBeginQuery is called within a render pass
-- instance, the sum of query and the number of bits set in the
-- current subpass’s view mask must be less than or equal to the
-- number of queries in queryPool
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - queryPool must be a valid VkQueryPool
-- handle
-- - flags must be a valid combination of
-- VkQueryControlFlagBits values
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - Both of commandBuffer, and queryPool must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkQueryControlFlags, VkQueryPool
vkCmdBeginQuery :: ("commandBuffer" ::: VkCommandBuffer) -> ("queryPool" ::: VkQueryPool) -> ("query" ::: Word32) -> ("flags" ::: VkQueryControlFlags) -> IO ()
-- | vkCmdEndQuery - Ends a query
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which this
-- command will be recorded.
--
--
--
-- - queryPool is the query pool that is managing the results
-- of the query.
-- - query is the query index within the query pool where the
-- result is stored.
--
--
-- Description
--
-- As queries operate asynchronously, ending a query does not immediately
-- set the query’s status to available. A query is considered
-- finished when the final results of the query are ready to be
-- retrieved by vkGetQueryPoolResults and
-- vkCmdCopyQueryPoolResults, and this is when the query’s status
-- is set to available.
--
-- Once a query is ended the query must finish in finite time,
-- unless the state of the query is changed using other commands, e.g. by
-- issuing a reset of the query.
--
-- Valid Usage
--
--
-- - All queries used by the command must be active
--
--
--
-- - query must be less than the number of queries in
-- queryPool
-- - If vkCmdEndQuery is called within a render pass instance,
-- the sum of query and the number of bits set in the current
-- subpass’s view mask must be less than or equal to the number of
-- queries in queryPool
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - queryPool must be a valid VkQueryPool
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - Both of commandBuffer, and queryPool must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkQueryPool
vkCmdEndQuery :: ("commandBuffer" ::: VkCommandBuffer) -> ("queryPool" ::: VkQueryPool) -> ("query" ::: Word32) -> IO ()
-- | vkCmdResetQueryPool - Reset queries in a query pool
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which this
-- command will be recorded.
--
--
--
-- - queryPool is the handle of the query pool managing the
-- queries being reset.
-- - firstQuery is the initial query index to reset.
-- - queryCount is the number of queries to reset.
--
--
-- Description
--
-- When executed on a queue, this command sets the status of query
-- indices [firstQuery, firstQuery +
-- queryCount - 1] to unavailable.
--
-- Valid Usage
--
--
-- - firstQuery must be less than the number of queries
-- in queryPool
--
--
--
-- - The sum of firstQuery and queryCount must
-- be less than or equal to the number of queries in
-- queryPool
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - queryPool must be a valid VkQueryPool
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - Both of commandBuffer, and queryPool must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkQueryPool
vkCmdResetQueryPool :: ("commandBuffer" ::: VkCommandBuffer) -> ("queryPool" ::: VkQueryPool) -> ("firstQuery" ::: Word32) -> ("queryCount" ::: Word32) -> IO ()
-- | vkCmdWriteTimestamp - Write a device timestamp into a query object
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which the
-- command will be recorded.
--
--
--
-- - pipelineStage is one of the
-- VkPipelineStageFlagBits, specifying a stage of the
-- pipeline.
-- - queryPool is the query pool that will manage the
-- timestamp.
-- - query is the query within the query pool that will
-- contain the timestamp.
--
--
-- Description
--
-- vkCmdWriteTimestamp latches the value of the timer when all
-- previous commands have completed executing as far as the specified
-- pipeline stage, and writes the timestamp value to memory. When the
-- timestamp value is written, the availability status of the query is
-- set to available.
--
-- Note
--
-- If an implementation is unable to detect completion and latch the
-- timer at any specific stage of the pipeline, it may instead do
-- so at any logically later stage.
--
-- vkCmdCopyQueryPoolResults can then be called to copy the
-- timestamp value from the query pool into buffer memory, with ordering
-- and synchronization behavior equivalent to how other queries operate.
-- Timestamp values can also be retrieved from the query pool
-- using vkGetQueryPoolResults. As with other queries, the query
-- must be reset using vkCmdResetQueryPool before
-- requesting the timestamp value be written to it.
--
-- While vkCmdWriteTimestamp can be called inside or
-- outside of a render pass instance, vkCmdCopyQueryPoolResults
-- must only be called outside of a render pass instance.
--
-- Timestamps may only be meaningfully compared if they are
-- written by commands submitted to the same queue.
--
-- Note
--
-- An example of such a comparison is determining the execution time of a
-- sequence of commands.
--
-- If vkCmdWriteTimestamp is called while executing a render
-- pass instance that has multiview enabled, the timestamp uses N
-- consecutive query indices in the query pool (starting at
-- query) where N is the number of bits set in the view mask of
-- the subpass the command is executed in. The resulting query values are
-- determined by an implementation-dependent choice of one of the
-- following behaviors:
--
--
-- - The first query is a timestamp value and (if more than one bit is
-- set in the view mask) zero is written to the remaining queries. If two
-- timestamps are written in the same subpass, the sum of the execution
-- time of all views between those commands is the difference between the
-- first query written by each command.
-- - All N queries are timestamp values. If two timestamps are written
-- in the same subpass, the sum of the execution time of all views
-- between those commands is the sum of the difference between
-- corresponding queries written by each command. The difference between
-- corresponding queries may be the execution time of a single
-- view.
--
--
-- In either case, the application can sum the differences between
-- all N queries to determine the total execution time.
--
-- Valid Usage
--
--
-- - queryPool must have been created with a
-- queryType of VK_QUERY_TYPE_TIMESTAMP
--
--
--
-- - The query identified by queryPool and query
-- must be unavailable
-- - The command pool’s queue family must support a non-zero
-- timestampValidBits
-- - All queries used by the command must be unavailable
-- - If vkCmdWriteTimestamp is called within a render pass
-- instance, the sum of query and the number of bits set in the
-- current subpass’s view mask must be less than or equal to the
-- number of queries in queryPool
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pipelineStage must be a valid
-- VkPipelineStageFlagBits value
-- - queryPool must be a valid VkQueryPool
-- handle
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - Both of commandBuffer, and queryPool must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Transfer | Transfer |
-- | Secondary | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkPipelineStageFlagBits,
-- VkQueryPool
vkCmdWriteTimestamp :: ("commandBuffer" ::: VkCommandBuffer) -> ("pipelineStage" ::: VkPipelineStageFlagBits) -> ("queryPool" ::: VkQueryPool) -> ("query" ::: Word32) -> IO ()
-- | vkCmdCopyQueryPoolResults - Copy the results of queries in a query
-- pool to a buffer object
--
-- Parameters
--
--
-- - commandBuffer is the command buffer into which this
-- command will be recorded.
--
--
--
-- - queryPool is the query pool managing the queries
-- containing the desired results.
-- - firstQuery is the initial query index.
-- - queryCount is the number of queries. firstQuery
-- and queryCount together define a range of queries.
-- - dstBuffer is a VkBuffer object that will receive
-- the results of the copy command.
-- - dstOffset is an offset into dstBuffer.
-- - stride is the stride in bytes between results for
-- individual queries within dstBuffer. The required size of the
-- backing memory for dstBuffer is determined as described above
-- for vkGetQueryPoolResults.
-- - flags is a bitmask of VkQueryResultFlagBits
-- specifying how and when results are returned.
--
--
-- Description
--
-- vkCmdCopyQueryPoolResults is guaranteed to see the effect of
-- previous uses of vkCmdResetQueryPool in the same queue,
-- without any additional synchronization. Thus, the results will always
-- reflect the most recent use of the query.
--
-- flags has the same possible values described above for the
-- flags parameter of vkGetQueryPoolResults, but the
-- different style of execution causes some subtle behavioral
-- differences. Because vkCmdCopyQueryPoolResults executes in
-- order with respect to other query commands, there is less ambiguity
-- about which use of a query is being requested.
--
-- If no bits are set in flags, results for all requested
-- queries in the available state are written as 32-bit unsigned integer
-- values, and nothing is written for queries in the unavailable state.
--
-- If VK_QUERY_RESULT_64_BIT is set, the results are written as
-- an array of 64-bit unsigned integer values as described for
-- vkGetQueryPoolResults.
--
-- If VK_QUERY_RESULT_WAIT_BIT is set, the implementation will
-- wait for each query’s status to be in the available state before
-- retrieving the numerical results for that query. This is guaranteed to
-- reflect the most recent use of the query on the same queue, assuming
-- that the query is not being simultaneously used by other queues. If
-- the query does not become available in a finite amount of time (e.g.
-- due to not issuing a query since the last reset), a
-- VK_ERROR_DEVICE_LOST error may occur.
--
-- Similarly, if VK_QUERY_RESULT_WITH_AVAILABILITY_BIT is set
-- and VK_QUERY_RESULT_WAIT_BIT is not set, the availability is
-- guaranteed to reflect the most recent use of the query on the same
-- queue, assuming that the query is not being simultaneously used by
-- other queues. As with vkGetQueryPoolResults, implementations
-- must guarantee that if they return a non-zero availability
-- value, then the numerical results are valid.
--
-- If VK_QUERY_RESULT_PARTIAL_BIT is set,
-- VK_QUERY_RESULT_WAIT_BIT is not set, and the query’s status
-- is unavailable, an intermediate result value between zero and the
-- final result value is written for that query.
--
-- VK_QUERY_RESULT_PARTIAL_BIT must not be used if the
-- pool’s queryType is VK_QUERY_TYPE_TIMESTAMP.
--
-- vkCmdCopyQueryPoolResults is considered to be a transfer
-- operation, and its writes to buffer memory must be synchronized
-- using VK_PIPELINE_STAGE_TRANSFER_BIT and
-- VK_ACCESS_TRANSFER_WRITE_BIT before using the results.
--
-- Valid Usage
--
--
-- - dstOffset must be less than the size of
-- dstBuffer
--
--
--
-- - firstQuery must be less than the number of queries
-- in queryPool
-- - The sum of firstQuery and queryCount must
-- be less than or equal to the number of queries in
-- queryPool
-- - If VK_QUERY_RESULT_64_BIT is not set in flags
-- then dstOffset and stride must be multiples
-- of 4
-- - If VK_QUERY_RESULT_64_BIT is set in flags then
-- dstOffset and stride must be multiples of
-- 8
-- - dstBuffer must have enough storage, from
-- dstOffset, to contain the result of each query, as described
-- here
-- - dstBuffer must have been created with
-- VK_BUFFER_USAGE_TRANSFER_DST_BIT usage flag
-- - If dstBuffer is non-sparse then it must be bound
-- completely and contiguously to a single VkDeviceMemory
-- object
-- - If the queryType used to create queryPool was
-- VK_QUERY_TYPE_TIMESTAMP, flags must not
-- contain VK_QUERY_RESULT_PARTIAL_BIT
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - queryPool must be a valid VkQueryPool
-- handle
-- - dstBuffer must be a valid VkBuffer
-- handle
-- - flags must be a valid combination of
-- VkQueryResultFlagBits values
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called outside of a render pass
-- instance
-- - Each of commandBuffer, dstBuffer, and
-- queryPool must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Transfer |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize,
-- VkQueryPool, VkQueryResultFlags
vkCmdCopyQueryPoolResults :: ("commandBuffer" ::: VkCommandBuffer) -> ("queryPool" ::: VkQueryPool) -> ("firstQuery" ::: Word32) -> ("queryCount" ::: Word32) -> ("dstBuffer" ::: VkBuffer) -> ("dstOffset" ::: VkDeviceSize) -> ("stride" ::: VkDeviceSize) -> ("flags" ::: VkQueryResultFlags) -> IO ()
-- | vkCmdPushConstants - Update the values of push constants
--
-- Parameters
--
--
-- - commandBuffer is the command buffer in which the push
-- constant update will be recorded.
--
--
--
-- - layout is the pipeline layout used to program the push
-- constant updates.
-- - stageFlags is a bitmask of VkShaderStageFlagBits
-- specifying the shader stages that will use the push constants in the
-- updated range.
-- - offset is the start offset of the push constant range to
-- update, in units of bytes.
-- - size is the size of the push constant range to update, in
-- units of bytes.
-- - pValues is an array of size bytes containing the
-- new push constant values.
--
--
-- Description
--
-- Valid Usage
--
--
-- - For each byte in the range specified by offset and
-- size and for each shader stage in stageFlags, there
-- must be a push constant range in layout that includes
-- that byte and that stage
--
--
--
-- - For each byte in the range specified by offset and
-- size and for each push constant range that overlaps that
-- byte, stageFlags must include all stages in that push
-- constant range’s VkPushConstantRange::stageFlags
-- - offset must be a multiple of 4
-- - size must be a multiple of 4
-- - offset must be less than
-- VkPhysicalDeviceLimits::maxPushConstantsSize
-- - size must be less than or equal to
-- VkPhysicalDeviceLimits::maxPushConstantsSize minus
-- offset
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - layout must be a valid VkPipelineLayout
-- handle
-- - stageFlags must be a valid combination of
-- VkShaderStageFlagBits values
-- - stageFlags must not be 0
-- - pValues must be a valid pointer to an array of
-- size bytes
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - size must be greater than 0
-- - Both of commandBuffer, and layout must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkPipelineLayout,
-- VkShaderStageFlags
vkCmdPushConstants :: ("commandBuffer" ::: VkCommandBuffer) -> ("layout" ::: VkPipelineLayout) -> ("stageFlags" ::: VkShaderStageFlags) -> ("offset" ::: Word32) -> ("size" ::: Word32) -> ("pValues" ::: Ptr ()) -> IO ()
-- | vkCmdBeginRenderPass - Begin a new render pass
--
-- Parameters
--
--
-- - commandBuffer is the command buffer in which to record
-- the command.
--
--
--
-- - pRenderPassBegin is a pointer to a
-- VkRenderPassBeginInfo structure (defined below) which specifies
-- the render pass to begin an instance of, and the framebuffer the
-- instance uses.
-- - contents is a VkSubpassContents value specifying
-- how the commands in the first subpass will be provided.
--
--
-- Description
--
-- After beginning a render pass instance, the command buffer is ready to
-- record the commands for the first subpass of that render pass.
--
-- Valid Usage
--
--
-- - If any of the initialLayout or finalLayout
-- member of the VkAttachmentDescription structures or the
-- layout member of the VkAttachmentReference
-- structures specified when creating the render pass specified in the
-- renderPass member of pRenderPassBegin is
-- VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL then the
-- corresponding attachment image subresource of the framebuffer
-- specified in the framebuffer member of
-- pRenderPassBegin must have been created with
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT set
--
--
--
-- - If any of the initialLayout or finalLayout
-- member of the VkAttachmentDescription structures or the
-- layout member of the VkAttachmentReference
-- structures specified when creating the render pass specified in the
-- renderPass member of pRenderPassBegin is
-- VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL,
-- VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL,
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL, or
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL then the
-- corresponding attachment image subresource of the framebuffer
-- specified in the framebuffer member of
-- pRenderPassBegin must have been created with
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT set
-- - If any of the initialLayout or finalLayout
-- member of the VkAttachmentDescription structures or the
-- layout member of the VkAttachmentReference
-- structures specified when creating the render pass specified in the
-- renderPass member of pRenderPassBegin is
-- VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL then the
-- corresponding attachment image subresource of the framebuffer
-- specified in the framebuffer member of
-- pRenderPassBegin must have been created with
-- VK_IMAGE_USAGE_SAMPLED_BIT or
-- VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT set
-- - If any of the initialLayout or finalLayout
-- member of the VkAttachmentDescription structures or the
-- layout member of the VkAttachmentReference
-- structures specified when creating the render pass specified in the
-- renderPass member of pRenderPassBegin is
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL then the corresponding
-- attachment image subresource of the framebuffer specified in the
-- framebuffer member of pRenderPassBegin must
-- have been created with VK_IMAGE_USAGE_TRANSFER_SRC_BIT
-- set
-- - If any of the initialLayout or finalLayout
-- member of the VkAttachmentDescription structures or the
-- layout member of the VkAttachmentReference
-- structures specified when creating the render pass specified in the
-- renderPass member of pRenderPassBegin is
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL then the corresponding
-- attachment image subresource of the framebuffer specified in the
-- framebuffer member of pRenderPassBegin must
-- have been created with VK_IMAGE_USAGE_TRANSFER_DST_BIT
-- set
-- - If any of the initialLayout members of the
-- VkAttachmentDescription structures specified when creating
-- the render pass specified in the renderPass member of
-- pRenderPassBegin is not VK_IMAGE_LAYOUT_UNDEFINED,
-- then each such initialLayout must be equal to the
-- current layout of the corresponding attachment image subresource of
-- the framebuffer specified in the framebuffer member of
-- pRenderPassBegin
-- - The srcStageMask and dstStageMask members of any
-- element of the pDependencies member of
-- VkRenderPassCreateInfo used to create renderPass
-- must be supported by the capabilities of the queue family
-- identified by the queueFamilyIndex member of the
-- VkCommandPoolCreateInfo used to create the command pool which
-- commandBuffer was allocated from.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pRenderPassBegin must be a valid pointer to a
-- valid VkRenderPassBeginInfo structure
-- - contents must be a valid VkSubpassContents
-- value
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called outside of a render pass
-- instance
-- - commandBuffer must be a primary
-- VkCommandBuffer
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Outside | Graphics | Graphics |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkRenderPassBeginInfo,
-- VkSubpassContents
vkCmdBeginRenderPass :: ("commandBuffer" ::: VkCommandBuffer) -> ("pRenderPassBegin" ::: Ptr VkRenderPassBeginInfo) -> ("contents" ::: VkSubpassContents) -> IO ()
-- | vkCmdNextSubpass - Transition to the next subpass of a render pass
--
-- Parameters
--
--
-- - commandBuffer is the command buffer in which to record
-- the command.
--
--
--
-- - contents specifies how the commands in the next subpass
-- will be provided, in the same fashion as the corresponding parameter
-- of vkCmdBeginRenderPass.
--
--
-- Description
--
-- The subpass index for a render pass begins at zero when
-- vkCmdBeginRenderPass is recorded, and increments each time
-- vkCmdNextSubpass is recorded.
--
-- Moving to the next subpass automatically performs any multisample
-- resolve operations in the subpass being ended. End-of-subpass
-- multisample resolves are treated as color attachment writes for the
-- purposes of synchronization. That is, they are considered to execute
-- in the VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT pipeline
-- stage and their writes are synchronized with
-- VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT. Synchronization between
-- rendering within a subpass and any resolve operations at the end of
-- the subpass occurs automatically, without need for explicit
-- dependencies or pipeline barriers. However, if the resolve attachment
-- is also used in a different subpass, an explicit dependency is needed.
--
-- After transitioning to the next subpass, the application can
-- record the commands for that subpass.
--
-- Valid Usage
--
--
-- - The current subpass index must be less than the number of
-- subpasses in the render pass minus one
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - contents must be a valid VkSubpassContents
-- value
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - commandBuffer must be a primary
-- VkCommandBuffer
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer, VkSubpassContents
vkCmdNextSubpass :: ("commandBuffer" ::: VkCommandBuffer) -> ("contents" ::: VkSubpassContents) -> IO ()
-- | vkCmdEndRenderPass - End the current render pass
--
-- Parameters
--
--
-- - commandBuffer is the command buffer in which to end the
-- current render pass instance.
--
--
-- Description
--
-- Ending a render pass instance performs any multisample resolve
-- operations on the final subpass.
--
-- Valid Usage
--
--
-- - The current subpass index must be equal to the number of
-- subpasses in the render pass minus one
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics operations
-- - This command must only be called inside of a render pass
-- instance
-- - commandBuffer must be a primary
-- VkCommandBuffer
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | Graphics |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdEndRenderPass :: ("commandBuffer" ::: VkCommandBuffer) -> IO ()
-- | vkCmdExecuteCommands - Execute a secondary command buffer from a
-- primary command buffer
--
-- Parameters
--
--
-- - commandBuffer is a handle to a primary command buffer
-- that the secondary command buffers are executed in.
--
--
--
-- - commandBufferCount is the length of the
-- pCommandBuffers array.
-- - pCommandBuffers is an array of secondary command buffer
-- handles, which are recorded to execute in the primary command buffer
-- in the order they are listed in the array.
--
--
-- Description
--
-- If any element of pCommandBuffers was not recorded with the
-- VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT flag, and it was
-- recorded into any other primary command buffer which is currently in
-- the executable or recording state, that primary command buffer
-- becomes invalid.
--
-- Valid Usage
--
--
-- - commandBuffer must have been allocated with a
-- level of VK_COMMAND_BUFFER_LEVEL_PRIMARY
--
--
--
-- - Each element of pCommandBuffers must have been
-- allocated with a level of
-- VK_COMMAND_BUFFER_LEVEL_SECONDARY
-- - Each element of pCommandBuffers must be in the
-- pending or executable state.
-- - If any element of pCommandBuffers was not recorded with
-- the VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT flag, and it
-- was recorded into any other primary command buffer, that primary
-- command buffer must not be in the pending state
-- - If any element of pCommandBuffers was not recorded with
-- the VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT flag, it
-- must not be in the pending state.
-- - If any element of pCommandBuffers was not recorded with
-- the VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT flag, it
-- must not have already been recorded to
-- commandBuffer.
-- - If any element of pCommandBuffers was not recorded with
-- the VK_COMMAND_BUFFER_USAGE_SIMULTANEOUS_USE_BIT flag, it
-- must not appear more than once in
-- pCommandBuffers.
-- - Each element of pCommandBuffers must have been
-- allocated from a VkCommandPool that was created for the same
-- queue family as the VkCommandPool from which
-- commandBuffer was allocated
-- - If vkCmdExecuteCommands is being called within a render
-- pass instance, that render pass instance must have been begun
-- with the contents parameter of vkCmdBeginRenderPass
-- set to VK_SUBPASS_CONTENTS_SECONDARY_COMMAND_BUFFERS
-- - If vkCmdExecuteCommands is being called within a render
-- pass instance, each element of pCommandBuffers must
-- have been recorded with the
-- VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT
-- - If vkCmdExecuteCommands is being called within a render
-- pass instance, each element of pCommandBuffers must
-- have been recorded with
-- VkCommandBufferInheritanceInfo::subpass set to the
-- index of the subpass which the given command buffer will be executed
-- in
-- - If vkCmdExecuteCommands is being called within a render
-- pass instance, the render passes specified in the
-- pname::pBeginInfo::pInheritanceInfo::renderPass
-- members of the vkBeginCommandBuffer commands used to begin
-- recording each element of pCommandBuffers must be
-- compatible with the current render pass.
-- - If vkCmdExecuteCommands is being called within a render
-- pass instance, and any element of pCommandBuffers was
-- recorded with
-- VkCommandBufferInheritanceInfo::framebuffer not
-- equal to VK_NULL_HANDLE, that VkFramebuffer
-- must match the VkFramebuffer used in the current
-- render pass instance
-- - If vkCmdExecuteCommands is not being called within a
-- render pass instance, each element of pCommandBuffers
-- must not have been recorded with the
-- VK_COMMAND_BUFFER_USAGE_RENDER_PASS_CONTINUE_BIT
-- - If the inherited queries feature is not enabled,
-- commandBuffer must not have any queries
-- active
-- - If commandBuffer has a VK_QUERY_TYPE_OCCLUSION
-- query active, then each element of pCommandBuffers
-- must have been recorded with
-- VkCommandBufferInheritanceInfo::occlusionQueryEnable
-- set to VK_TRUE
-- - If commandBuffer has a VK_QUERY_TYPE_OCCLUSION
-- query active, then each element of pCommandBuffers
-- must have been recorded with
-- VkCommandBufferInheritanceInfo::queryFlags having
-- all bits set that are set for the query
-- - If commandBuffer has a
-- VK_QUERY_TYPE_PIPELINE_STATISTICS query active, then
-- each element of pCommandBuffers must have been
-- recorded with
-- VkCommandBufferInheritanceInfo::pipelineStatistics
-- having all bits set that are set in the VkQueryPool the query
-- uses
-- - Each element of pCommandBuffers must not begin any
-- query types that are active in commandBuffer
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pCommandBuffers must be a valid pointer to an
-- array of commandBufferCount valid VkCommandBuffer
-- handles
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support transfer, graphics, or compute
-- operations
-- - commandBuffer must be a primary
-- VkCommandBuffer
-- - commandBufferCount must be greater than
-- 0
-- - Both of commandBuffer, and the elements of
-- pCommandBuffers must have been created, allocated, or
-- retrieved from the same VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Both | Transfer | |
-- | | | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCommandBuffer
vkCmdExecuteCommands :: ("commandBuffer" ::: VkCommandBuffer) -> ("commandBufferCount" ::: Word32) -> ("pCommandBuffers" ::: Ptr VkCommandBuffer) -> IO ()
-- | VkClearRect - Structure specifying a clear rectangle
--
-- Description
--
-- The layers [baseArrayLayer, baseArrayLayer +
-- layerCount) counting from the base layer of the attachment
-- image view are cleared.
--
-- See Also
--
-- VkRect2D, vkCmdClearAttachments
data VkClearRect
VkClearRect :: VkRect2D -> Word32 -> Word32 -> VkClearRect
-- | rect is the two-dimensional region to be cleared.
[$sel:vkRect:VkClearRect] :: VkClearRect -> VkRect2D
-- | baseArrayLayer is the first layer to be cleared.
[$sel:vkBaseArrayLayer:VkClearRect] :: VkClearRect -> Word32
-- | layerCount is the number of layers to clear.
[$sel:vkLayerCount:VkClearRect] :: VkClearRect -> Word32
-- | VkImageSubresourceLayers - Structure specifying a image subresource
-- layers
--
-- Description
--
-- Valid Usage
--
--
-- - If aspectMask contains
-- VK_IMAGE_ASPECT_COLOR_BIT, it must not contain either
-- of VK_IMAGE_ASPECT_DEPTH_BIT or
-- VK_IMAGE_ASPECT_STENCIL_BIT
--
--
--
-- - aspectMask must not contain
-- VK_IMAGE_ASPECT_METADATA_BIT
-- - layerCount must be greater than 0
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - aspectMask must not be 0
--
--
-- See Also
--
-- VkBufferImageCopy, VkImageAspectFlags,
-- VkImageBlit, VkImageCopy, VkImageResolve
data VkImageSubresourceLayers
VkImageSubresourceLayers :: VkImageAspectFlags -> Word32 -> Word32 -> Word32 -> VkImageSubresourceLayers
-- | aspectMask is a combination of VkImageAspectFlagBits,
-- selecting the color, depth and/or stencil aspects to be copied.
[$sel:vkAspectMask:VkImageSubresourceLayers] :: VkImageSubresourceLayers -> VkImageAspectFlags
-- | mipLevel is the mipmap level to copy from.
[$sel:vkMipLevel:VkImageSubresourceLayers] :: VkImageSubresourceLayers -> Word32
-- | baseArrayLayer and layerCount are the starting layer
-- and number of layers to copy.
[$sel:vkBaseArrayLayer:VkImageSubresourceLayers] :: VkImageSubresourceLayers -> Word32
[$sel:vkLayerCount:VkImageSubresourceLayers] :: VkImageSubresourceLayers -> Word32
-- | VkMemoryBarrier - Structure specifying a global memory barrier
--
-- Description
--
-- The first access scope is limited to access types in the
-- source access mask specified by srcAccessMask.
--
-- The second access scope is limited to access types in the
-- destination access mask specified by dstAccessMask.
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_MEMORY_BARRIER
--
--
--
-- - pNext must be NULL
-- - srcAccessMask must be a valid combination of
-- VkAccessFlagBits values
-- - dstAccessMask must be a valid combination of
-- VkAccessFlagBits values
--
--
-- See Also
--
-- VkAccessFlags, VkStructureType,
-- vkCmdPipelineBarrier, vkCmdWaitEvents
data VkMemoryBarrier
VkMemoryBarrier :: VkStructureType -> Ptr () -> VkAccessFlags -> VkAccessFlags -> VkMemoryBarrier
-- | sType is the type of this structure.
[$sel:vkSType:VkMemoryBarrier] :: VkMemoryBarrier -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkMemoryBarrier] :: VkMemoryBarrier -> Ptr ()
-- | srcAccessMask is a bitmask of VkAccessFlagBits
-- specifying a source access mask.
[$sel:vkSrcAccessMask:VkMemoryBarrier] :: VkMemoryBarrier -> VkAccessFlags
-- | dstAccessMask is a bitmask of VkAccessFlagBits
-- specifying a destination access mask.
[$sel:vkDstAccessMask:VkMemoryBarrier] :: VkMemoryBarrier -> VkAccessFlags
-- | VkBufferMemoryBarrier - Structure specifying a buffer memory barrier
--
-- Description
--
-- The first access scope is limited to access to memory through
-- the specified buffer range, via access types in the source access
-- mask specified by srcAccessMask. If
-- srcAccessMask includes VK_ACCESS_HOST_WRITE_BIT,
-- memory writes performed by that access type are also made visible, as
-- that access type is not performed through a resource.
--
-- The second access scope is limited to access to memory through
-- the specified buffer range, via access types in the destination
-- access mask. specified by dstAccessMask. If
-- dstAccessMask includes VK_ACCESS_HOST_WRITE_BIT or
-- VK_ACCESS_HOST_READ_BIT, available memory writes are also
-- made visible to accesses of those types, as those access types are not
-- performed through a resource.
--
-- If srcQueueFamilyIndex is not equal to
-- dstQueueFamilyIndex, and srcQueueFamilyIndex is
-- equal to the current queue family, then the memory barrier defines a
-- queue family release operation for the specified buffer range,
-- and the second access scope includes no access, as if
-- dstAccessMask was 0.
--
-- If dstQueueFamilyIndex is not equal to
-- srcQueueFamilyIndex, and dstQueueFamilyIndex is
-- equal to the current queue family, then the memory barrier defines a
-- queue family acquire operation for the specified buffer range,
-- and the first access scope includes no access, as if
-- srcAccessMask was 0.
--
-- Valid Usage
--
--
-- - offset must be less than the size of
-- buffer
--
--
--
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be greater than 0
-- - If size is not equal to VK_WHOLE_SIZE,
-- size must be less than or equal to than the size of
-- buffer minus offset
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_CONCURRENT, at least one of
-- srcQueueFamilyIndex and dstQueueFamilyIndex
-- must be VK_QUEUE_FAMILY_IGNORED
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_CONCURRENT, and one of
-- srcQueueFamilyIndex and dstQueueFamilyIndex is
-- VK_QUEUE_FAMILY_IGNORED, the other must be
-- VK_QUEUE_FAMILY_IGNORED or a special queue family reserved
-- for external memory ownership transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and srcQueueFamilyIndex is
-- VK_QUEUE_FAMILY_IGNORED, dstQueueFamilyIndex
-- must also be VK_QUEUE_FAMILY_IGNORED
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and srcQueueFamilyIndex is
-- not VK_QUEUE_FAMILY_IGNORED, it must be a valid queue
-- family or a special queue family reserved for external memory
-- transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and dstQueueFamilyIndex is
-- not VK_QUEUE_FAMILY_IGNORED, it must be a valid queue
-- family or a special queue family reserved for external memory
-- transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If buffer was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE, and srcQueueFamilyIndex
-- and dstQueueFamilyIndex are not
-- VK_QUEUE_FAMILY_IGNORED, at least one of them must be
-- the same as the family of the queue that will execute this
-- barrier
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER
--
--
--
-- - pNext must be NULL
-- - srcAccessMask must be a valid combination of
-- VkAccessFlagBits values
-- - dstAccessMask must be a valid combination of
-- VkAccessFlagBits values
-- - buffer must be a valid VkBuffer
-- handle
--
--
-- See Also
--
-- VkAccessFlags, VkBuffer, VkDeviceSize,
-- VkStructureType, vkCmdPipelineBarrier,
-- vkCmdWaitEvents
data VkBufferMemoryBarrier
VkBufferMemoryBarrier :: VkStructureType -> Ptr () -> VkAccessFlags -> VkAccessFlags -> Word32 -> Word32 -> VkBuffer -> VkDeviceSize -> VkDeviceSize -> VkBufferMemoryBarrier
-- | sType is the type of this structure.
[$sel:vkSType:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> Ptr ()
-- | srcAccessMask is a bitmask of VkAccessFlagBits
-- specifying a source access mask.
[$sel:vkSrcAccessMask:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkAccessFlags
-- | dstAccessMask is a bitmask of VkAccessFlagBits
-- specifying a destination access mask.
[$sel:vkDstAccessMask:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkAccessFlags
-- | srcQueueFamilyIndex is the source queue family for a queue
-- family ownership transfer.
[$sel:vkSrcQueueFamilyIndex:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> Word32
-- | dstQueueFamilyIndex is the destination queue family for a
-- queue family ownership transfer.
[$sel:vkDstQueueFamilyIndex:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> Word32
-- | buffer is a handle to the buffer whose backing memory is
-- affected by the barrier.
[$sel:vkBuffer:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkBuffer
-- | offset is an offset in bytes into the backing memory for
-- buffer; this is relative to the base offset as bound to the
-- buffer (see vkBindBufferMemory).
[$sel:vkOffset:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkDeviceSize
-- | size is a size in bytes of the affected area of backing
-- memory for buffer, or VK_WHOLE_SIZE to use the range
-- from offset to the end of the buffer.
[$sel:vkSize:VkBufferMemoryBarrier] :: VkBufferMemoryBarrier -> VkDeviceSize
-- | VkImageMemoryBarrier - Structure specifying the parameters of an image
-- memory barrier
--
-- Description
--
-- The first access scope is limited to access to memory through
-- the specified image subresource range, via access types in the
-- source access mask specified by srcAccessMask. If
-- srcAccessMask includes VK_ACCESS_HOST_WRITE_BIT,
-- memory writes performed by that access type are also made visible, as
-- that access type is not performed through a resource.
--
-- The second access scope is limited to access to memory through
-- the specified image subresource range, via access types in the
-- destination access mask specified by dstAccessMask. If
-- dstAccessMask includes VK_ACCESS_HOST_WRITE_BIT or
-- VK_ACCESS_HOST_READ_BIT, available memory writes are also
-- made visible to accesses of those types, as those access types are not
-- performed through a resource.
--
-- If srcQueueFamilyIndex is not equal to
-- dstQueueFamilyIndex, and srcQueueFamilyIndex is
-- equal to the current queue family, then the memory barrier defines a
-- queue family release operation for the specified image
-- subresource range, and the second access scope includes no access, as
-- if dstAccessMask was 0.
--
-- If dstQueueFamilyIndex is not equal to
-- srcQueueFamilyIndex, and dstQueueFamilyIndex is
-- equal to the current queue family, then the memory barrier defines a
-- queue family acquire operation for the specified image
-- subresource range, and the first access scope includes no access, as
-- if srcAccessMask was 0.
--
-- If oldLayout is not equal to newLayout, then the
-- memory barrier defines an image layout transition for the
-- specified image subresource range.
--
-- Layout transitions that are performed via image memory barriers
-- execute in their entirety in submission order, relative to
-- other image layout transitions submitted to the same queue, including
-- those performed by render passes. In effect there is an
-- implicit execution dependency from each such layout transition to all
-- layout transitions previously submitted to the same queue.
--
-- The image layout of each image subresource of a depth/stencil image
-- created with
-- VK_IMAGE_CREATE_SAMPLE_LOCATIONS_COMPATIBLE_DEPTH_BIT_EXT is
-- dependent on the last sample locations used to render to the image
-- subresource as a depth/stencil attachment, thus when the
-- image member of an VkImageMemoryBarrier is an image
-- created with this flag the application can chain a
-- VkSampleLocationsInfoEXT structure to the pNext chain
-- of VkImageMemoryBarrier to specify the sample locations to
-- use during the image layout transition.
--
-- If the VkSampleLocationsInfoEXT structure in the
-- pNext chain of VkImageMemoryBarrier does not match
-- the sample location state last used to render to the image subresource
-- range specified by subresourceRange or if no
-- VkSampleLocationsInfoEXT structure is in the pNext
-- chain of VkImageMemoryBarrier then the contents of the given
-- image subresource range becomes undefined as if oldLayout
-- would equal VK_IMAGE_LAYOUT_UNDEFINED.
--
-- If image has a multi-planar format and the image is
-- disjoint, then including VK_IMAGE_ASPECT_COLOR_BIT in
-- the aspectMask member of subresourceRange is
-- equivalent to including VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, and (for three-plane formats
-- only) VK_IMAGE_ASPECT_PLANE_2_BIT.
--
-- Valid Usage
--
--
-- - oldLayout must be
-- VK_IMAGE_LAYOUT_UNDEFINED or the current layout of the image
-- subresources affected by the barrier
--
--
--
-- - newLayout must not be
-- VK_IMAGE_LAYOUT_UNDEFINED or
-- VK_IMAGE_LAYOUT_PREINITIALIZED
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_CONCURRENT, at least one of
-- srcQueueFamilyIndex and dstQueueFamilyIndex
-- must be VK_QUEUE_FAMILY_IGNORED
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_CONCURRENT, and one of
-- srcQueueFamilyIndex and dstQueueFamilyIndex is
-- VK_QUEUE_FAMILY_IGNORED, the other must be
-- VK_QUEUE_FAMILY_IGNORED or a special queue family reserved
-- for external memory transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and srcQueueFamilyIndex is
-- VK_QUEUE_FAMILY_IGNORED, dstQueueFamilyIndex
-- must also be VK_QUEUE_FAMILY_IGNORED.
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and srcQueueFamilyIndex is
-- not VK_QUEUE_FAMILY_IGNORED, it must be a valid queue
-- family or a special queue family reserved for external memory
-- transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE and dstQueueFamilyIndex is
-- not VK_QUEUE_FAMILY_IGNORED, it must be a valid queue
-- family or a special queue family reserved for external memory
-- transfers, as described in
-- {html_spec_relative}#synchronization-queue-transfers.
-- - If image was created with a sharing mode of
-- VK_SHARING_MODE_EXCLUSIVE, and srcQueueFamilyIndex
-- and dstQueueFamilyIndex are not
-- VK_QUEUE_FAMILY_IGNORED, at least one of them must be
-- the same as the family of the queue that will execute this
-- barrier
-- - subresourceRange.baseMipLevel must be less than
-- the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - If subresourceRange.levelCount is not
-- VK_REMAINING_MIP_LEVELS,
-- subresourceRange.baseMipLevel +
-- subresourceRange.levelCount must be less than or equal
-- to the mipLevels specified in VkImageCreateInfo when
-- image was created
-- - subresourceRange.baseArrayLayer must be less than
-- the arrayLayers specified in VkImageCreateInfo when
-- image was created
-- - If subresourceRange.layerCount is not
-- VK_REMAINING_ARRAY_LAYERS,
-- subresourceRange.baseArrayLayer +
-- subresourceRange.layerCount must be less than or equal
-- to the arrayLayers specified in VkImageCreateInfo when
-- image was created
-- - If image has a depth/stencil format with both depth and
-- stencil components, then the aspectMask member of
-- subresourceRange must include both
-- VK_IMAGE_ASPECT_DEPTH_BIT and
-- VK_IMAGE_ASPECT_STENCIL_BIT
-- - If image has a single-plane color format or is not
-- disjoint, then the aspectMask member of
-- subresourceRange must be
-- VK_IMAGE_ASPECT_COLOR_BIT
-- - If image has a multi-planar format and the image is
-- disjoint, then the aspectMask member of
-- subresourceRange must include either at least one of
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, and
-- VK_IMAGE_ASPECT_PLANE_2_BIT; or must include
-- VK_IMAGE_ASPECT_COLOR_BIT
-- - If image has a multi-planar format with only two planes,
-- then the aspectMask member of subresourceRange
-- must not include VK_IMAGE_ASPECT_PLANE_2_BIT
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL then image
-- must have been created with
-- VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL then
-- image must have been created with
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_DEPTH_STENCIL_READ_ONLY_OPTIMAL then
-- image must have been created with
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_DEPTH_READ_ONLY_STENCIL_ATTACHMENT_OPTIMAL
-- then image must have been created with
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_DEPTH_ATTACHMENT_STENCIL_READ_ONLY_OPTIMAL
-- then image must have been created with
-- VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL then image
-- must have been created with VK_IMAGE_USAGE_SAMPLED_BIT
-- or VK_IMAGE_USAGE_INPUT_ATTACHMENT_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_TRANSFER_SRC_OPTIMAL then image
-- must have been created with
-- VK_IMAGE_USAGE_TRANSFER_SRC_BIT set
-- - If either oldLayout or newLayout is
-- VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL then image
-- must have been created with
-- VK_IMAGE_USAGE_TRANSFER_DST_BIT set
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER
--
--
--
-- - pNext must be NULL or a pointer to a
-- valid instance of VkSampleLocationsInfoEXT
-- - srcAccessMask must be a valid combination of
-- VkAccessFlagBits values
-- - dstAccessMask must be a valid combination of
-- VkAccessFlagBits values
-- - oldLayout must be a valid VkImageLayout
-- value
-- - newLayout must be a valid VkImageLayout
-- value
-- - image must be a valid VkImage handle
-- - subresourceRange must be a valid
-- VkImageSubresourceRange structure
--
--
-- See Also
--
-- VkAccessFlags, VkImage, VkImageLayout,
-- VkImageSubresourceRange, VkStructureType,
-- vkCmdPipelineBarrier, vkCmdWaitEvents
data VkImageMemoryBarrier
VkImageMemoryBarrier :: VkStructureType -> Ptr () -> VkAccessFlags -> VkAccessFlags -> VkImageLayout -> VkImageLayout -> Word32 -> Word32 -> VkImage -> VkImageSubresourceRange -> VkImageMemoryBarrier
-- | sType is the type of this structure.
[$sel:vkSType:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> Ptr ()
-- | srcAccessMask is a bitmask of VkAccessFlagBits
-- specifying a source access mask.
[$sel:vkSrcAccessMask:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkAccessFlags
-- | dstAccessMask is a bitmask of VkAccessFlagBits
-- specifying a destination access mask.
[$sel:vkDstAccessMask:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkAccessFlags
-- | oldLayout is the old layout in an image layout
-- transition.
[$sel:vkOldLayout:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkImageLayout
-- | newLayout is the new layout in an image layout
-- transition.
[$sel:vkNewLayout:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkImageLayout
-- | srcQueueFamilyIndex is the source queue family for a queue
-- family ownership transfer.
[$sel:vkSrcQueueFamilyIndex:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> Word32
-- | dstQueueFamilyIndex is the destination queue family for a
-- queue family ownership transfer.
[$sel:vkDstQueueFamilyIndex:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> Word32
-- | image is a handle to the image affected by this barrier.
[$sel:vkImage:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkImage
-- | subresourceRange describes the image subresource range
-- within image that is affected by this barrier.
[$sel:vkSubresourceRange:VkImageMemoryBarrier] :: VkImageMemoryBarrier -> VkImageSubresourceRange
-- | VkBufferCopy - Structure specifying a buffer copy operation
--
-- Description
--
-- See Also
--
-- VkDeviceSize, vkCmdCopyBuffer
data VkBufferCopy
VkBufferCopy :: VkDeviceSize -> VkDeviceSize -> VkDeviceSize -> VkBufferCopy
-- | srcOffset is the starting offset in bytes from the start of
-- srcBuffer.
[$sel:vkSrcOffset:VkBufferCopy] :: VkBufferCopy -> VkDeviceSize
-- | dstOffset is the starting offset in bytes from the start of
-- dstBuffer.
[$sel:vkDstOffset:VkBufferCopy] :: VkBufferCopy -> VkDeviceSize
-- | size is the number of bytes to copy.
[$sel:vkSize:VkBufferCopy] :: VkBufferCopy -> VkDeviceSize
-- | VkImageCopy - Structure specifying an image copy operation
--
-- Description
--
-- For VK_IMAGE_TYPE_3D images, copies are performed slice by
-- slice starting with the z member of the srcOffset or
-- dstOffset, and copying depth slices. For images with
-- multiple layers, copies are performed layer by layer starting with the
-- baseArrayLayer member of the srcSubresource or
-- dstSubresource and copying layerCount layers. Image
-- data can be copied between images with different image types.
-- If one image is VK_IMAGE_TYPE_3D and the other image is
-- VK_IMAGE_TYPE_2D with multiple layers, then each slice is
-- copied to or from a different layer.
--
-- Copies involving a multi-planar image format specify the region
-- to be copied in terms of the plane to be copied, not the
-- coordinates of the multi-planar image. This means that copies
-- accessing the R/B planes of “_422” format images must
-- fit the copied region within half the width of the parent
-- image, and that copies accessing the R/B planes of “_420”
-- format images must fit the copied region within half the
-- width and height of the parent image.
--
-- Valid Usage
--
--
-- - If neither the calling command’s srcImage nor the calling
-- command’s dstImage has a multi-planar image format
-- then the aspectMask member of srcSubresource and
-- dstSubresource must match
--
--
--
-- - If the calling command’s srcImage has a VkFormat
-- with two planes then the srcSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT or
-- VK_IMAGE_ASPECT_PLANE_1_BIT
-- - If the calling command’s srcImage has a VkFormat
-- with three planes then the srcSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT
-- - If the calling command’s dstImage has a VkFormat
-- with two planes then the dstSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT or
-- VK_IMAGE_ASPECT_PLANE_1_BIT
-- - If the calling command’s dstImage has a VkFormat
-- with three planes then the dstSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT
-- - If the calling command’s srcImage has a multi-planar
-- image format and the dstImage does not have a
-- multi-planar image format, the dstSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_COLOR_BIT
-- - If the calling command’s dstImage has a multi-planar
-- image format and the srcImage does not have a
-- multi-planar image format, the srcSubresource
-- aspectMask must be
-- VK_IMAGE_ASPECT_COLOR_BIT
-- - The number of slices of the extent (for 3D) or layers of
-- the srcSubresource (for non-3D) must match the number
-- of slices of the extent (for 3D) or layers of the
-- dstSubresource (for non-3D)
-- - If either of the calling command’s srcImage or
-- dstImage parameters are of VkImageType
-- VK_IMAGE_TYPE_3D, the baseArrayLayer and
-- layerCount members of the corresponding subresource
-- must be 0 and 1, respectively
-- - The aspectMask member of srcSubresource
-- must specify aspects present in the calling command’s
-- srcImage
-- - The aspectMask member of dstSubresource
-- must specify aspects present in the calling command’s
-- dstImage
-- - srcOffset.x and (extent.width +
-- srcOffset.x) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- width
-- - srcOffset.y and (extent.height +
-- srcOffset.y) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- height
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D, then srcOffset.y must be
-- 0 and extent.height must be 1.
-- - srcOffset.z and (extent.depth +
-- srcOffset.z) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- depth
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D, then srcOffset.z must be
-- 0 and extent.depth must be 1.
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D, then dstOffset.z must be
-- 0 and extent.depth must be 1.
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_2D, then srcOffset.z must be
-- 0.
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_2D, then dstOffset.z must be
-- 0.
-- - If both srcImage and dstImage are of type
-- VK_IMAGE_TYPE_2D then then extent.depth must
-- be 1.
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_2D, and the dstImage is of type
-- VK_IMAGE_TYPE_3D, then extent.depth must
-- equal to the layerCount member of
-- srcSubresource.
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_2D, and the srcImage is of type
-- VK_IMAGE_TYPE_3D, then extent.depth must
-- equal to the layerCount member of
-- dstSubresource.
-- - dstOffset.x and (extent.width +
-- dstOffset.x) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- width
-- - dstOffset.y and (extent.height +
-- dstOffset.y) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- height
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D, then dstOffset.y must be
-- 0 and extent.height must be 1.
-- - dstOffset.z and (extent.depth +
-- dstOffset.z) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- depth
-- - If the calling command’s srcImage is a compressed image,
-- or a single-plane, “_422” image format, all members of
-- srcOffset must be a multiple of the corresponding
-- dimensions of the compressed texel block
-- - If the calling command’s srcImage is a compressed image,
-- or a single-plane, “_422” image format,
-- extent.width must be a multiple of the compressed
-- texel block width or (extent.width + srcOffset.x)
-- must equal the source image subresource width
-- - If the calling command’s srcImage is a compressed image,
-- or a single-plane, “_422” image format,
-- extent.height must be a multiple of the compressed
-- texel block height or (extent.height + srcOffset.y)
-- must equal the source image subresource height
-- - If the calling command’s srcImage is a compressed image,
-- or a single-plane, “_422” image format,
-- extent.depth must be a multiple of the compressed
-- texel block depth or (extent.depth + srcOffset.z)
-- must equal the source image subresource depth
-- - If the calling command’s dstImage is a compressed format
-- image, or a single-plane, “_422” image format, all
-- members of dstOffset must be a multiple of the
-- corresponding dimensions of the compressed texel block
-- - If the calling command’s dstImage is a compressed format
-- image, or a single-plane, “_422” image format,
-- extent.width must be a multiple of the compressed
-- texel block width or (extent.width + dstOffset.x)
-- must equal the destination image subresource width
-- - If the calling command’s dstImage is a compressed format
-- image, or a single-plane, “_422” image format,
-- extent.height must be a multiple of the compressed
-- texel block height or (extent.height + dstOffset.y)
-- must equal the destination image subresource height
-- - If the calling command’s dstImage is a compressed format
-- image, or a single-plane, “_422” image format,
-- extent.depth must be a multiple of the compressed
-- texel block depth or (extent.depth + dstOffset.z)
-- must equal the destination image subresource depth
--
--
-- Valid Usage (Implicit)
--
--
-- - srcSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
--
-- - dstSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
-- See Also
--
-- VkExtent3D, VkImageSubresourceLayers, VkOffset3D,
-- vkCmdCopyImage
data VkImageCopy
VkImageCopy :: VkImageSubresourceLayers -> VkOffset3D -> VkImageSubresourceLayers -> VkOffset3D -> VkExtent3D -> VkImageCopy
-- | srcSubresource and dstSubresource are
-- VkImageSubresourceLayers structures specifying the image
-- subresources of the images used for the source and destination image
-- data, respectively.
[$sel:vkSrcSubresource:VkImageCopy] :: VkImageCopy -> VkImageSubresourceLayers
-- | srcOffset and dstOffset select the initial
-- x, y, and z offsets in texels of the
-- sub-regions of the source and destination image data.
[$sel:vkSrcOffset:VkImageCopy] :: VkImageCopy -> VkOffset3D
[$sel:vkDstSubresource:VkImageCopy] :: VkImageCopy -> VkImageSubresourceLayers
[$sel:vkDstOffset:VkImageCopy] :: VkImageCopy -> VkOffset3D
-- | extent is the size in texels of the image to copy in
-- width, height and depth.
[$sel:vkExtent:VkImageCopy] :: VkImageCopy -> VkExtent3D
-- | VkImageBlit - Structure specifying an image blit operation
--
-- Description
--
-- For each element of the pRegions array, a blit operation is
-- performed the specified source and destination regions.
--
-- Valid Usage
--
--
-- - The aspectMask member of srcSubresource and
-- dstSubresource must match
--
--
--
-- - The layerCount member of srcSubresource and
-- dstSubresource must match
-- - If either of the calling command’s srcImage or
-- dstImage parameters are of VkImageType
-- VK_IMAGE_TYPE_3D, the baseArrayLayer and
-- layerCount members of both srcSubresource and
-- dstSubresource must be 0 and 1,
-- respectively
-- - The aspectMask member of srcSubresource
-- must specify aspects present in the calling command’s
-- srcImage
-- - The aspectMask member of dstSubresource
-- must specify aspects present in the calling command’s
-- dstImage
-- - srcOffset[0].x and
-- srcOffset[1].x must both be greater than or
-- equal to 0 and less than or equal to the source image
-- subresource width
-- - srcOffset[0].y and
-- srcOffset[1].y must both be greater than or
-- equal to 0 and less than or equal to the source image
-- subresource height
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D, then srcOffset[0].y must be
-- 0 and srcOffset[1].y must be 1.
-- - srcOffset[0].z and
-- srcOffset[1].z must both be greater than or
-- equal to 0 and less than or equal to the source image
-- subresource depth
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D or VK_IMAGE_TYPE_2D, then
-- srcOffset[0].z must be 0 and
-- srcOffset[1].z must be 1.
-- - dstOffset[0].x and
-- dstOffset[1].x must both be greater than or
-- equal to 0 and less than or equal to the destination image
-- subresource width
-- - dstOffset[0].y and
-- dstOffset[1].y must both be greater than or
-- equal to 0 and less than or equal to the destination image
-- subresource height
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D, then dstOffset[0].y must be
-- 0 and dstOffset[1].y must be 1.
-- - dstOffset[0].z and
-- dstOffset[1].z must both be greater than or
-- equal to 0 and less than or equal to the destination image
-- subresource depth
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D or VK_IMAGE_TYPE_2D, then
-- dstOffset[0].z must be 0 and
-- dstOffset[1].z must be 1.
--
--
-- Valid Usage (Implicit)
--
--
-- - srcSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
--
-- - dstSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
-- See Also
--
-- VkImageSubresourceLayers, VkOffset3D,
-- vkCmdBlitImage
data VkImageBlit
VkImageBlit :: VkImageSubresourceLayers -> Vector 2 VkOffset3D -> VkImageSubresourceLayers -> Vector 2 VkOffset3D -> VkImageBlit
-- | srcSubresource is the subresource to blit from.
[$sel:vkSrcSubresource:VkImageBlit] :: VkImageBlit -> VkImageSubresourceLayers
-- | srcOffsets is an array of two VkOffset3D structures
-- specifying the bounds of the source region within
-- srcSubresource.
[$sel:vkSrcOffsets:VkImageBlit] :: VkImageBlit -> Vector 2 VkOffset3D
-- | dstSubresource is the subresource to blit into.
[$sel:vkDstSubresource:VkImageBlit] :: VkImageBlit -> VkImageSubresourceLayers
-- | dstOffsets is an array of two VkOffset3D structures
-- specifying the bounds of the destination region within
-- dstSubresource.
[$sel:vkDstOffsets:VkImageBlit] :: VkImageBlit -> Vector 2 VkOffset3D
-- | VkBufferImageCopy - Structure specifying a buffer image copy operation
--
-- Description
--
-- When copying to or from a depth or stencil aspect, the data in buffer
-- memory uses a layout that is a (mostly) tightly packed representation
-- of the depth or stencil data. Specifically:
--
--
-- - data copied to or from the stencil aspect of any depth/stencil
-- format is tightly packed with one VK_FORMAT_S8_UINT value per
-- texel.
-- - data copied to or from the depth aspect of a
-- VK_FORMAT_D16_UNORM or VK_FORMAT_D16_UNORM_S8_UINT
-- format is tightly packed with one VK_FORMAT_D16_UNORM value
-- per texel.
-- - data copied to or from the depth aspect of a
-- VK_FORMAT_D32_SFLOAT or VK_FORMAT_D32_SFLOAT_S8_UINT
-- format is tightly packed with one VK_FORMAT_D32_SFLOAT value
-- per texel.
-- - data copied to or from the depth aspect of a
-- VK_FORMAT_X8_D24_UNORM_PACK32 or
-- VK_FORMAT_D24_UNORM_S8_UINT format is packed with one 32-bit
-- word per texel with the D24 value in the LSBs of the word, and
-- undefined values in the eight MSBs.
--
--
-- Note
--
-- To copy both the depth and stencil aspects of a depth/stencil format,
-- two entries in pRegions can be used, where one
-- specifies the depth aspect in imageSubresource, and the other
-- specifies the stencil aspect.
--
-- Because depth or stencil aspect buffer to image copies may
-- require format conversions on some implementations, they are not
-- supported on queues that do not support graphics. When copying to a
-- depth aspect, the data in buffer memory must be in the the
-- range [0,1] or undefined results occur.
--
-- Copies are done layer by layer starting with image layer
-- baseArrayLayer member of imageSubresource.
-- layerCount layers are copied from the source image or to the
-- destination image.
--
-- Valid Usage
--
--
-- - If the calling command’s VkImage parameter’s format is
-- not a depth/stencil format or a multi-planar format, then
-- bufferOffset must be a multiple of the format’s
-- element size
--
--
--
-- - If the calling command’s VkImage parameter’s format is a
-- multi-planar format, then bufferOffset must be
-- a multiple of the element size of the compatible format for the format
-- and the aspectMask of the imageSubresource as
-- defined in
-- {html_spec_relative}#features-formats-compatible-planes
-- - bufferOffset must be a multiple of 4
-- - bufferRowLength must be 0, or greater
-- than or equal to the width member of
-- imageExtent
-- - bufferImageHeight must be 0, or greater
-- than or equal to the height member of
-- imageExtent
-- - imageOffset.x and (imageExtent.width +
-- imageOffset.x) must both be greater than or equal to
-- 0 and less than or equal to the image subresource width where
-- this refers to the width of the plane of the image involved in
-- the copy in the case of a multi-planar format
-- - imageOffset.y and (imageExtent.height +
-- imageOffset.y) must both be greater than or equal to
-- 0 and less than or equal to the image subresource height
-- where this refers to the height of the plane of the image
-- involved in the copy in the case of a multi-planar format
-- - If the calling command’s srcImage
-- (vkCmdCopyImageToBuffer) or dstImage
-- (vkCmdCopyBufferToImage) is of type VK_IMAGE_TYPE_1D,
-- then imageOffset.y must be 0 and
-- imageExtent.height must be 1.
-- - imageOffset.z and (imageExtent.depth +
-- imageOffset.z) must both be greater than or equal to
-- 0 and less than or equal to the image subresource depth
-- - If the calling command’s srcImage
-- (vkCmdCopyImageToBuffer) or dstImage
-- (vkCmdCopyBufferToImage) is of type VK_IMAGE_TYPE_1D
-- or VK_IMAGE_TYPE_2D, then imageOffset.z must
-- be 0 and imageExtent.depth must be
-- 1
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, bufferRowLength must be a multiple of the
-- compressed texel block width
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, bufferImageHeight must be a multiple of the
-- compressed texel block height
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, all members of imageOffset must be a multiple
-- of the corresponding dimensions of the compressed texel block
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, bufferOffset must be a multiple of the
-- compressed texel block size in bytes
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, imageExtent.width must be a multiple of the
-- compressed texel block width or (imageExtent.width +
-- imageOffset.x) must equal the image subresource
-- width
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, imageExtent.height must be a multiple of the
-- compressed texel block height or (imageExtent.height +
-- imageOffset.y) must equal the image subresource
-- height
-- - If the calling command’s VkImage parameter is a
-- compressed image, or a single-plane, “_422” image
-- format, imageExtent.depth must be a multiple of the
-- compressed texel block depth or (imageExtent.depth +
-- imageOffset.z) must equal the image subresource
-- depth
-- - The aspectMask member of imageSubresource
-- must specify aspects present in the calling command’s
-- VkImage parameter
-- - If the calling command’s VkImage parameter’s format is a
-- multi-planar format, then the aspectMask member of
-- imageSubresource must be
-- VK_IMAGE_ASPECT_PLANE_0_BIT,
-- VK_IMAGE_ASPECT_PLANE_1_BIT, or
-- VK_IMAGE_ASPECT_PLANE_2_BIT (with
-- VK_IMAGE_ASPECT_PLANE_2_BIT valid only for image formats with
-- three planes)
-- - The aspectMask member of imageSubresource
-- must only have a single bit set
-- - If the calling command’s VkImage parameter is of
-- VkImageType VK_IMAGE_TYPE_3D, the
-- baseArrayLayer and layerCount members of
-- imageSubresource must be 0 and 1,
-- respectively
-- - When copying to the depth aspect of an image subresource, the data
-- in the source buffer must be in the range [0,1]
--
--
-- Valid Usage (Implicit)
--
--
-- - imageSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
-- See Also
--
-- VkDeviceSize, VkExtent3D,
-- VkImageSubresourceLayers, VkOffset3D,
-- vkCmdCopyBufferToImage, vkCmdCopyImageToBuffer
data VkBufferImageCopy
VkBufferImageCopy :: VkDeviceSize -> Word32 -> Word32 -> VkImageSubresourceLayers -> VkOffset3D -> VkExtent3D -> VkBufferImageCopy
-- | bufferOffset is the offset in bytes from the start of the
-- buffer object where the image data is copied from or to.
[$sel:vkBufferOffset:VkBufferImageCopy] :: VkBufferImageCopy -> VkDeviceSize
-- | bufferRowLength and bufferImageHeight specify the
-- data in buffer memory as a subregion of a larger two- or
-- three-dimensional image, and control the addressing calculations of
-- data in buffer memory. If either of these values is zero, that aspect
-- of the buffer memory is considered to be tightly packed according to
-- the imageExtent.
[$sel:vkBufferRowLength:VkBufferImageCopy] :: VkBufferImageCopy -> Word32
[$sel:vkBufferImageHeight:VkBufferImageCopy] :: VkBufferImageCopy -> Word32
-- | imageSubresource is a VkImageSubresourceLayers used to
-- specify the specific image subresources of the image used for the
-- source or destination image data.
[$sel:vkImageSubresource:VkBufferImageCopy] :: VkBufferImageCopy -> VkImageSubresourceLayers
-- | imageOffset selects the initial x, y,
-- z offsets in texels of the sub-region of the source or
-- destination image data.
[$sel:vkImageOffset:VkBufferImageCopy] :: VkBufferImageCopy -> VkOffset3D
-- | imageExtent is the size in texels of the image to copy in
-- width, height and depth.
[$sel:vkImageExtent:VkBufferImageCopy] :: VkBufferImageCopy -> VkExtent3D
-- | VkImageResolve - Structure specifying an image resolve operation
--
-- Description
--
-- Valid Usage
--
--
-- - The aspectMask member of srcSubresource and
-- dstSubresource must only contain
-- VK_IMAGE_ASPECT_COLOR_BIT
--
--
--
-- - The layerCount member of srcSubresource and
-- dstSubresource must match
-- - If either of the calling command’s srcImage or
-- dstImage parameters are of VkImageType
-- VK_IMAGE_TYPE_3D, the baseArrayLayer and
-- layerCount members of both srcSubresource and
-- dstSubresource must be 0 and 1,
-- respectively
-- - srcOffset.x and (extent.width +
-- srcOffset.x) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- width
-- - srcOffset.y and (extent.height +
-- srcOffset.y) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- height
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D, then srcOffset.y must be
-- 0 and extent.height must be 1.
-- - srcOffset.z and (extent.depth +
-- srcOffset.z) must both be greater than or equal to
-- 0 and less than or equal to the source image subresource
-- depth
-- - If the calling command’s srcImage is of type
-- VK_IMAGE_TYPE_1D or VK_IMAGE_TYPE_2D, then
-- srcOffset.z must be 0 and
-- extent.depth must be 1.
-- - dstOffset.x and (extent.width +
-- dstOffset.x) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- width
-- - dstOffset.y and (extent.height +
-- dstOffset.y) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- height
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D, then dstOffset.y must be
-- 0 and extent.height must be 1.
-- - dstOffset.z and (extent.depth +
-- dstOffset.z) must both be greater than or equal to
-- 0 and less than or equal to the destination image subresource
-- depth
-- - If the calling command’s dstImage is of type
-- VK_IMAGE_TYPE_1D or VK_IMAGE_TYPE_2D, then
-- dstOffset.z must be 0 and
-- extent.depth must be 1.
--
--
-- Valid Usage (Implicit)
--
--
-- - srcSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
--
-- - dstSubresource must be a valid
-- VkImageSubresourceLayers structure
--
--
-- See Also
--
-- VkExtent3D, VkImageSubresourceLayers, VkOffset3D,
-- vkCmdResolveImage
data VkImageResolve
VkImageResolve :: VkImageSubresourceLayers -> VkOffset3D -> VkImageSubresourceLayers -> VkOffset3D -> VkExtent3D -> VkImageResolve
-- | srcSubresource and dstSubresource are
-- VkImageSubresourceLayers structures specifying the image
-- subresources of the images used for the source and destination image
-- data, respectively. Resolve of depth/stencil images is not supported.
[$sel:vkSrcSubresource:VkImageResolve] :: VkImageResolve -> VkImageSubresourceLayers
-- | srcOffset and dstOffset select the initial
-- x, y, and z offsets in texels of the
-- sub-regions of the source and destination image data.
[$sel:vkSrcOffset:VkImageResolve] :: VkImageResolve -> VkOffset3D
[$sel:vkDstSubresource:VkImageResolve] :: VkImageResolve -> VkImageSubresourceLayers
[$sel:vkDstOffset:VkImageResolve] :: VkImageResolve -> VkOffset3D
-- | extent is the size in texels of the source image to resolve
-- in width, height and depth.
[$sel:vkExtent:VkImageResolve] :: VkImageResolve -> VkExtent3D
-- | VkRenderPassBeginInfo - Structure specifying render pass begin info
--
-- Description
--
-- renderArea is the render area that is affected by the render
-- pass instance. The effects of attachment load, store and multisample
-- resolve operations are restricted to the pixels whose x and y
-- coordinates fall within the render area on all attachments. The render
-- area extends to all layers of framebuffer. The application
-- must ensure (using scissor if necessary) that all rendering is
-- contained within the render area, otherwise the pixels outside of the
-- render area become undefined and shader side effects may occur
-- for fragments outside the render area. The render area must be
-- contained within the framebuffer dimensions.
--
-- When multiview is enabled, the resolve operation at the end of a
-- subpass applies to all views in the view mask.
--
-- Note
--
-- There may be a performance cost for using a render area smaller
-- than the framebuffer, unless it matches the render area granularity
-- for the render pass.
--
-- Valid Usage
--
--
-- - clearValueCount must be greater than the largest
-- attachment index in renderPass that specifies a
-- loadOp (or stencilLoadOp, if the attachment has a
-- depth/stencil format) of VK_ATTACHMENT_LOAD_OP_CLEAR
--
--
--
-- - If clearValueCount is not 0,
-- pClearValues must be a valid pointer to an array of
-- clearValueCount valid VkClearValue unions
-- - renderPass must be compatible with the
-- renderPass member of the VkFramebufferCreateInfo
-- structure specified when creating framebuffer.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO
--
--
--
-- - Each pNext member of any structure (including this one)
-- in the pNext chain must be either NULL or a
-- pointer to a valid instance of VkDeviceGroupRenderPassBeginInfo
-- or VkRenderPassSampleLocationsBeginInfoEXT
-- - Each sType member in the pNext chain must
-- be unique
-- - renderPass must be a valid VkRenderPass
-- handle
-- - framebuffer must be a valid VkFramebuffer
-- handle
-- - Both of framebuffer, and renderPass must
-- have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkClearValue, VkFramebuffer, VkRect2D,
-- VkRenderPass, VkStructureType,
-- vkCmdBeginRenderPass
data VkRenderPassBeginInfo
VkRenderPassBeginInfo :: VkStructureType -> Ptr () -> VkRenderPass -> VkFramebuffer -> VkRect2D -> Word32 -> Ptr VkClearValue -> VkRenderPassBeginInfo
-- | sType is the type of this structure.
[$sel:vkSType:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> Ptr ()
-- | renderPass is the render pass to begin an instance of.
[$sel:vkRenderPass:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> VkRenderPass
-- | framebuffer is the framebuffer containing the attachments
-- that are used with the render pass.
[$sel:vkFramebuffer:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> VkFramebuffer
-- | renderArea is the render area that is affected by the render
-- pass instance, and is described in more detail below.
[$sel:vkRenderArea:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> VkRect2D
-- | clearValueCount is the number of elements in
-- pClearValues.
[$sel:vkClearValueCount:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> Word32
-- | pClearValues is an array of VkClearValue structures
-- that contains clear values for each attachment, if the attachment uses
-- a loadOp value of VK_ATTACHMENT_LOAD_OP_CLEAR or if
-- the attachment has a depth/stencil format and uses a
-- stencilLoadOp value of VK_ATTACHMENT_LOAD_OP_CLEAR.
-- The array is indexed by attachment number. Only elements corresponding
-- to cleared attachments are used. Other elements of
-- pClearValues are ignored.
[$sel:vkPClearValues:VkRenderPassBeginInfo] :: VkRenderPassBeginInfo -> Ptr VkClearValue
-- | VkClearDepthStencilValue - Structure specifying a clear depth stencil
-- value
--
-- Description
--
-- Valid Usage
--
--
-- - Unless the
-- {html_spec_relative}#VK_EXT_depth_range_unrestricted
-- extension is enabled depth must be between
-- 0.0 and 1.0, inclusive
--
--
-- See Also
--
-- VkClearValue, vkCmdClearDepthStencilImage
data VkClearDepthStencilValue
VkClearDepthStencilValue :: CFloat -> Word32 -> VkClearDepthStencilValue
-- | depth is the clear value for the depth aspect of the
-- depth/stencil attachment. It is a floating-point value which is
-- automatically converted to the attachment’s format.
[$sel:vkDepth:VkClearDepthStencilValue] :: VkClearDepthStencilValue -> CFloat
-- | stencil is the clear value for the stencil aspect of the
-- depth/stencil attachment. It is a 32-bit integer value which is
-- converted to the attachment’s format by taking the appropriate number
-- of LSBs.
[$sel:vkStencil:VkClearDepthStencilValue] :: VkClearDepthStencilValue -> Word32
-- | VkClearAttachment - Structure specifying a clear attachment
--
-- Description
--
-- No memory barriers are needed between vkCmdClearAttachments
-- and preceding or subsequent draw or attachment clear commands in the
-- same subpass.
--
-- The vkCmdClearAttachments command is not affected by the
-- bound pipeline state.
--
-- Attachments can also be cleared at the beginning of a render
-- pass instance by setting loadOp (or stencilLoadOp)
-- of VkAttachmentDescription to
-- VK_ATTACHMENT_LOAD_OP_CLEAR, as described for
-- vkCreateRenderPass.
--
-- Valid Usage
--
--
-- - If aspectMask includes
-- VK_IMAGE_ASPECT_COLOR_BIT, it must not include
-- VK_IMAGE_ASPECT_DEPTH_BIT or
-- VK_IMAGE_ASPECT_STENCIL_BIT
--
--
--
-- - aspectMask must not include
-- VK_IMAGE_ASPECT_METADATA_BIT
-- - clearValue must be a valid VkClearValue
-- union
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - aspectMask must not be 0
--
--
-- See Also
--
-- VkClearValue, VkImageAspectFlags,
-- vkCmdClearAttachments
data VkClearAttachment
VkClearAttachment :: VkImageAspectFlags -> Word32 -> VkClearValue -> VkClearAttachment
-- | aspectMask is a mask selecting the color, depth and/or
-- stencil aspects of the attachment to be cleared. aspectMask
-- can include VK_IMAGE_ASPECT_COLOR_BIT for color
-- attachments, VK_IMAGE_ASPECT_DEPTH_BIT for depth/stencil
-- attachments with a depth component, and
-- VK_IMAGE_ASPECT_STENCIL_BIT for depth/stencil attachments
-- with a stencil component. If the subpass’s depth/stencil attachment is
-- VK_ATTACHMENT_UNUSED, then the clear has no effect.
[$sel:vkAspectMask:VkClearAttachment] :: VkClearAttachment -> VkImageAspectFlags
-- | colorAttachment is only meaningful if
-- VK_IMAGE_ASPECT_COLOR_BIT is set in aspectMask, in
-- which case it is an index to the pColorAttachments array in
-- the VkSubpassDescription structure of the current subpass which
-- selects the color attachment to clear. If colorAttachment is
-- VK_ATTACHMENT_UNUSED then the clear has no effect.
[$sel:vkColorAttachment:VkClearAttachment] :: VkClearAttachment -> Word32
-- | clearValue is the color or depth/stencil value to clear the
-- attachment to, as described in Clear Values below.
[$sel:vkClearValue:VkClearAttachment] :: VkClearAttachment -> VkClearValue
-- | VkDrawIndirectCommand - Structure specifying a draw indirect command
--
-- Description
--
-- The members of VkDrawIndirectCommand have the same meaning as
-- the similarly named parameters of vkCmdDraw.
--
-- Valid Usage
--
--
-- - For a given vertex buffer binding, any attribute data fetched
-- must be entirely contained within the corresponding vertex
-- buffer binding, as described in
-- {html_spec_relative}#fxvertex-input
--
--
--
--
-- See Also
--
-- vkCmdDrawIndirect
data VkDrawIndirectCommand
VkDrawIndirectCommand :: Word32 -> Word32 -> Word32 -> Word32 -> VkDrawIndirectCommand
-- | vertexCount is the number of vertices to draw.
[$sel:vkVertexCount:VkDrawIndirectCommand] :: VkDrawIndirectCommand -> Word32
-- | instanceCount is the number of instances to draw.
[$sel:vkInstanceCount:VkDrawIndirectCommand] :: VkDrawIndirectCommand -> Word32
-- | firstVertex is the index of the first vertex to draw.
[$sel:vkFirstVertex:VkDrawIndirectCommand] :: VkDrawIndirectCommand -> Word32
-- | firstInstance is the instance ID of the first instance to
-- draw.
[$sel:vkFirstInstance:VkDrawIndirectCommand] :: VkDrawIndirectCommand -> Word32
-- | VkDrawIndexedIndirectCommand - Structure specifying a draw indexed
-- indirect command
--
-- Description
--
-- The members of VkDrawIndexedIndirectCommand have the same
-- meaning as the similarly named parameters of vkCmdDrawIndexed.
--
-- Valid Usage
--
--
-- - For a given vertex buffer binding, any attribute data fetched
-- must be entirely contained within the corresponding vertex
-- buffer binding, as described in
-- {html_spec_relative}#fxvertex-input
--
--
--
-- - (indexSize * (firstIndex + indexCount)
-- + offset) must be less than or equal to the size of
-- the bound index buffer, with indexSize being based on the
-- type specified by indexType, where the index buffer,
-- indexType, and offset are specified via
-- vkCmdBindIndexBuffer
-- - If the drawIndirectFirstInstance feature is not enabled,
-- firstInstance must be 0
--
--
-- See Also
--
-- vkCmdDrawIndexedIndirect
data VkDrawIndexedIndirectCommand
VkDrawIndexedIndirectCommand :: Word32 -> Word32 -> Word32 -> Int32 -> Word32 -> VkDrawIndexedIndirectCommand
-- | indexCount is the number of vertices to draw.
[$sel:vkIndexCount:VkDrawIndexedIndirectCommand] :: VkDrawIndexedIndirectCommand -> Word32
-- | instanceCount is the number of instances to draw.
[$sel:vkInstanceCount:VkDrawIndexedIndirectCommand] :: VkDrawIndexedIndirectCommand -> Word32
-- | firstIndex is the base index within the index buffer.
[$sel:vkFirstIndex:VkDrawIndexedIndirectCommand] :: VkDrawIndexedIndirectCommand -> Word32
-- | vertexOffset is the value added to the vertex index before
-- indexing into the vertex buffer.
[$sel:vkVertexOffset:VkDrawIndexedIndirectCommand] :: VkDrawIndexedIndirectCommand -> Int32
-- | firstInstance is the instance ID of the first instance to
-- draw.
[$sel:vkFirstInstance:VkDrawIndexedIndirectCommand] :: VkDrawIndexedIndirectCommand -> Word32
-- | VkDispatchIndirectCommand - Structure specifying a dispatch indirect
-- command
--
-- Description
--
-- The members of VkDispatchIndirectCommand have the same
-- meaning as the corresponding parameters of vkCmdDispatch.
--
-- Valid Usage
--
--
-- - x must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[0]
--
--
--
-- - y must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[1]
-- - z must be less than or equal to
-- VkPhysicalDeviceLimits::maxComputeWorkGroupCount[2]
--
--
-- See Also
--
-- vkCmdDispatchIndirect
data VkDispatchIndirectCommand
VkDispatchIndirectCommand :: Word32 -> Word32 -> Word32 -> VkDispatchIndirectCommand
-- | x is the number of local workgroups to dispatch in the X
-- dimension.
[$sel:vkX:VkDispatchIndirectCommand] :: VkDispatchIndirectCommand -> Word32
-- | y is the number of local workgroups to dispatch in the Y
-- dimension.
[$sel:vkY:VkDispatchIndirectCommand] :: VkDispatchIndirectCommand -> Word32
-- | z is the number of local workgroups to dispatch in the Z
-- dimension.
[$sel:vkZ:VkDispatchIndirectCommand] :: VkDispatchIndirectCommand -> Word32
-- | VkClearColorValue - Structure specifying a clear color value
--
-- Description
--
-- The four array elements of the clear color map to R, G, B, and A
-- components of image formats, in order.
--
-- If the image has more than one sample, the same value is written to
-- all samples for any pixels being cleared.
--
-- See Also
--
-- VkClearValue, vkCmdClearColorImage
data VkClearColorValue
VkFloat32 :: (Vector 4 CFloat) -> VkClearColorValue
VkInt32 :: (Vector 4 Int32) -> VkClearColorValue
VkUint32 :: (Vector 4 Word32) -> VkClearColorValue
-- | VkClearValue - Structure specifying a clear value
--
-- Description
--
-- This union is used where part of the API requires either color or
-- depth/stencil clear values, depending on the attachment, and defines
-- the initial clear values in the VkRenderPassBeginInfo
-- structure.
--
-- Valid Usage
--
--
-- - depthStencil must be a valid
-- VkClearDepthStencilValue structure
--
--
-- See Also
--
-- VkClearAttachment, VkClearColorValue,
-- VkClearDepthStencilValue, VkRenderPassBeginInfo
data VkClearValue
VkColor :: VkClearColorValue -> VkClearValue
VkDepthStencil :: VkClearDepthStencilValue -> VkClearValue
-- | VkStencilFaceFlags - Bitmask of VkStencilFaceFlagBits
--
-- Description
--
-- VkStencilFaceFlags is a bitmask type for setting a mask of
-- zero or more VkStencilFaceFlagBits.
--
-- See Also
--
-- VkStencilFaceFlagBits, vkCmdSetStencilCompareMask,
-- vkCmdSetStencilReference, vkCmdSetStencilWriteMask
type VkStencilFaceFlags = VkStencilFaceFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkRenderPassBeginInfo
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkRenderPassBeginInfo
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearAttachment
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearAttachment
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearValue
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearValue
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearColorValue
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearColorValue
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkDispatchIndirectCommand
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkDispatchIndirectCommand
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndexedIndirectCommand
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndexedIndirectCommand
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndirectCommand
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndirectCommand
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearDepthStencilValue
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearDepthStencilValue
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageResolve
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageResolve
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferImageCopy
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferImageCopy
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageBlit
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageBlit
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageCopy
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageCopy
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferCopy
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferCopy
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageMemoryBarrier
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageMemoryBarrier
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferMemoryBarrier
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferMemoryBarrier
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkMemoryBarrier
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkMemoryBarrier
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageSubresourceLayers
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageSubresourceLayers
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearRect
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearRect
instance Data.Bits.FiniteBits Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance Data.Bits.Bits Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkSubpassContents
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBufferBuilding.VkSubpassContents
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkSubpassContents
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkIndexType
instance GHC.Classes.Ord Graphics.Vulkan.Core10.CommandBufferBuilding.VkIndexType
instance GHC.Classes.Eq Graphics.Vulkan.Core10.CommandBufferBuilding.VkIndexType
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkRenderPassBeginInfo
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearAttachment
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearValue
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearColorValue
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkDispatchIndirectCommand
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndexedIndirectCommand
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkDrawIndirectCommand
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearDepthStencilValue
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageResolve
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferImageCopy
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageBlit
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageCopy
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferCopy
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageMemoryBarrier
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkBufferMemoryBarrier
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkMemoryBarrier
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkImageSubresourceLayers
instance Foreign.Storable.Storable Graphics.Vulkan.Core10.CommandBufferBuilding.VkClearRect
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBufferBuilding.VkStencilFaceFlagBits
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkSubpassContents
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBufferBuilding.VkSubpassContents
instance GHC.Show.Show Graphics.Vulkan.Core10.CommandBufferBuilding.VkIndexType
instance GHC.Read.Read Graphics.Vulkan.Core10.CommandBufferBuilding.VkIndexType
module Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands
-- | VkIndirectCommandsTokenTypeNVX - Enum specifying
--
-- Description
--
--
-- +-----------------------------------------------+----------------------+
-- | Token type | Equivalent command |
-- +===============================================+======================+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX | @vkCmdBindPipeline@ |
-- | @ | |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_DESCRIPTOR_S | @vkCmdBindDescriptor |
-- | ET_NVX@ | Sets@ |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_INDEX_BUFFER | @vkCmdBindIndexBuffe |
-- | _NVX@ | r@ |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_VERTEX_BUFFE | @vkCmdBindVertexBuff |
-- | R_NVX@ | ers@ |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_PUSH_CONSTAN | @vkCmdPushConstants@ |
-- | T_NVX@ | |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED | @vkCmdDrawIndexedInd |
-- | _NVX@ | irect@ |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX@ | @vkCmdDrawIndirect@ |
-- +-----------------------------------------------+----------------------+
-- | @VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX | @vkCmdDispatchIndire |
-- | @ | ct@ |
-- +-----------------------------------------------+----------------------+
--
-- Supported indirect command tokens
--
--
-- See Also
--
-- VkIndirectCommandsLayoutTokenNVX,
-- VkIndirectCommandsTokenNVX
newtype VkIndirectCommandsTokenTypeNVX
VkIndirectCommandsTokenTypeNVX :: Int32 -> VkIndirectCommandsTokenTypeNVX
-- | VkObjectEntryTypeNVX - Enum specifying object table entry type
--
-- See Also
--
-- VkObjectTableCreateInfoNVX,
-- VkObjectTableDescriptorSetEntryNVX,
-- VkObjectTableEntryNVX, VkObjectTableIndexBufferEntryNVX,
-- VkObjectTablePipelineEntryNVX,
-- VkObjectTablePushConstantEntryNVX,
-- VkObjectTableVertexBufferEntryNVX,
-- vkUnregisterObjectsNVX
newtype VkObjectEntryTypeNVX
VkObjectEntryTypeNVX :: Int32 -> VkObjectEntryTypeNVX
-- | VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX specifies a
-- VkDescriptorSet resource entry that is registered via
-- VkObjectTableDescriptorSetEntryNVX.
-- | VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX specifies a
-- VkPipeline resource entry that is registered via
-- VkObjectTablePipelineEntryNVX.
-- | VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX specifies a
-- VkBuffer resource entry that is registered via
-- VkObjectTableIndexBufferEntryNVX.
-- | VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX specifies a
-- VkBuffer resource entry that is registered via
-- VkObjectTableVertexBufferEntryNVX.
-- | VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX specifies the resource
-- entry is registered via VkObjectTablePushConstantEntryNVX.
-- | VkIndirectCommandsLayoutUsageFlagBitsNVX - Bitmask specifying allowed
-- usage of a indirect commands layout
--
-- See Also
--
-- VkIndirectCommandsLayoutUsageFlagsNVX
newtype VkIndirectCommandsLayoutUsageFlagBitsNVX
VkIndirectCommandsLayoutUsageFlagBitsNVX :: VkFlags -> VkIndirectCommandsLayoutUsageFlagBitsNVX
-- | VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX
-- specifies that the processing of sequences can happen at an
-- implementation-dependent order, which is not guaranteed to be coherent
-- across multiple invocations.
-- | VK_INDIRECT_COMMANDS_LAYOUT_USAGE_SPARSE_SEQUENCES_BIT_NVX
-- specifies that there is likely a high difference between allocated
-- number of sequences and actually used.
-- | VK_INDIRECT_COMMANDS_LAYOUT_USAGE_EMPTY_EXECUTIONS_BIT_NVX
-- specifies that there are likely many draw or dispatch calls that are
-- zero-sized (zero grid dimension, no primitives to render).
-- | VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX
-- specifies that the input data for the sequences is not implicitly
-- indexed from 0..sequencesUsed but a user provided VkBuffer
-- encoding the index is provided.
-- | VkObjectEntryUsageFlagBitsNVX - Bitmask specifying allowed usage of an
-- object entry
--
-- See Also
--
-- VkObjectEntryUsageFlagsNVX
newtype VkObjectEntryUsageFlagBitsNVX
VkObjectEntryUsageFlagBitsNVX :: VkFlags -> VkObjectEntryUsageFlagBitsNVX
-- | VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX specifies that the
-- resource is bound to VK_PIPELINE_BIND_POINT_GRAPHICS
-- | VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX specifies that the
-- resource is bound to VK_PIPELINE_BIND_POINT_COMPUTE
-- | VkObjectTableNVX - Opaque handle to an object table
--
-- Description
--
-- See Also
--
-- VkCmdProcessCommandsInfoNVX,
-- VkCmdReserveSpaceForCommandsInfoNVX,
-- vkCreateObjectTableNVX, vkDestroyObjectTableNVX,
-- vkRegisterObjectsNVX, vkUnregisterObjectsNVX
type VkObjectTableNVX = Ptr VkObjectTableNVX_T
-- | VkIndirectCommandsLayoutNVX - Opaque handle to an indirect commands
-- layout object
--
-- Description
--
-- See Also
--
-- VkCmdProcessCommandsInfoNVX,
-- VkCmdReserveSpaceForCommandsInfoNVX,
-- vkCreateIndirectCommandsLayoutNVX,
-- vkDestroyIndirectCommandsLayoutNVX
type VkIndirectCommandsLayoutNVX = Ptr VkIndirectCommandsLayoutNVX_T
-- | vkCmdProcessCommandsNVX - Performs the generation of commands on the
-- device
--
-- Parameters
--
--
-- - commandBuffer is the primary command buffer in which the
-- generation process takes space.
--
--
--
-- - pProcessCommandsInfo is a pointer to an instance of the
-- VkCmdProcessCommandsInfoNVX structure containing parameters
-- affecting the processing of commands.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pProcessCommandsInfo must be a valid pointer to a
-- valid VkCmdProcessCommandsInfoNVX structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called inside of a render pass
-- instance
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Primary | Inside | Graphics | |
-- | Secondary | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCmdProcessCommandsInfoNVX, VkCommandBuffer
vkCmdProcessCommandsNVX :: ("commandBuffer" ::: VkCommandBuffer) -> ("pProcessCommandsInfo" ::: Ptr VkCmdProcessCommandsInfoNVX) -> IO ()
-- | vkCmdReserveSpaceForCommandsNVX - Perform a reservation of command
-- buffer space
--
-- Parameters
--
--
-- - commandBuffer is the secondary command buffer in which
-- the space for device-generated commands is reserved.
--
--
--
-- - pProcessCommandsInfo is a pointer to an instance of the
-- vkCmdReserveSpaceForCommandsNVX structure containing parameters
-- affecting the reservation of command buffer space.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The provided commandBuffer must not have had a
-- prior space reservation since its creation or the last reset.
--
--
--
-- - The state of the commandBuffer must be legal to
-- execute all commands within the sequence provided by the
-- indirectCommandsLayout member of
-- pProcessCommandsInfo.
--
--
-- Valid Usage (Implicit)
--
--
-- - commandBuffer must be a valid
-- VkCommandBuffer handle
--
--
--
-- - pReserveSpaceInfo must be a valid pointer to a
-- valid VkCmdReserveSpaceForCommandsInfoNVX structure
-- - commandBuffer must be in the recording
-- state
-- - The VkCommandPool that commandBuffer was
-- allocated from must support graphics, or compute
-- operations
-- - This command must only be called inside of a render pass
-- instance
-- - commandBuffer must be a secondary
-- VkCommandBuffer
--
--
-- Host Synchronization
--
--
-- - Host access to commandBuffer must be externally
-- synchronized
--
--
--
-- - Host access to the VkCommandPool that
-- commandBuffer was allocated from must be externally
-- synchronized
--
--
-- Command Properties
--
--
-- +-----------------+-----------------+-----------------+-----------------+
-- | <#VkCommandBuff | <#vkCmdBeginRen | <#VkQueueFlagBi | <#synchronizati |
-- | erLevel Command | derPass Render | ts Supported Qu | on-pipeline-sta |
-- | Buffer Levels> | Pass Scope> | eue Types> | ges-types Pipel |
-- | | | | ine Type> |
-- +=================+=================+=================+=================+
-- | Secondary | Inside | Graphics | |
-- | | | Compute | |
-- +-----------------+-----------------+-----------------+-----------------+
--
--
-- See Also
--
-- VkCmdReserveSpaceForCommandsInfoNVX, VkCommandBuffer
vkCmdReserveSpaceForCommandsNVX :: ("commandBuffer" ::: VkCommandBuffer) -> ("pReserveSpaceInfo" ::: Ptr VkCmdReserveSpaceForCommandsInfoNVX) -> IO ()
-- | vkCreateIndirectCommandsLayoutNVX - Create an indirect command layout
-- object
--
-- Parameters
--
--
-- - device is the logical device that creates the indirect
-- command layout.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkIndirectCommandsLayoutCreateInfoNVX structure containing
-- parameters affecting creation of the indirect command layout.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pIndirectCommandsLayout points to a
-- VkIndirectCommandsLayoutNVX handle in which the resulting
-- indirect command layout is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkIndirectCommandsLayoutCreateInfoNVX structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pIndirectCommandsLayout must be a valid pointer to
-- a VkIndirectCommandsLayoutNVX handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkIndirectCommandsLayoutCreateInfoNVX,
-- VkIndirectCommandsLayoutNVX
vkCreateIndirectCommandsLayoutNVX :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkIndirectCommandsLayoutCreateInfoNVX) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pIndirectCommandsLayout" ::: Ptr VkIndirectCommandsLayoutNVX) -> IO VkResult
-- | vkDestroyIndirectCommandsLayoutNVX - Destroy a object table
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- layout.
--
--
--
-- - indirectCommandsLayout is the table to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to
-- indirectCommandsLayout must have completed
-- execution
--
--
--
-- - If VkAllocationCallbacks were provided when
-- objectTable was created, a compatible set of callbacks
-- must be provided here
-- - If no VkAllocationCallbacks were provided when
-- objectTable was created, pAllocator must be
-- NULL
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - indirectCommandsLayout must be a valid
-- VkIndirectCommandsLayoutNVX handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - indirectCommandsLayout must have been created,
-- allocated, or retrieved from device
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkIndirectCommandsLayoutNVX
vkDestroyIndirectCommandsLayoutNVX :: ("device" ::: VkDevice) -> ("indirectCommandsLayout" ::: VkIndirectCommandsLayoutNVX) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkCreateObjectTableNVX - Create an object table
--
-- Parameters
--
--
-- - device is the logical device that creates the object
-- table.
--
--
--
-- - pCreateInfo is a pointer to an instance of the
-- VkObjectTableCreateInfoNVX structure containing parameters
-- affecting creation of the table.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
-- - pObjectTable points to a VkObjectTableNVX handle
-- in which the resulting object table is returned.
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - pCreateInfo must be a valid pointer to a valid
-- VkObjectTableCreateInfoNVX structure
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - pObjectTable must be a valid pointer to a
-- VkObjectTableNVX handle
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice,
-- VkObjectTableCreateInfoNVX, VkObjectTableNVX
vkCreateObjectTableNVX :: ("device" ::: VkDevice) -> ("pCreateInfo" ::: Ptr VkObjectTableCreateInfoNVX) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> ("pObjectTable" ::: Ptr VkObjectTableNVX) -> IO VkResult
-- | vkDestroyObjectTableNVX - Destroy a object table
--
-- Parameters
--
--
-- - device is the logical device that destroys the
-- table.
--
--
--
-- - objectTable is the table to destroy.
-- - pAllocator controls host memory allocation as described
-- in the Memory Allocation chapter.
--
--
-- Description
--
-- Valid Usage
--
--
-- - All submitted commands that refer to objectTable
-- must have completed execution.
--
--
--
-- - If VkAllocationCallbacks were provided when
-- objectTable was created, a compatible set of callbacks
-- must be provided here.
-- - If no VkAllocationCallbacks were provided when
-- objectTable was created, pAllocator must be
-- NULL.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - objectTable must be a valid
-- VkObjectTableNVX handle
-- - If pAllocator is not NULL, pAllocator
-- must be a valid pointer to a valid
-- VkAllocationCallbacks structure
-- - objectTable must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to objectTable must be externally
-- synchronized
--
--
-- See Also
--
-- VkAllocationCallbacks, VkDevice, VkObjectTableNVX
vkDestroyObjectTableNVX :: ("device" ::: VkDevice) -> ("objectTable" ::: VkObjectTableNVX) -> ("pAllocator" ::: Ptr VkAllocationCallbacks) -> IO ()
-- | vkRegisterObjectsNVX - Register resource bindings in an object table
--
-- Parameters
--
--
-- - device is the logical device that creates the object
-- table.
--
--
--
-- - objectTable is the table for which the resources are
-- registered.
-- - objectCount is the number of resources to register.
-- - ppObjectTableEntries provides an array for detailed
-- binding informations, each array element is a pointer to a struct of
-- type VkObjectTablePipelineEntryNVX,
-- VkObjectTableDescriptorSetEntryNVX,
-- VkObjectTableVertexBufferEntryNVX,
-- VkObjectTableIndexBufferEntryNVX or
-- VkObjectTablePushConstantEntryNVX (see below for
-- details).
-- - pObjectIndices are the indices at which each resource is
-- registered.
--
--
-- Description
--
-- Valid Usage
--
--
-- - The contents of pObjectTableEntry must yield
-- plausible bindings supported by the device.
--
--
--
-- - At any pObjectIndices there must not be a
-- registered resource already.
-- - Any value inside pObjectIndices must be below the
-- appropriate
-- VkObjectTableCreateInfoNVX::pObjectEntryCounts
-- limits provided at objectTable creation time.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - objectTable must be a valid
-- VkObjectTableNVX handle
-- - ppObjectTableEntries must be a valid pointer to an
-- array of objectCount valid VkObjectTableEntryNVX
-- structures
-- - pObjectIndices must be a valid pointer to an array
-- of objectCount uint32_t values
-- - objectCount must be greater than 0
-- - objectTable must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to objectTable must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkObjectTableEntryNVX, VkObjectTableNVX
vkRegisterObjectsNVX :: ("device" ::: VkDevice) -> ("objectTable" ::: VkObjectTableNVX) -> ("objectCount" ::: Word32) -> ("ppObjectTableEntries" ::: Ptr (Ptr VkObjectTableEntryNVX)) -> ("pObjectIndices" ::: Ptr Word32) -> IO VkResult
-- | vkUnregisterObjectsNVX - Unregister resource bindings in an object
-- table
--
-- Parameters
--
--
-- - device is the logical device that creates the object
-- table.
--
--
--
-- - objectTable is the table from which the resources are
-- unregistered.
-- - objectCount is the number of resources being removed from
-- the object table.
-- - pObjectEntryType provides an array of
-- VkObjectEntryTypeNVX for the resources being removed.
-- - pObjectIndices provides the array of object indices to be
-- removed.
--
--
-- Description
--
-- Valid Usage
--
--
-- - At any pObjectIndices there must be a registered
-- resource already.
--
--
--
-- - The pObjectEntryTypes of the resource at
-- pObjectIndices must match.
-- - All operations on the device using the registered resource
-- must have been completed.
--
--
-- Valid Usage (Implicit)
--
--
-- - device must be a valid VkDevice
-- handle
--
--
--
-- - objectTable must be a valid
-- VkObjectTableNVX handle
-- - pObjectEntryTypes must be a valid pointer to an
-- array of objectCount valid VkObjectEntryTypeNVX
-- values
-- - pObjectIndices must be a valid pointer to an array
-- of objectCount uint32_t values
-- - objectCount must be greater than 0
-- - objectTable must have been created, allocated, or
-- retrieved from device
--
--
-- Host Synchronization
--
--
-- - Host access to objectTable must be externally
-- synchronized
--
--
-- Return Codes
--
--
--
--
-- - Failure -
-- VK_ERROR_OUT_OF_HOST_MEMORY
--
--
-- See Also
--
-- VkDevice, VkObjectEntryTypeNVX, VkObjectTableNVX
vkUnregisterObjectsNVX :: ("device" ::: VkDevice) -> ("objectTable" ::: VkObjectTableNVX) -> ("objectCount" ::: Word32) -> ("pObjectEntryTypes" ::: Ptr VkObjectEntryTypeNVX) -> ("pObjectIndices" ::: Ptr Word32) -> IO VkResult
-- | vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX - Returns
-- device-generated commands related properties of a physical device
--
-- Parameters
--
--
-- - physicalDevice is the handle to the physical device whose
-- properties will be queried.
--
--
--
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - physicalDevice must be a valid
-- VkPhysicalDevice handle
--
--
--
-- - pFeatures must be a valid pointer to a
-- VkDeviceGeneratedCommandsFeaturesNVX structure
-- - pLimits must be a valid pointer to a
-- VkDeviceGeneratedCommandsLimitsNVX structure
--
--
-- See Also
--
-- VkDeviceGeneratedCommandsFeaturesNVX,
-- VkDeviceGeneratedCommandsLimitsNVX, VkPhysicalDevice
vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX :: ("physicalDevice" ::: VkPhysicalDevice) -> ("pFeatures" ::: Ptr VkDeviceGeneratedCommandsFeaturesNVX) -> ("pLimits" ::: Ptr VkDeviceGeneratedCommandsLimitsNVX) -> IO ()
-- | VkDeviceGeneratedCommandsFeaturesNVX - Structure specifying physical
-- device support
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_FEATURES_NVX
--
--
--
--
-- See Also
--
-- VkBool32, VkStructureType,
-- vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX
data VkDeviceGeneratedCommandsFeaturesNVX
VkDeviceGeneratedCommandsFeaturesNVX :: VkStructureType -> Ptr () -> VkBool32 -> VkDeviceGeneratedCommandsFeaturesNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGeneratedCommandsFeaturesNVX] :: VkDeviceGeneratedCommandsFeaturesNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGeneratedCommandsFeaturesNVX] :: VkDeviceGeneratedCommandsFeaturesNVX -> Ptr ()
-- | computeBindingPointSupport specifies whether the
-- VkObjectTableNVX supports entries with
-- VK_OBJECT_ENTRY_USAGE_GRAPHICS_BIT_NVX bit set and
-- VkIndirectCommandsLayoutNVX supports
-- VK_PIPELINE_BIND_POINT_COMPUTE.
[$sel:vkComputeBindingPointSupport:VkDeviceGeneratedCommandsFeaturesNVX] :: VkDeviceGeneratedCommandsFeaturesNVX -> VkBool32
-- | VkDeviceGeneratedCommandsLimitsNVX - Structure specifying physical
-- device limits
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_DEVICE_GENERATED_COMMANDS_LIMITS_NVX
--
--
--
--
-- See Also
--
-- VkStructureType,
-- vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX
data VkDeviceGeneratedCommandsLimitsNVX
VkDeviceGeneratedCommandsLimitsNVX :: VkStructureType -> Ptr () -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> VkDeviceGeneratedCommandsLimitsNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Ptr ()
-- | maxIndirectCommandsLayoutTokenCount the maximum number of
-- tokens in VkIndirectCommandsLayoutNVX.
[$sel:vkMaxIndirectCommandsLayoutTokenCount:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Word32
-- | maxObjectEntryCounts the maximum number of entries per
-- resource type in VkObjectTableNVX.
[$sel:vkMaxObjectEntryCounts:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Word32
-- | minSequenceCountBufferOffsetAlignment the minimum alignment
-- for memory addresses optionally used in
-- vkCmdProcessCommandsNVX.
[$sel:vkMinSequenceCountBufferOffsetAlignment:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Word32
-- | minSequenceIndexBufferOffsetAlignment the minimum alignment
-- for memory addresses optionally used in
-- vkCmdProcessCommandsNVX.
[$sel:vkMinSequenceIndexBufferOffsetAlignment:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Word32
-- | minCommandsTokenBufferOffsetAlignment the minimum alignment
-- for memory addresses optionally used in
-- vkCmdProcessCommandsNVX.
[$sel:vkMinCommandsTokenBufferOffsetAlignment:VkDeviceGeneratedCommandsLimitsNVX] :: VkDeviceGeneratedCommandsLimitsNVX -> Word32
-- | VkIndirectCommandsTokenNVX - Structure specifying parameters for the
-- reservation of command buffer space
--
-- Description
--
-- Valid Usage
--
--
-- - The buffer’s usage flag must have the
-- VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit set.
--
--
--
-- - The offset must be aligned to
-- VkDeviceGeneratedCommandsLimitsNVX::minCommandsTokenBufferOffsetAlignment.
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - buffer must be a valid VkBuffer
-- handle
--
--
-- See Also
--
-- VkBuffer, VkCmdProcessCommandsInfoNVX,
-- VkDeviceSize, VkIndirectCommandsTokenTypeNVX
data VkIndirectCommandsTokenNVX
VkIndirectCommandsTokenNVX :: VkIndirectCommandsTokenTypeNVX -> VkBuffer -> VkDeviceSize -> VkIndirectCommandsTokenNVX
-- | tokenType specifies the token command type.
[$sel:vkTokenType:VkIndirectCommandsTokenNVX] :: VkIndirectCommandsTokenNVX -> VkIndirectCommandsTokenTypeNVX
-- | buffer specifies the VkBuffer storing the functional
-- arguments for each squence. These argumetns can be written by the
-- device.
[$sel:vkBuffer:VkIndirectCommandsTokenNVX] :: VkIndirectCommandsTokenNVX -> VkBuffer
-- | offset specified an offset into buffer where the
-- arguments start.
[$sel:vkOffset:VkIndirectCommandsTokenNVX] :: VkIndirectCommandsTokenNVX -> VkDeviceSize
-- | VkIndirectCommandsLayoutTokenNVX - Struct specifying the details of an
-- indirect command layout token
--
-- Description
--
-- Valid Usage
--
--
-- - bindingUnit must stay within device supported
-- limits for the appropriate commands.
--
--
--
-- - dynamicCount must stay within device supported
-- limits for the appropriate commands.
-- - divisor must be greater than 0 and a
-- power of two.
--
--
-- Valid Usage (Implicit)
--
--
--
-- See Also
--
-- VkIndirectCommandsLayoutCreateInfoNVX,
-- VkIndirectCommandsTokenTypeNVX
data VkIndirectCommandsLayoutTokenNVX
VkIndirectCommandsLayoutTokenNVX :: VkIndirectCommandsTokenTypeNVX -> Word32 -> Word32 -> Word32 -> VkIndirectCommandsLayoutTokenNVX
[$sel:vkTokenType:VkIndirectCommandsLayoutTokenNVX] :: VkIndirectCommandsLayoutTokenNVX -> VkIndirectCommandsTokenTypeNVX
-- | bindingUnit has a different meaning depending on the type,
-- please refer pseudo code further down for details.
[$sel:vkBindingUnit:VkIndirectCommandsLayoutTokenNVX] :: VkIndirectCommandsLayoutTokenNVX -> Word32
-- | dynamicCount has a different meaning depending on the type,
-- please refer pseudo code further down for details.
[$sel:vkDynamicCount:VkIndirectCommandsLayoutTokenNVX] :: VkIndirectCommandsLayoutTokenNVX -> Word32
-- | divisor defines the rate at which the input data buffers are
-- accessed.
[$sel:vkDivisor:VkIndirectCommandsLayoutTokenNVX] :: VkIndirectCommandsLayoutTokenNVX -> Word32
-- | VkIndirectCommandsLayoutCreateInfoNVX - Structure specifying the
-- parameters of a newly created indirect commands layout object
--
-- Description
--
-- The following code illustrates some of the key flags:
--
--
-- void cmdProcessAllSequences(cmd, objectTable, indirectCommandsLayout, pIndirectCommandsTokens, sequencesCount, indexbuffer, indexbufferoffset)
-- {
-- for (s = 0; s < sequencesCount; s++)
-- {
-- sequence = s;
--
-- if (indirectCommandsLayout.flags & VK_INDIRECT_COMMANDS_LAYOUT_USAGE_UNORDERED_SEQUENCES_BIT_NVX) {
-- sequence = incoherent_implementation_dependent_permutation[ sequence ];
-- }
-- if (indirectCommandsLayout.flags & VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT_NVX) {
-- sequence = indexbuffer.load_uint32( sequence * sizeof(uint32_t) + indexbufferoffset);
-- }
--
-- cmdProcessSequence( cmd, objectTable, indirectCommandsLayout, pIndirectCommandsTokens, sequence );
-- }
-- }
--
--
-- Valid Usage
--
--
-- - tokenCount must be greater than 0 and
-- below
-- VkDeviceGeneratedCommandsLimitsNVX::maxIndirectCommandsLayoutTokenCount
--
--
--
-- - If the
-- VkDeviceGeneratedCommandsFeaturesNVX::computeBindingPointSupport
-- feature is not enabled, then pipelineBindPoint must
-- not be VK_PIPELINE_BIND_POINT_COMPUTE
-- - If pTokens contains an entry of
-- VK_INDIRECT_COMMANDS_TOKEN_TYPE_PIPELINE_NVX it must
-- be the first element of the array and there must be only a
-- single element of such token type.
-- - All state binding tokens in pTokens must occur
-- prior work provoking tokens
-- (VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_NVX,
-- VK_INDIRECT_COMMANDS_TOKEN_TYPE_DRAW_INDEXED_NVX,
-- VK_INDIRECT_COMMANDS_TOKEN_TYPE_DISPATCH_NVX).
-- - The content of pTokens must include one single
-- work provoking token that is compatible with the
-- pipelineBindPoint.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_INDIRECT_COMMANDS_LAYOUT_CREATE_INFO_NVX
--
--
--
-- - pNext must be NULL
-- - pipelineBindPoint must be a valid
-- VkPipelineBindPoint value
-- - flags must be a valid combination of
-- VkIndirectCommandsLayoutUsageFlagBitsNVX values
-- - flags must not be 0
-- - pTokens must be a valid pointer to an array of
-- tokenCount valid VkIndirectCommandsLayoutTokenNVX
-- structures
-- - tokenCount must be greater than 0
--
--
-- See Also
--
-- VkIndirectCommandsLayoutTokenNVX,
-- VkIndirectCommandsLayoutUsageFlagsNVX,
-- VkPipelineBindPoint, VkStructureType,
-- vkCreateIndirectCommandsLayoutNVX
data VkIndirectCommandsLayoutCreateInfoNVX
VkIndirectCommandsLayoutCreateInfoNVX :: VkStructureType -> Ptr () -> VkPipelineBindPoint -> VkIndirectCommandsLayoutUsageFlagsNVX -> Word32 -> Ptr VkIndirectCommandsLayoutTokenNVX -> VkIndirectCommandsLayoutCreateInfoNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> Ptr ()
-- | pipelineBindPoint is the VkPipelineBindPoint that
-- this layout targets.
[$sel:vkPipelineBindPoint:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> VkPipelineBindPoint
-- | flags is a bitmask of
-- VkIndirectCommandsLayoutUsageFlagBitsNVX specifying usage hints
-- of this layout.
[$sel:vkFlags:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> VkIndirectCommandsLayoutUsageFlagsNVX
-- | tokenCount is the length of the individual command sequnce.
[$sel:vkTokenCount:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> Word32
-- | pTokens is an array describing each command token in detail.
-- See VkIndirectCommandsTokenTypeNVX and
-- VkIndirectCommandsLayoutTokenNVX below for details.
[$sel:vkPTokens:VkIndirectCommandsLayoutCreateInfoNVX] :: VkIndirectCommandsLayoutCreateInfoNVX -> Ptr VkIndirectCommandsLayoutTokenNVX
-- | VkCmdProcessCommandsInfoNVX - Structure specifying parameters for the
-- generation of commands
--
-- Description
--
-- Valid Usage
--
--
-- - The provided objectTable must include all objects
-- referenced by the generation process.
--
--
--
-- - indirectCommandsTokenCount must match the
-- indirectCommandsLayout’s tokenCount.
-- - The tokenType member of each entry in the
-- pIndirectCommandsTokens array must match the values
-- used at creation time of indirectCommandsLayout
-- - If targetCommandBuffer is provided, it must have
-- reserved command space.
-- - If targetCommandBuffer is provided, the
-- objectTable must match the reservation’s objectTable
-- and must have had all referenced objects registered at
-- reservation time.
-- - If targetCommandBuffer is provided, the
-- indirectCommandsLayout must match the reservation’s
-- indirectCommandsLayout.
-- - If targetCommandBuffer is provided, the
-- maxSequencesCount must not exceed the reservation’s
-- maxSequencesCount.
-- - If sequencesCountBuffer is used, its usage flag
-- must have VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit
-- set.
-- - If sequencesCountBuffer is used,
-- sequencesCountOffset must be aligned to
-- VkDeviceGeneratedCommandsLimitsNVX::minSequenceCountBufferOffsetAlignment.
-- - If sequencesIndexBuffer is used, its usage flag
-- must have VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT bit
-- set.
-- - If sequencesIndexBuffer is used,
-- sequencesIndexOffset must be aligned to
-- VkDeviceGeneratedCommandsLimitsNVX::minSequenceIndexBufferOffsetAlignment.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_CMD_PROCESS_COMMANDS_INFO_NVX
--
--
--
-- - pNext must be NULL
-- - objectTable must be a valid
-- VkObjectTableNVX handle
-- - indirectCommandsLayout must be a valid
-- VkIndirectCommandsLayoutNVX handle
-- - pIndirectCommandsTokens must be a valid pointer to
-- an array of indirectCommandsTokenCount valid
-- VkIndirectCommandsTokenNVX structures
-- - If targetCommandBuffer is not NULL,
-- targetCommandBuffer must be a valid
-- VkCommandBuffer handle
-- - If sequencesCountBuffer is not VK_NULL_HANDLE,
-- sequencesCountBuffer must be a valid VkBuffer
-- handle
-- - If sequencesIndexBuffer is not VK_NULL_HANDLE,
-- sequencesIndexBuffer must be a valid VkBuffer
-- handle
-- - indirectCommandsTokenCount must be greater than
-- 0
-- - Each of indirectCommandsLayout, objectTable,
-- sequencesCountBuffer, sequencesIndexBuffer, and
-- targetCommandBuffer that are valid handles must have
-- been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to objectTable must be externally
-- synchronized
--
--
--
-- - Host access to targetCommandBuffer must be
-- externally synchronized
--
--
-- See Also
--
-- VkBuffer, VkCommandBuffer, VkDeviceSize,
-- VkIndirectCommandsLayoutNVX, VkIndirectCommandsTokenNVX,
-- VkObjectTableNVX, VkStructureType,
-- vkCmdProcessCommandsNVX
data VkCmdProcessCommandsInfoNVX
VkCmdProcessCommandsInfoNVX :: VkStructureType -> Ptr () -> VkObjectTableNVX -> VkIndirectCommandsLayoutNVX -> Word32 -> Ptr VkIndirectCommandsTokenNVX -> Word32 -> VkCommandBuffer -> VkBuffer -> VkDeviceSize -> VkBuffer -> VkDeviceSize -> VkCmdProcessCommandsInfoNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> Ptr ()
-- | objectTable is the VkObjectTableNVX to be used for
-- the generation process. Only registered objects at the time
-- vkCmdReserveSpaceForCommandsNVX is called, will be taken into
-- account for the reservation.
[$sel:vkObjectTable:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkObjectTableNVX
-- | indirectCommandsLayout is the
-- VkIndirectCommandsLayoutNVX that provides the command
-- sequence to generate.
[$sel:vkIndirectCommandsLayout:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkIndirectCommandsLayoutNVX
-- | indirectCommandsTokenCount defines the number of input tokens
-- used.
[$sel:vkIndirectCommandsTokenCount:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> Word32
-- | pIndirectCommandsTokens provides an array of
-- VkIndirectCommandsTokenNVX that reference the input data for
-- each token command.
[$sel:vkPIndirectCommandsTokens:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> Ptr VkIndirectCommandsTokenNVX
-- | maxSequencesCount is the maximum number of sequences for
-- which command buffer space will be reserved. If
-- sequencesCountBuffer is VK_NULL_HANDLE, this is also
-- the actual number of sequences generated.
[$sel:vkMaxSequencesCount:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> Word32
-- | targetCommandBuffer can be the secondary
-- VkCommandBuffer in which the commands should be recorded. If
-- targetCommandBuffer is NULL an implicit reservation
-- as well as execution takes place on the processing
-- VkCommandBuffer.
[$sel:vkTargetCommandBuffer:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkCommandBuffer
-- | sequencesCountBuffer can be VkBuffer from
-- which the actual amount of sequences is sourced from as
-- uint32_t value.
[$sel:vkSequencesCountBuffer:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkBuffer
-- | sequencesCountOffset is the byte offset into
-- sequencesCountBuffer where the count value is stored.
[$sel:vkSequencesCountOffset:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkDeviceSize
-- | sequencesIndexBuffer must be set if
-- indirectCommandsLayout’s
-- VK_INDIRECT_COMMANDS_LAYOUT_USAGE_INDEXED_SEQUENCES_BIT is
-- set and provides the used sequence indices as uint32_t array.
-- Otherwise it must be VK_NULL_HANDLE.
[$sel:vkSequencesIndexBuffer:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkBuffer
-- | sequencesIndexOffset is the byte offset into
-- sequencesIndexBuffer where the index values start.
[$sel:vkSequencesIndexOffset:VkCmdProcessCommandsInfoNVX] :: VkCmdProcessCommandsInfoNVX -> VkDeviceSize
-- | VkCmdReserveSpaceForCommandsInfoNVX - Structure specifying parameters
-- for the reservation of command buffer space
--
-- Description
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_CMD_RESERVE_SPACE_FOR_COMMANDS_INFO_NVX
--
--
--
-- - pNext must be NULL
-- - objectTable must be a valid
-- VkObjectTableNVX handle
-- - indirectCommandsLayout must be a valid
-- VkIndirectCommandsLayoutNVX handle
-- - Both of indirectCommandsLayout, and objectTable
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- Host Synchronization
--
--
-- - Host access to objectTable must be externally
-- synchronized
--
--
-- See Also
--
-- VkIndirectCommandsLayoutNVX, VkObjectTableNVX,
-- VkStructureType, vkCmdReserveSpaceForCommandsNVX
data VkCmdReserveSpaceForCommandsInfoNVX
VkCmdReserveSpaceForCommandsInfoNVX :: VkStructureType -> Ptr () -> VkObjectTableNVX -> VkIndirectCommandsLayoutNVX -> Word32 -> VkCmdReserveSpaceForCommandsInfoNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkCmdReserveSpaceForCommandsInfoNVX] :: VkCmdReserveSpaceForCommandsInfoNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkCmdReserveSpaceForCommandsInfoNVX] :: VkCmdReserveSpaceForCommandsInfoNVX -> Ptr ()
-- | objectTable is the VkObjectTableNVX to be used for
-- the generation process. Only registered objects at the time
-- vkCmdReserveSpaceForCommandsNVX is called, will be taken into
-- account for the reservation.
[$sel:vkObjectTable:VkCmdReserveSpaceForCommandsInfoNVX] :: VkCmdReserveSpaceForCommandsInfoNVX -> VkObjectTableNVX
-- | indirectCommandsLayout is the
-- VkIndirectCommandsLayoutNVX that must also be used at
-- generation time.
[$sel:vkIndirectCommandsLayout:VkCmdReserveSpaceForCommandsInfoNVX] :: VkCmdReserveSpaceForCommandsInfoNVX -> VkIndirectCommandsLayoutNVX
-- | maxSequencesCount is the maximum number of sequences for
-- which command buffer space will be reserved.
[$sel:vkMaxSequencesCount:VkCmdReserveSpaceForCommandsInfoNVX] :: VkCmdReserveSpaceForCommandsInfoNVX -> Word32
-- | VkObjectTableCreateInfoNVX - Structure specifying the parameters of a
-- newly created object table
--
-- Description
--
-- Valid Usage
--
--
-- - If the
-- VkDeviceGeneratedCommandsFeaturesNVX::computeBindingPointSupport
-- feature is not enabled, pObjectEntryUsageFlags must
-- not contain VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX
--
--
--
-- - Any value within pObjectEntryCounts must not
-- exceed
-- VkDeviceGeneratedCommandsLimitsNVX::maxObjectEntryCounts
-- - maxUniformBuffersPerDescriptor must be within the
-- limits supported by the device.
-- - maxStorageBuffersPerDescriptor must be within the
-- limits supported by the device.
-- - maxStorageImagesPerDescriptor must be within the
-- limits supported by the device.
-- - maxSampledImagesPerDescriptor must be within the
-- limits supported by the device.
--
--
-- Valid Usage (Implicit)
--
--
-- - sType must be
-- VK_STRUCTURE_TYPE_OBJECT_TABLE_CREATE_INFO_NVX
--
--
--
-- - pNext must be NULL
-- - pObjectEntryTypes must be a valid pointer to an
-- array of objectCount valid VkObjectEntryTypeNVX
-- values
-- - pObjectEntryCounts must be a valid pointer to an
-- array of objectCount uint32_t values
-- - pObjectEntryUsageFlags must be a valid pointer to
-- an array of objectCount valid combinations of
-- VkObjectEntryUsageFlagBitsNVX values
-- - Each element of pObjectEntryUsageFlags must not be
-- 0
-- - objectCount must be greater than 0
--
--
-- See Also
--
-- VkObjectEntryTypeNVX, VkObjectEntryUsageFlagsNVX,
-- VkStructureType, vkCreateObjectTableNVX
data VkObjectTableCreateInfoNVX
VkObjectTableCreateInfoNVX :: VkStructureType -> Ptr () -> Word32 -> Ptr VkObjectEntryTypeNVX -> Ptr Word32 -> Ptr VkObjectEntryUsageFlagsNVX -> Word32 -> Word32 -> Word32 -> Word32 -> Word32 -> VkObjectTableCreateInfoNVX
-- | sType is the type of this structure.
[$sel:vkSType:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> VkStructureType
-- | pNext is NULL or a pointer to an extension-specific
-- structure.
[$sel:vkPNext:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Ptr ()
-- | objectCount is the number of entry configurations that the
-- object table supports.
[$sel:vkObjectCount:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | pObjectEntryTypes is an array of VkObjectEntryTypeNVX
-- values providing the entry type of a given configuration.
[$sel:vkPObjectEntryTypes:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Ptr VkObjectEntryTypeNVX
-- | pObjectEntryCounts is an array of counts of how many objects
-- can be registered in the table.
[$sel:vkPObjectEntryCounts:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Ptr Word32
-- | pObjectEntryUsageFlags is an array of bitmasks of
-- VkObjectEntryUsageFlagBitsNVX specifying the binding usage of
-- the entry.
[$sel:vkPObjectEntryUsageFlags:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Ptr VkObjectEntryUsageFlagsNVX
-- | maxUniformBuffersPerDescriptor is the maximum number of
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER or
-- VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC used by any single
-- registered VkDescriptorSet in this table.
[$sel:vkMaxUniformBuffersPerDescriptor:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | maxStorageBuffersPerDescriptor is the maximum number of
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER or
-- VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC used by any single
-- registered VkDescriptorSet in this table.
[$sel:vkMaxStorageBuffersPerDescriptor:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | maxStorageImagesPerDescriptor is the maximum number of
-- VK_DESCRIPTOR_TYPE_STORAGE_IMAGE or
-- VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER used by any single
-- registered VkDescriptorSet in this table.
[$sel:vkMaxStorageImagesPerDescriptor:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | maxSampledImagesPerDescriptor is the maximum number of
-- VK_DESCRIPTOR_TYPE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
-- VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER or
-- VK_DESCRIPTOR_TYPE_INPUT_ATTACHMENT used by any single
-- registered VkDescriptorSet in this table.
[$sel:vkMaxSampledImagesPerDescriptor:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | maxPipelineLayouts is the maximum number of unique
-- VkPipelineLayout used by any registered
-- VkDescriptorSet or VkPipeline in this table.
[$sel:vkMaxPipelineLayouts:VkObjectTableCreateInfoNVX] :: VkObjectTableCreateInfoNVX -> Word32
-- | VkObjectTableEntryNVX - Common parameters of an object table resource
-- entry
--
-- Description
--
-- Valid Usage
--
--
-- - If the
-- VkDeviceGeneratedCommandsFeaturesNVX::computeBindingPointSupport
-- feature is not enabled, flags must not contain
-- VK_OBJECT_ENTRY_USAGE_COMPUTE_BIT_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
--
-- See Also
--
-- VkObjectEntryTypeNVX, VkObjectEntryUsageFlagsNVX,
-- vkRegisterObjectsNVX
data VkObjectTableEntryNVX
VkObjectTableEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkObjectTableEntryNVX
-- | type defines the entry type
[$sel:vkType:VkObjectTableEntryNVX] :: VkObjectTableEntryNVX -> VkObjectEntryTypeNVX
-- | flags defines which VkPipelineBindPoint the resource
-- can be used with. Some entry types allow only a single flag to be set.
[$sel:vkFlags:VkObjectTableEntryNVX] :: VkObjectTableEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | VkObjectTablePipelineEntryNVX - Parameters of an object table pipeline
-- entry
--
-- Description
--
-- Valid Usage
--
--
-- - type must be
-- VK_OBJECT_ENTRY_TYPE_PIPELINE_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - flags must be a valid combination of
-- VkObjectEntryUsageFlagBitsNVX values
-- - flags must not be 0
-- - pipeline must be a valid VkPipeline
-- handle
--
--
-- See Also
--
-- VkObjectEntryTypeNVX, VkObjectEntryUsageFlagsNVX,
-- VkPipeline
data VkObjectTablePipelineEntryNVX
VkObjectTablePipelineEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkPipeline -> VkObjectTablePipelineEntryNVX
[$sel:vkType:VkObjectTablePipelineEntryNVX] :: VkObjectTablePipelineEntryNVX -> VkObjectEntryTypeNVX
[$sel:vkFlags:VkObjectTablePipelineEntryNVX] :: VkObjectTablePipelineEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | pipeline specifies the VkPipeline that this resource
-- entry references.
[$sel:vkPipeline:VkObjectTablePipelineEntryNVX] :: VkObjectTablePipelineEntryNVX -> VkPipeline
-- | VkObjectTableDescriptorSetEntryNVX - Parameters of an object table
-- descriptor set entry
--
-- Description
--
-- Valid Usage
--
--
-- - type must be
-- VK_OBJECT_ENTRY_TYPE_DESCRIPTOR_SET_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - flags must be a valid combination of
-- VkObjectEntryUsageFlagBitsNVX values
-- - flags must not be 0
-- - pipelineLayout must be a valid
-- VkPipelineLayout handle
-- - descriptorSet must be a valid
-- VkDescriptorSet handle
-- - Both of descriptorSet, and pipelineLayout
-- must have been created, allocated, or retrieved from the same
-- VkDevice
--
--
-- See Also
--
-- VkDescriptorSet, VkObjectEntryTypeNVX,
-- VkObjectEntryUsageFlagsNVX, VkPipelineLayout
data VkObjectTableDescriptorSetEntryNVX
VkObjectTableDescriptorSetEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkPipelineLayout -> VkDescriptorSet -> VkObjectTableDescriptorSetEntryNVX
[$sel:vkType:VkObjectTableDescriptorSetEntryNVX] :: VkObjectTableDescriptorSetEntryNVX -> VkObjectEntryTypeNVX
[$sel:vkFlags:VkObjectTableDescriptorSetEntryNVX] :: VkObjectTableDescriptorSetEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | pipelineLayout specifies the VkPipelineLayout that
-- the descriptorSet is used with.
[$sel:vkPipelineLayout:VkObjectTableDescriptorSetEntryNVX] :: VkObjectTableDescriptorSetEntryNVX -> VkPipelineLayout
-- | descriptorSet specifies the VkDescriptorSet that can
-- be bound with this entry.
[$sel:vkDescriptorSet:VkObjectTableDescriptorSetEntryNVX] :: VkObjectTableDescriptorSetEntryNVX -> VkDescriptorSet
-- | VkObjectTableVertexBufferEntryNVX - Parameters of an object table
-- vertex buffer entry
--
-- Description
--
-- Valid Usage
--
--
-- - type must be
-- VK_OBJECT_ENTRY_TYPE_VERTEX_BUFFER_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - flags must be a valid combination of
-- VkObjectEntryUsageFlagBitsNVX values
-- - flags must not be 0
-- - buffer must be a valid VkBuffer
-- handle
--
--
-- See Also
--
-- VkBuffer, VkObjectEntryTypeNVX,
-- VkObjectEntryUsageFlagsNVX
data VkObjectTableVertexBufferEntryNVX
VkObjectTableVertexBufferEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkBuffer -> VkObjectTableVertexBufferEntryNVX
[$sel:vkType:VkObjectTableVertexBufferEntryNVX] :: VkObjectTableVertexBufferEntryNVX -> VkObjectEntryTypeNVX
[$sel:vkFlags:VkObjectTableVertexBufferEntryNVX] :: VkObjectTableVertexBufferEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | buffer specifies the VkBuffer that can be bound as
-- vertex bufer
[$sel:vkBuffer:VkObjectTableVertexBufferEntryNVX] :: VkObjectTableVertexBufferEntryNVX -> VkBuffer
-- | VkObjectTableIndexBufferEntryNVX - Parameters of an object table index
-- buffer entry
--
-- Description
--
-- Valid Usage
--
--
-- - type must be
-- VK_OBJECT_ENTRY_TYPE_INDEX_BUFFER_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - flags must be a valid combination of
-- VkObjectEntryUsageFlagBitsNVX values
-- - flags must not be 0
-- - buffer must be a valid VkBuffer
-- handle
-- - indexType must be a valid VkIndexType
-- value
--
--
-- See Also
--
-- VkBuffer, VkIndexType, VkObjectEntryTypeNVX,
-- VkObjectEntryUsageFlagsNVX
data VkObjectTableIndexBufferEntryNVX
VkObjectTableIndexBufferEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkBuffer -> VkIndexType -> VkObjectTableIndexBufferEntryNVX
[$sel:vkType:VkObjectTableIndexBufferEntryNVX] :: VkObjectTableIndexBufferEntryNVX -> VkObjectEntryTypeNVX
[$sel:vkFlags:VkObjectTableIndexBufferEntryNVX] :: VkObjectTableIndexBufferEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | buffer specifies the VkBuffer that can be bound as
-- index buffer
[$sel:vkBuffer:VkObjectTableIndexBufferEntryNVX] :: VkObjectTableIndexBufferEntryNVX -> VkBuffer
-- | indexType specifies the VkIndexType used with this
-- index buffer
[$sel:vkIndexType:VkObjectTableIndexBufferEntryNVX] :: VkObjectTableIndexBufferEntryNVX -> VkIndexType
-- | VkObjectTablePushConstantEntryNVX - Parameters of an object table push
-- constant entry
--
-- Description
--
-- Valid Usage
--
--
-- - type must be
-- VK_OBJECT_ENTRY_TYPE_PUSH_CONSTANT_NVX
--
--
-- Valid Usage (Implicit)
--
--
--
--
-- - flags must be a valid combination of
-- VkObjectEntryUsageFlagBitsNVX values
-- - flags must not be 0
-- - pipelineLayout must be a valid
-- VkPipelineLayout handle
-- - stageFlags must be a valid combination of
-- VkShaderStageFlagBits values
-- - stageFlags must not be 0
--
--
-- See Also
--
-- VkObjectEntryTypeNVX, VkObjectEntryUsageFlagsNVX,
-- VkPipelineLayout, VkShaderStageFlags
data VkObjectTablePushConstantEntryNVX
VkObjectTablePushConstantEntryNVX :: VkObjectEntryTypeNVX -> VkObjectEntryUsageFlagsNVX -> VkPipelineLayout -> VkShaderStageFlags -> VkObjectTablePushConstantEntryNVX
[$sel:vkType:VkObjectTablePushConstantEntryNVX] :: VkObjectTablePushConstantEntryNVX -> VkObjectEntryTypeNVX
[$sel:vkFlags:VkObjectTablePushConstantEntryNVX] :: VkObjectTablePushConstantEntryNVX -> VkObjectEntryUsageFlagsNVX
-- | pipelineLayout specifies the VkPipelineLayout that
-- the pushconstants are used with
[$sel:vkPipelineLayout:VkObjectTablePushConstantEntryNVX] :: VkObjectTablePushConstantEntryNVX -> VkPipelineLayout
-- | stageFlags specifies the VkShaderStageFlags that the
-- pushconstants are used with
[$sel:vkStageFlags:VkObjectTablePushConstantEntryNVX] :: VkObjectTablePushConstantEntryNVX -> VkShaderStageFlags
-- | VkIndirectCommandsLayoutUsageFlagsNVX - Bitmask of
-- VkIndirectCommandsLayoutUsageFlagBitsNVX
--
-- Description
--
-- VkIndirectCommandsLayoutUsageFlagsNVX is a bitmask type for
-- setting a mask of zero or more
-- VkIndirectCommandsLayoutUsageFlagBitsNVX.
--
-- See Also
--
-- VkIndirectCommandsLayoutCreateInfoNVX,
-- VkIndirectCommandsLayoutUsageFlagBitsNVX
type VkIndirectCommandsLayoutUsageFlagsNVX = VkIndirectCommandsLayoutUsageFlagBitsNVX
-- | VkObjectEntryUsageFlagsNVX - Bitmask of VkObjectEntryUsageFlagBitsNVX
--
-- Description
--
-- VkObjectEntryUsageFlagsNVX is a bitmask type for setting a
-- mask of zero or more VkObjectEntryUsageFlagBitsNVX.
--
-- See Also
--
-- VkObjectEntryUsageFlagBitsNVX,
-- VkObjectTableCreateInfoNVX,
-- VkObjectTableDescriptorSetEntryNVX,
-- VkObjectTableEntryNVX, VkObjectTableIndexBufferEntryNVX,
-- VkObjectTablePipelineEntryNVX,
-- VkObjectTablePushConstantEntryNVX,
-- VkObjectTableVertexBufferEntryNVX
type VkObjectEntryUsageFlagsNVX = VkObjectEntryUsageFlagBitsNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableCreateInfoNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableCreateInfoNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePipelineEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePipelineEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableDescriptorSetEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableDescriptorSetEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableVertexBufferEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableVertexBufferEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableIndexBufferEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableIndexBufferEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePushConstantEntryNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePushConstantEntryNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutCreateInfoNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutCreateInfoNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdReserveSpaceForCommandsInfoNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdReserveSpaceForCommandsInfoNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdProcessCommandsInfoNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdProcessCommandsInfoNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutTokenNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutTokenNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsLimitsNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsLimitsNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsFeaturesNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsFeaturesNVX
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance Data.Bits.FiniteBits Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance Data.Bits.Bits Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryTypeNVX
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryTypeNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryTypeNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenTypeNVX
instance GHC.Classes.Ord Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenTypeNVX
instance GHC.Classes.Eq Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenTypeNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableCreateInfoNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePipelineEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableDescriptorSetEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableVertexBufferEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTableIndexBufferEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectTablePushConstantEntryNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutCreateInfoNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdReserveSpaceForCommandsInfoNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkCmdProcessCommandsInfoNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutTokenNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsLimitsNVX
instance Foreign.Storable.Storable Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkDeviceGeneratedCommandsFeaturesNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryUsageFlagBitsNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsLayoutUsageFlagBitsNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryTypeNVX
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkObjectEntryTypeNVX
instance GHC.Show.Show Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenTypeNVX
instance GHC.Read.Read Graphics.Vulkan.Extensions.VK_NVX_device_generated_commands.VkIndirectCommandsTokenTypeNVX
module Graphics.Vulkan.Extensions
module Graphics.Vulkan.Core10
module Graphics.Vulkan