{-# language CPP #-}
-- No documentation found for Chapter "DeviceInitialization"
module Vulkan.Core10.DeviceInitialization  ( createInstance
                                           , withInstance
                                           , destroyInstance
                                           , enumeratePhysicalDevices
                                           , getDeviceProcAddr
                                           , getInstanceProcAddr
                                           , getPhysicalDeviceProperties
                                           , getPhysicalDeviceQueueFamilyProperties
                                           , getPhysicalDeviceMemoryProperties
                                           , getPhysicalDeviceFeatures
                                           , getPhysicalDeviceFormatProperties
                                           , getPhysicalDeviceImageFormatProperties
                                           , PhysicalDeviceProperties(..)
                                           , ApplicationInfo(..)
                                           , InstanceCreateInfo(..)
                                           , QueueFamilyProperties(..)
                                           , PhysicalDeviceMemoryProperties(..)
                                           , MemoryType(..)
                                           , MemoryHeap(..)
                                           , FormatProperties(..)
                                           , ImageFormatProperties(..)
                                           , PhysicalDeviceFeatures(..)
                                           , PhysicalDeviceSparseProperties(..)
                                           , PhysicalDeviceLimits(..)
                                           , Instance(..)
                                           , PhysicalDevice(..)
                                           , AllocationCallbacks(..)
                                           , ImageType(..)
                                           , ImageTiling(..)
                                           , InternalAllocationType(..)
                                           , SystemAllocationScope(..)
                                           , PhysicalDeviceType(..)
                                           , Format(..)
                                           , QueueFlagBits(..)
                                           , QueueFlags
                                           , MemoryPropertyFlagBits(..)
                                           , MemoryPropertyFlags
                                           , MemoryHeapFlagBits(..)
                                           , MemoryHeapFlags
                                           , ImageUsageFlagBits(..)
                                           , ImageUsageFlags
                                           , ImageCreateFlagBits(..)
                                           , ImageCreateFlags
                                           , FormatFeatureFlagBits(..)
                                           , FormatFeatureFlags
                                           , SampleCountFlagBits(..)
                                           , SampleCountFlags
                                           , InstanceCreateFlagBits(..)
                                           , InstanceCreateFlags
                                           , FN_vkInternalAllocationNotification
                                           , PFN_vkInternalAllocationNotification
                                           , FN_vkInternalFreeNotification
                                           , PFN_vkInternalFreeNotification
                                           , FN_vkReallocationFunction
                                           , PFN_vkReallocationFunction
                                           , FN_vkAllocationFunction
                                           , PFN_vkAllocationFunction
                                           , FN_vkFreeFunction
                                           , PFN_vkFreeFunction
                                           , FN_vkVoidFunction
                                           , PFN_vkVoidFunction
                                           ) where

import Vulkan.CStruct.Utils (FixedArray)
import Vulkan.Internal.Utils (traceAroundEvent)
import Control.Exception.Base (bracket)
import Control.Monad (unless)
import Control.Monad.IO.Class (liftIO)
import Data.Typeable (eqT)
import Foreign.Marshal.Alloc (allocaBytes)
import Foreign.Marshal.Alloc (callocBytes)
import Foreign.Marshal.Alloc (free)
import Foreign.Marshal.Utils (maybePeek)
import GHC.Base (when)
import GHC.IO (throwIO)
import Foreign.Ptr (castFunPtr)
import GHC.Ptr (castPtr)
import GHC.Ptr (nullFunPtr)
import Foreign.Ptr (nullPtr)
import Foreign.Ptr (plusPtr)
import Data.ByteString (packCString)
import Data.ByteString (useAsCString)
import Data.Coerce (coerce)
import Control.Monad.Trans.Class (lift)
import Control.Monad.Trans.Cont (evalContT)
import Data.Vector (generateM)
import qualified Data.Vector (imapM_)
import qualified Data.Vector (length)
import Foreign.C.Types (CChar(..))
import Vulkan.CStruct (FromCStruct)
import Vulkan.CStruct (FromCStruct(..))
import Vulkan.CStruct (ToCStruct)
import Vulkan.CStruct (ToCStruct(..))
import Vulkan.Zero (Zero(..))
import Control.Monad.IO.Class (MonadIO)
import Data.Type.Equality ((:~:)(Refl))
import Data.Typeable (Typeable)
import Foreign.C.Types (CChar)
import Foreign.C.Types (CFloat)
import Foreign.C.Types (CFloat(..))
import Foreign.C.Types (CFloat(CFloat))
import Foreign.C.Types (CSize)
import Foreign.C.Types (CSize(..))
import Foreign.C.Types (CSize(CSize))
import Foreign.Storable (Storable)
import Foreign.Storable (Storable(peek))
import Foreign.Storable (Storable(poke))
import qualified Foreign.Storable (Storable(..))
import GHC.Generics (Generic)
import GHC.IO.Exception (IOErrorType(..))
import GHC.IO.Exception (IOException(..))
import Data.Int (Int32)
import Foreign.Ptr (FunPtr)
import Foreign.Ptr (Ptr)
import GHC.Ptr (Ptr(Ptr))
import Data.Word (Word32)
import Data.Word (Word64)
import Data.Word (Word8)
import Data.ByteString (ByteString)
import Data.Kind (Type)
import Control.Monad.Trans.Cont (ContT(..))
import Data.Vector (Vector)
import Vulkan.CStruct.Utils (advancePtrBytes)
import Vulkan.Core10.FundamentalTypes (bool32ToBool)
import Vulkan.Core10.FundamentalTypes (boolToBool32)
import Vulkan.CStruct.Extends (forgetExtensions)
import Vulkan.Dynamic (getInstanceProcAddr')
import Vulkan.Dynamic (initInstanceCmds)
import Vulkan.CStruct.Utils (lowerArrayPtr)
import Vulkan.CStruct.Utils (peekByteStringFromSizedVectorPtr)
import Vulkan.CStruct.Utils (pokeFixedLengthByteString)
import Vulkan.CStruct.Utils (pokeFixedLengthNullTerminatedByteString)
import Vulkan.NamedType ((:::))
import Vulkan.Core10.AllocationCallbacks (AllocationCallbacks)
import Vulkan.Core10.FundamentalTypes (Bool32)
import Vulkan.CStruct.Extends (Chain)
import {-# SOURCE #-} Vulkan.Extensions.VK_EXT_debug_report (DebugReportCallbackCreateInfoEXT)
import {-# SOURCE #-} Vulkan.Extensions.VK_EXT_debug_utils (DebugUtilsMessengerCreateInfoEXT)
import Vulkan.Core10.Handles (Device)
import Vulkan.Core10.Handles (Device(..))
import Vulkan.Core10.Handles (Device(Device))
import Vulkan.Dynamic (DeviceCmds(pVkGetDeviceProcAddr))
import Vulkan.Core10.FundamentalTypes (DeviceSize)
import Vulkan.Core10.Handles (Device_T)
import {-# SOURCE #-} Vulkan.Extensions.VK_LUNARG_direct_driver_loading (DirectDriverLoadingListLUNARG)
import {-# SOURCE #-} Vulkan.Extensions.VK_EXT_metal_objects (ExportMetalObjectCreateInfoEXT)
import Vulkan.CStruct.Extends (Extends)
import Vulkan.CStruct.Extends (Extendss)
import Vulkan.CStruct.Extends (Extensible(..))
import Vulkan.Core10.FundamentalTypes (Extent3D)
import Vulkan.Core10.Enums.Format (Format)
import Vulkan.Core10.Enums.Format (Format(..))
import Vulkan.Core10.Enums.FormatFeatureFlagBits (FormatFeatureFlags)
import Vulkan.Core10.Enums.ImageCreateFlagBits (ImageCreateFlagBits(..))
import Vulkan.Core10.Enums.ImageCreateFlagBits (ImageCreateFlags)
import Vulkan.Core10.Enums.ImageTiling (ImageTiling)
import Vulkan.Core10.Enums.ImageTiling (ImageTiling(..))
import Vulkan.Core10.Enums.ImageType (ImageType)
import Vulkan.Core10.Enums.ImageType (ImageType(..))
import Vulkan.Core10.Enums.ImageUsageFlagBits (ImageUsageFlagBits(..))
import Vulkan.Core10.Enums.ImageUsageFlagBits (ImageUsageFlags)
import Vulkan.Core10.Handles (Instance)
import Vulkan.Core10.Handles (Instance(..))
import Vulkan.Core10.Handles (Instance(Instance))
import Vulkan.Dynamic (InstanceCmds(pVkDestroyInstance))
import Vulkan.Dynamic (InstanceCmds(pVkEnumeratePhysicalDevices))
import Vulkan.Dynamic (InstanceCmds(pVkGetInstanceProcAddr))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceFeatures))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceFormatProperties))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceImageFormatProperties))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceMemoryProperties))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceProperties))
import Vulkan.Dynamic (InstanceCmds(pVkGetPhysicalDeviceQueueFamilyProperties))
import Vulkan.Core10.Enums.InstanceCreateFlagBits (InstanceCreateFlags)
import Vulkan.Core10.Handles (Instance_T)
import Vulkan.Core10.APIConstants (MAX_MEMORY_HEAPS)
import Vulkan.Core10.APIConstants (MAX_MEMORY_TYPES)
import Vulkan.Core10.APIConstants (MAX_PHYSICAL_DEVICE_NAME_SIZE)
import Vulkan.Core10.Enums.MemoryHeapFlagBits (MemoryHeapFlags)
import Vulkan.Core10.Enums.MemoryPropertyFlagBits (MemoryPropertyFlags)
import Vulkan.Core10.FuncPointers (PFN_vkVoidFunction)
import Vulkan.CStruct.Extends (PeekChain)
import Vulkan.CStruct.Extends (PeekChain(..))
import Vulkan.Core10.Handles (PhysicalDevice)
import Vulkan.Core10.Handles (PhysicalDevice(..))
import Vulkan.Core10.Handles (PhysicalDevice(PhysicalDevice))
import Vulkan.Core10.Enums.PhysicalDeviceType (PhysicalDeviceType)
import Vulkan.Core10.Handles (PhysicalDevice_T)
import Vulkan.CStruct.Extends (PokeChain)
import Vulkan.CStruct.Extends (PokeChain(..))
import Vulkan.Core10.Enums.QueueFlagBits (QueueFlags)
import Vulkan.Core10.Enums.Result (Result)
import Vulkan.Core10.Enums.Result (Result(..))
import Vulkan.Core10.Enums.SampleCountFlagBits (SampleCountFlags)
import Vulkan.CStruct.Extends (SomeStruct)
import Vulkan.Core10.Enums.StructureType (StructureType)
import Vulkan.Core10.APIConstants (UUID_SIZE)
import {-# SOURCE #-} Vulkan.Extensions.VK_EXT_validation_features (ValidationFeaturesEXT)
import {-# SOURCE #-} Vulkan.Extensions.VK_EXT_validation_flags (ValidationFlagsEXT)
import Vulkan.Exception (VulkanException(..))
import Vulkan.Core10.APIConstants (pattern MAX_MEMORY_HEAPS)
import Vulkan.Core10.APIConstants (pattern MAX_MEMORY_TYPES)
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_APPLICATION_INFO))
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_INSTANCE_CREATE_INFO))
import Vulkan.Core10.Enums.Result (Result(SUCCESS))
import Vulkan.Core10.AllocationCallbacks (AllocationCallbacks(..))
import Vulkan.Core10.FuncPointers (FN_vkAllocationFunction)
import Vulkan.Core10.FuncPointers (FN_vkFreeFunction)
import Vulkan.Core10.FuncPointers (FN_vkInternalAllocationNotification)
import Vulkan.Core10.FuncPointers (FN_vkInternalFreeNotification)
import Vulkan.Core10.FuncPointers (FN_vkReallocationFunction)
import Vulkan.Core10.FuncPointers (FN_vkVoidFunction)
import Vulkan.Core10.Enums.Format (Format(..))
import Vulkan.Core10.Enums.FormatFeatureFlagBits (FormatFeatureFlagBits(..))
import Vulkan.Core10.Enums.FormatFeatureFlagBits (FormatFeatureFlags)
import Vulkan.Core10.Enums.ImageCreateFlagBits (ImageCreateFlagBits(..))
import Vulkan.Core10.Enums.ImageCreateFlagBits (ImageCreateFlags)
import Vulkan.Core10.Enums.ImageTiling (ImageTiling(..))
import Vulkan.Core10.Enums.ImageType (ImageType(..))
import Vulkan.Core10.Enums.ImageUsageFlagBits (ImageUsageFlagBits(..))
import Vulkan.Core10.Enums.ImageUsageFlagBits (ImageUsageFlags)
import Vulkan.Core10.Handles (Instance(..))
import Vulkan.Core10.Enums.InstanceCreateFlagBits (InstanceCreateFlagBits(..))
import Vulkan.Core10.Enums.InstanceCreateFlagBits (InstanceCreateFlags)
import Vulkan.Core10.Enums.InternalAllocationType (InternalAllocationType(..))
import Vulkan.Core10.Enums.MemoryHeapFlagBits (MemoryHeapFlagBits(..))
import Vulkan.Core10.Enums.MemoryHeapFlagBits (MemoryHeapFlags)
import Vulkan.Core10.Enums.MemoryPropertyFlagBits (MemoryPropertyFlagBits(..))
import Vulkan.Core10.Enums.MemoryPropertyFlagBits (MemoryPropertyFlags)
import Vulkan.Core10.FuncPointers (PFN_vkAllocationFunction)
import Vulkan.Core10.FuncPointers (PFN_vkFreeFunction)
import Vulkan.Core10.FuncPointers (PFN_vkInternalAllocationNotification)
import Vulkan.Core10.FuncPointers (PFN_vkInternalFreeNotification)
import Vulkan.Core10.FuncPointers (PFN_vkReallocationFunction)
import Vulkan.Core10.FuncPointers (PFN_vkVoidFunction)
import Vulkan.Core10.Handles (PhysicalDevice(..))
import Vulkan.Core10.Enums.PhysicalDeviceType (PhysicalDeviceType(..))
import Vulkan.Core10.Enums.QueueFlagBits (QueueFlagBits(..))
import Vulkan.Core10.Enums.QueueFlagBits (QueueFlags)
import Vulkan.Core10.Enums.SampleCountFlagBits (SampleCountFlagBits(..))
import Vulkan.Core10.Enums.SampleCountFlagBits (SampleCountFlags)
import Vulkan.Core10.Enums.SystemAllocationScope (SystemAllocationScope(..))
foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkCreateInstance
  :: FunPtr (Ptr (SomeStruct InstanceCreateInfo) -> Ptr AllocationCallbacks -> Ptr (Ptr Instance_T) -> IO Result) -> Ptr (SomeStruct InstanceCreateInfo) -> Ptr AllocationCallbacks -> Ptr (Ptr Instance_T) -> IO Result

-- | vkCreateInstance - Create a new Vulkan instance
--
-- = Description
--
-- 'createInstance' verifies that the requested layers exist. If not,
-- 'createInstance' will return
-- 'Vulkan.Core10.Enums.Result.ERROR_LAYER_NOT_PRESENT'. Next
-- 'createInstance' 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, 'createInstance' /must/ return
-- 'Vulkan.Core10.Enums.Result.ERROR_EXTENSION_NOT_PRESENT'. After
-- verifying and enabling the instance layers and extensions the
-- 'Vulkan.Core10.Handles.Instance' 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 'createInstance'
-- time for the creation to succeed.
--
-- == Valid Usage
--
-- -   #VUID-vkCreateInstance-ppEnabledExtensionNames-01388# All
--     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#extendingvulkan-extensions-extensiondependencies required extensions>
--     for each extension in the
--     'InstanceCreateInfo'::@ppEnabledExtensionNames@ list /must/ also be
--     present in that list
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-vkCreateInstance-pCreateInfo-parameter# @pCreateInfo@ /must/
--     be a valid pointer to a valid 'InstanceCreateInfo' structure
--
-- -   #VUID-vkCreateInstance-pAllocator-parameter# If @pAllocator@ is not
--     @NULL@, @pAllocator@ /must/ be a valid pointer to a valid
--     'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks' structure
--
-- -   #VUID-vkCreateInstance-pInstance-parameter# @pInstance@ /must/ be a
--     valid pointer to a 'Vulkan.Core10.Handles.Instance' handle
--
-- == Return Codes
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-successcodes Success>]
--
--     -   'Vulkan.Core10.Enums.Result.SUCCESS'
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-errorcodes Failure>]
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_HOST_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_DEVICE_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_INITIALIZATION_FAILED'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_LAYER_NOT_PRESENT'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_EXTENSION_NOT_PRESENT'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_INCOMPATIBLE_DRIVER'
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks',
-- 'Vulkan.Core10.Handles.Instance', 'InstanceCreateInfo'
createInstance :: forall a io
                . (Extendss InstanceCreateInfo a, PokeChain a, MonadIO io)
               => -- | @pCreateInfo@ is a pointer to a 'InstanceCreateInfo' structure
                  -- controlling creation of the instance.
                  (InstanceCreateInfo a)
               -> -- | @pAllocator@ controls host memory allocation as described in the
                  -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-allocation Memory Allocation>
                  -- chapter.
                  ("allocator" ::: Maybe AllocationCallbacks)
               -> io (Instance)
createInstance :: forall (a :: [*]) (io :: * -> *).
(Extendss InstanceCreateInfo a, PokeChain a, MonadIO io) =>
InstanceCreateInfo a
-> ("allocator" ::: Maybe AllocationCallbacks) -> io Instance
createInstance InstanceCreateInfo a
createInfo "allocator" ::: Maybe AllocationCallbacks
allocator = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  FunPtr
  (("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
   -> ("pAllocator" ::: Ptr AllocationCallbacks)
   -> ("pInstance" ::: Ptr (Ptr Instance_T))
   -> IO Result)
vkCreateInstancePtr <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a b. FunPtr a -> FunPtr b
castFunPtr @_ @(("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo)) -> ("pAllocator" ::: Ptr AllocationCallbacks) -> ("pInstance" ::: Ptr (Ptr Instance_T)) -> IO Result) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Ptr Instance_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
getInstanceProcAddr' forall a. Ptr a
nullPtr (forall a. Addr# -> Ptr a
Ptr Addr#
"vkCreateInstance"#)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
   -> ("pAllocator" ::: Ptr AllocationCallbacks)
   -> ("pInstance" ::: Ptr (Ptr Instance_T))
   -> IO Result)
vkCreateInstancePtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkCreateInstance is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkCreateInstance' :: ("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
-> ("pAllocator" ::: Ptr AllocationCallbacks)
-> ("pInstance" ::: Ptr (Ptr Instance_T))
-> IO Result
vkCreateInstance' = FunPtr
  (("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
   -> ("pAllocator" ::: Ptr AllocationCallbacks)
   -> ("pInstance" ::: Ptr (Ptr Instance_T))
   -> IO Result)
-> ("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
-> ("pAllocator" ::: Ptr AllocationCallbacks)
-> ("pInstance" ::: Ptr (Ptr Instance_T))
-> IO Result
mkVkCreateInstance FunPtr
  (("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
   -> ("pAllocator" ::: Ptr AllocationCallbacks)
   -> ("pInstance" ::: Ptr (Ptr Instance_T))
   -> IO Result)
vkCreateInstancePtr
  Ptr (InstanceCreateInfo a)
pCreateInfo <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
withCStruct (InstanceCreateInfo a
createInfo)
  "pAllocator" ::: Ptr AllocationCallbacks
pAllocator <- case ("allocator" ::: Maybe AllocationCallbacks
allocator) of
    "allocator" ::: Maybe AllocationCallbacks
Nothing -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Ptr a
nullPtr
    Just AllocationCallbacks
j -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
withCStruct (AllocationCallbacks
j)
  "pInstance" ::: Ptr (Ptr Instance_T)
pPInstance <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b c. IO a -> (a -> IO b) -> (a -> IO c) -> IO c
bracket (forall a. Int -> IO (Ptr a)
callocBytes @(Ptr Instance_T) Int
8) forall a. Ptr a -> IO ()
free
  Result
r <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkCreateInstance" (("pCreateInfo" ::: Ptr (SomeStruct InstanceCreateInfo))
-> ("pAllocator" ::: Ptr AllocationCallbacks)
-> ("pInstance" ::: Ptr (Ptr Instance_T))
-> IO Result
vkCreateInstance'
                                                     (forall (a :: [*] -> *) (es :: [*]).
Ptr (a es) -> Ptr (SomeStruct a)
forgetExtensions Ptr (InstanceCreateInfo a)
pCreateInfo)
                                                     "pAllocator" ::: Ptr AllocationCallbacks
pAllocator
                                                     ("pInstance" ::: Ptr (Ptr Instance_T)
pPInstance))
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
  Ptr Instance_T
pInstance <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> IO a
peek @(Ptr Instance_T) "pInstance" ::: Ptr (Ptr Instance_T)
pPInstance
  Instance
pInstance' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ (\Ptr Instance_T
h -> Ptr Instance_T -> InstanceCmds -> Instance
Instance Ptr Instance_T
h forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Ptr Instance_T -> IO InstanceCmds
initInstanceCmds Ptr Instance_T
h) Ptr Instance_T
pInstance
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (Instance
pInstance')

-- | A convenience wrapper to make a compatible pair of calls to
-- 'createInstance' and 'destroyInstance'
--
-- To ensure that 'destroyInstance' is always called: pass
-- 'Control.Exception.bracket' (or the allocate function from your
-- favourite resource management library) as the last argument.
-- To just extract the pair pass '(,)' as the last argument.
--
withInstance :: forall a io r . (Extendss InstanceCreateInfo a, PokeChain a, MonadIO io) => InstanceCreateInfo a -> Maybe AllocationCallbacks -> (io Instance -> (Instance -> io ()) -> r) -> r
withInstance :: forall (a :: [*]) (io :: * -> *) r.
(Extendss InstanceCreateInfo a, PokeChain a, MonadIO io) =>
InstanceCreateInfo a
-> ("allocator" ::: Maybe AllocationCallbacks)
-> (io Instance -> (Instance -> io ()) -> r)
-> r
withInstance InstanceCreateInfo a
pCreateInfo "allocator" ::: Maybe AllocationCallbacks
pAllocator io Instance -> (Instance -> io ()) -> r
b =
  io Instance -> (Instance -> io ()) -> r
b (forall (a :: [*]) (io :: * -> *).
(Extendss InstanceCreateInfo a, PokeChain a, MonadIO io) =>
InstanceCreateInfo a
-> ("allocator" ::: Maybe AllocationCallbacks) -> io Instance
createInstance InstanceCreateInfo a
pCreateInfo "allocator" ::: Maybe AllocationCallbacks
pAllocator)
    (\(Instance
o0) -> forall (io :: * -> *).
MonadIO io =>
Instance -> ("allocator" ::: Maybe AllocationCallbacks) -> io ()
destroyInstance Instance
o0 "allocator" ::: Maybe AllocationCallbacks
pAllocator)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkDestroyInstance
  :: FunPtr (Ptr Instance_T -> Ptr AllocationCallbacks -> IO ()) -> Ptr Instance_T -> Ptr AllocationCallbacks -> IO ()

-- | vkDestroyInstance - Destroy an instance of Vulkan
--
-- == Valid Usage
--
-- -   #VUID-vkDestroyInstance-instance-00629# All child objects created
--     using @instance@ /must/ have been destroyed prior to destroying
--     @instance@
--
-- -   #VUID-vkDestroyInstance-instance-00630# If
--     'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks' were
--     provided when @instance@ was created, a compatible set of callbacks
--     /must/ be provided here
--
-- -   #VUID-vkDestroyInstance-instance-00631# If no
--     'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks' were
--     provided when @instance@ was created, @pAllocator@ /must/ be @NULL@
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-vkDestroyInstance-instance-parameter# If @instance@ is not
--     @NULL@, @instance@ /must/ be a valid
--     'Vulkan.Core10.Handles.Instance' handle
--
-- -   #VUID-vkDestroyInstance-pAllocator-parameter# If @pAllocator@ is not
--     @NULL@, @pAllocator@ /must/ be a valid pointer to a valid
--     'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks' structure
--
-- == Host Synchronization
--
-- -   Host access to @instance@ /must/ be externally synchronized
--
-- -   Host access to all 'Vulkan.Core10.Handles.PhysicalDevice' objects
--     enumerated from @instance@ /must/ be externally synchronized
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.AllocationCallbacks.AllocationCallbacks',
-- 'Vulkan.Core10.Handles.Instance'
destroyInstance :: forall io
                 . (MonadIO io)
                => -- | @instance@ is the handle of the instance to destroy.
                   Instance
                -> -- | @pAllocator@ controls host memory allocation as described in the
                   -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-allocation Memory Allocation>
                   -- chapter.
                   ("allocator" ::: Maybe AllocationCallbacks)
                -> io ()
destroyInstance :: forall (io :: * -> *).
MonadIO io =>
Instance -> ("allocator" ::: Maybe AllocationCallbacks) -> io ()
destroyInstance Instance
instance' "allocator" ::: Maybe AllocationCallbacks
allocator = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkDestroyInstancePtr :: FunPtr
  (Ptr Instance_T
   -> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ())
vkDestroyInstancePtr = InstanceCmds
-> FunPtr
     (Ptr Instance_T
      -> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ())
pVkDestroyInstance (case Instance
instance' of Instance{InstanceCmds
$sel:instanceCmds:Instance :: Instance -> InstanceCmds
instanceCmds :: InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr Instance_T
   -> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ())
vkDestroyInstancePtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkDestroyInstance is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkDestroyInstance' :: Ptr Instance_T
-> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ()
vkDestroyInstance' = FunPtr
  (Ptr Instance_T
   -> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ())
-> Ptr Instance_T
-> ("pAllocator" ::: Ptr AllocationCallbacks)
-> IO ()
mkVkDestroyInstance FunPtr
  (Ptr Instance_T
   -> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ())
vkDestroyInstancePtr
  "pAllocator" ::: Ptr AllocationCallbacks
pAllocator <- case ("allocator" ::: Maybe AllocationCallbacks
allocator) of
    "allocator" ::: Maybe AllocationCallbacks
Nothing -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Ptr a
nullPtr
    Just AllocationCallbacks
j -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
withCStruct (AllocationCallbacks
j)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkDestroyInstance" (Ptr Instance_T
-> ("pAllocator" ::: Ptr AllocationCallbacks) -> IO ()
vkDestroyInstance'
                                                 (Instance -> Ptr Instance_T
instanceHandle (Instance
instance'))
                                                 "pAllocator" ::: Ptr AllocationCallbacks
pAllocator)
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ ()


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkEnumeratePhysicalDevices
  :: FunPtr (Ptr Instance_T -> Ptr Word32 -> Ptr (Ptr PhysicalDevice_T) -> IO Result) -> Ptr Instance_T -> Ptr Word32 -> Ptr (Ptr PhysicalDevice_T) -> IO Result

-- | vkEnumeratePhysicalDevices - Enumerates the physical devices accessible
-- to a Vulkan instance
--
-- = 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, and 'Vulkan.Core10.Enums.Result.INCOMPLETE' will be
-- returned instead of 'Vulkan.Core10.Enums.Result.SUCCESS', to indicate
-- that not all the available physical devices were returned.
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-vkEnumeratePhysicalDevices-instance-parameter# @instance@
--     /must/ be a valid 'Vulkan.Core10.Handles.Instance' handle
--
-- -   #VUID-vkEnumeratePhysicalDevices-pPhysicalDeviceCount-parameter#
--     @pPhysicalDeviceCount@ /must/ be a valid pointer to a @uint32_t@
--     value
--
-- -   #VUID-vkEnumeratePhysicalDevices-pPhysicalDevices-parameter# 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@
--     'Vulkan.Core10.Handles.PhysicalDevice' handles
--
-- == Return Codes
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-successcodes Success>]
--
--     -   'Vulkan.Core10.Enums.Result.SUCCESS'
--
--     -   'Vulkan.Core10.Enums.Result.INCOMPLETE'
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-errorcodes Failure>]
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_HOST_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_DEVICE_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_INITIALIZATION_FAILED'
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.Instance', 'Vulkan.Core10.Handles.PhysicalDevice'
enumeratePhysicalDevices :: forall io
                          . (MonadIO io)
                         => -- | @instance@ is a handle to a Vulkan instance previously created with
                            -- 'createInstance'.
                            Instance
                         -> io (Result, ("physicalDevices" ::: Vector PhysicalDevice))
enumeratePhysicalDevices :: forall (io :: * -> *).
MonadIO io =>
Instance
-> io (Result, "physicalDevices" ::: Vector PhysicalDevice)
enumeratePhysicalDevices Instance
instance' = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let cmds :: InstanceCmds
cmds = case Instance
instance' of Instance{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:Instance :: Instance -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds
  let vkEnumeratePhysicalDevicesPtr :: FunPtr
  (Ptr Instance_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
   -> IO Result)
vkEnumeratePhysicalDevicesPtr = InstanceCmds
-> FunPtr
     (Ptr Instance_T
      -> ("pPhysicalDeviceCount" ::: Ptr Word32)
      -> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
      -> IO Result)
pVkEnumeratePhysicalDevices InstanceCmds
cmds
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr Instance_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
   -> IO Result)
vkEnumeratePhysicalDevicesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkEnumeratePhysicalDevices is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkEnumeratePhysicalDevices' :: Ptr Instance_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
-> IO Result
vkEnumeratePhysicalDevices' = FunPtr
  (Ptr Instance_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
   -> IO Result)
-> Ptr Instance_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
-> IO Result
mkVkEnumeratePhysicalDevices FunPtr
  (Ptr Instance_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
   -> IO Result)
vkEnumeratePhysicalDevicesPtr
  let instance'' :: Ptr Instance_T
instance'' = Instance -> Ptr Instance_T
instanceHandle (Instance
instance')
  "pPhysicalDeviceCount" ::: Ptr Word32
pPPhysicalDeviceCount <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b c. IO a -> (a -> IO b) -> (a -> IO c) -> IO c
bracket (forall a. Int -> IO (Ptr a)
callocBytes @Word32 Int
4) forall a. Ptr a -> IO ()
free
  Result
r <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkEnumeratePhysicalDevices" (Ptr Instance_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
-> IO Result
vkEnumeratePhysicalDevices'
                                                               Ptr Instance_T
instance''
                                                               ("pPhysicalDeviceCount" ::: Ptr Word32
pPPhysicalDeviceCount)
                                                               (forall a. Ptr a
nullPtr))
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
  Word32
pPhysicalDeviceCount <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> IO a
peek @Word32 "pPhysicalDeviceCount" ::: Ptr Word32
pPPhysicalDeviceCount
  "pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T)
pPPhysicalDevices <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b c. IO a -> (a -> IO b) -> (a -> IO c) -> IO c
bracket (forall a. Int -> IO (Ptr a)
callocBytes @(Ptr PhysicalDevice_T) ((forall a b. (Integral a, Num b) => a -> b
fromIntegral (Word32
pPhysicalDeviceCount)) forall a. Num a => a -> a -> a
* Int
8)) forall a. Ptr a -> IO ()
free
  Result
r' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkEnumeratePhysicalDevices" (Ptr Instance_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T))
-> IO Result
vkEnumeratePhysicalDevices'
                                                                Ptr Instance_T
instance''
                                                                ("pPhysicalDeviceCount" ::: Ptr Word32
pPPhysicalDeviceCount)
                                                                ("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T)
pPPhysicalDevices))
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r' forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r'))
  Word32
pPhysicalDeviceCount' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> IO a
peek @Word32 "pPhysicalDeviceCount" ::: Ptr Word32
pPPhysicalDeviceCount
  "physicalDevices" ::: Vector PhysicalDevice
pPhysicalDevices' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a b. (Integral a, Num b) => a -> b
fromIntegral (Word32
pPhysicalDeviceCount')) (\Int
i -> do
    Ptr PhysicalDevice_T
pPhysicalDevicesElem <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr PhysicalDevice_T) (("pPhysicalDevices" ::: Ptr (Ptr PhysicalDevice_T)
pPPhysicalDevices forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr (Ptr PhysicalDevice_T)))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (\Ptr PhysicalDevice_T
h -> Ptr PhysicalDevice_T -> InstanceCmds -> PhysicalDevice
PhysicalDevice Ptr PhysicalDevice_T
h InstanceCmds
cmds ) Ptr PhysicalDevice_T
pPhysicalDevicesElem)
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ ((Result
r'), "physicalDevices" ::: Vector PhysicalDevice
pPhysicalDevices')


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetDeviceProcAddr
  :: FunPtr (Ptr Device_T -> Ptr CChar -> IO PFN_vkVoidFunction) -> Ptr Device_T -> Ptr CChar -> IO PFN_vkVoidFunction

-- | vkGetDeviceProcAddr - Return a function pointer for a command
--
-- = Parameters
--
-- The table below defines the various use cases for 'getDeviceProcAddr'
-- and expected return value (“fp” is “function pointer”) for each case. A
-- valid returned function pointer (“fp”) /must/ not be @NULL@.
--
-- = Description
--
-- The returned function pointer is of type
-- 'Vulkan.Core10.FuncPointers.PFN_vkVoidFunction', and /must/ be cast to
-- the type of the command being queried before use. 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@           | *1               | undefined        |
-- +------------------+------------------+------------------+
-- | invalid device   | *1               | undefined        |
-- +------------------+------------------+------------------+
-- | device           | @NULL@           | undefined        |
-- +------------------+------------------+------------------+
-- | device           | requested core   | fp4              |
-- |                  | version2         |                  |
-- |                  | device-level     |                  |
-- |                  | dispatchable     |                  |
-- |                  | command3         |                  |
-- +------------------+------------------+------------------+
-- | device           | enabled          | fp4              |
-- |                  | extension        |                  |
-- |                  | device-level     |                  |
-- |                  | dispatchable     |                  |
-- |                  | command3         |                  |
-- +------------------+------------------+------------------+
-- | any other case,  |                  | @NULL@           |
-- | not covered      |                  |                  |
-- | above            |                  |                  |
-- +------------------+------------------+------------------+
--
-- 'getDeviceProcAddr' behavior
--
-- [1]
--     \"*\" means any representable value for the parameter (including
--     valid values, invalid values, and @NULL@).
--
-- [2]
--     Device-level commands which are part of the core version specified
--     by 'ApplicationInfo'::@apiVersion@ when creating the instance will
--     always return a valid function pointer. If the
--     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-maintenance5 maintenance5>
--     feature is enabled, core commands beyond that version which are
--     supported by the implementation will return @NULL@, otherwise the
--     implementation /may/ either return @NULL@ or a function pointer. If
--     a function pointer is returned, it /must/ not be called.
--
-- [3]
--     In this function, device-level excludes all physical-device-level
--     commands.
--
-- [4]
--     The returned function pointer /must/ only be called with a
--     dispatchable object (the first parameter) that is @device@ or a
--     child of @device@ e.g. 'Vulkan.Core10.Handles.Device',
--     'Vulkan.Core10.Handles.Queue', or
--     'Vulkan.Core10.Handles.CommandBuffer'.
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- 'Vulkan.Core10.FuncPointers.PFN_vkVoidFunction',
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.Device'
getDeviceProcAddr :: forall io
                   . (MonadIO io)
                  => -- | #VUID-vkGetDeviceProcAddr-device-parameter# @device@ /must/ be a valid
                     -- 'Vulkan.Core10.Handles.Device' handle
                     Device
                  -> -- | #VUID-vkGetDeviceProcAddr-pName-parameter# @pName@ /must/ be a
                     -- null-terminated UTF-8 string
                     ("name" ::: ByteString)
                  -> io (PFN_vkVoidFunction)
getDeviceProcAddr :: forall (io :: * -> *).
MonadIO io =>
Device -> ("name" ::: ByteString) -> io PFN_vkVoidFunction
getDeviceProcAddr Device
device "name" ::: ByteString
name = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetDeviceProcAddrPtr :: FunPtr
  (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetDeviceProcAddrPtr = DeviceCmds
-> FunPtr
     (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
pVkGetDeviceProcAddr (case Device
device of Device{DeviceCmds
$sel:deviceCmds:Device :: Device -> DeviceCmds
deviceCmds :: DeviceCmds
deviceCmds} -> DeviceCmds
deviceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetDeviceProcAddrPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetDeviceProcAddr is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetDeviceProcAddr' :: Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
vkGetDeviceProcAddr' = FunPtr
  (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
-> Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
mkVkGetDeviceProcAddr FunPtr
  (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetDeviceProcAddrPtr
  "pName" ::: Ptr CChar
pName <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
name)
  PFN_vkVoidFunction
r <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetDeviceProcAddr" (Ptr Device_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
vkGetDeviceProcAddr'
                                                        (Device -> Ptr Device_T
deviceHandle (Device
device))
                                                        "pName" ::: Ptr CChar
pName)
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (PFN_vkVoidFunction
r)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetInstanceProcAddr
  :: FunPtr (Ptr Instance_T -> Ptr CChar -> IO PFN_vkVoidFunction) -> Ptr Instance_T -> Ptr CChar -> IO PFN_vkVoidFunction

-- | vkGetInstanceProcAddr - Return a function pointer for a command
--
-- = Description
--
-- 'getInstanceProcAddr' 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 'getInstanceProcAddr'
-- and expected return value (“fp” is “function pointer”) for each case. A
-- valid returned function pointer (“fp”) /must/ not be @NULL@.
--
-- The returned function pointer is of type
-- 'Vulkan.Core10.FuncPointers.PFN_vkVoidFunction', and /must/ be cast to
-- the type of the command being queried before use.
--
-- +------------------+-----------------------+------------------+
-- | @instance@       | @pName@               | return value     |
-- +==================+=======================+==================+
-- | *1               | @NULL@                | undefined        |
-- +------------------+-----------------------+------------------+
-- | invalid          | *1                    | undefined        |
-- | non-@NULL@       |                       |                  |
-- | instance         |                       |                  |
-- +------------------+-----------------------+------------------+
-- | @NULL@           | /global command/2     | fp               |
-- +------------------+-----------------------+------------------+
-- | @NULL@           | 'getInstanceProcAddr' | fp5              |
-- +------------------+-----------------------+------------------+
-- | instance         | 'getInstanceProcAddr' | fp               |
-- +------------------+-----------------------+------------------+
-- | instance         | core /dispatchable    | fp3              |
-- |                  | command/              |                  |
-- +------------------+-----------------------+------------------+
-- | instance         | enabled instance      | fp3              |
-- |                  | extension             |                  |
-- |                  | dispatchable command  |                  |
-- |                  | for @instance@        |                  |
-- +------------------+-----------------------+------------------+
-- | instance         | available device      | fp3              |
-- |                  | extension4            |                  |
-- |                  | dispatchable command  |                  |
-- |                  | for @instance@        |                  |
-- +------------------+-----------------------+------------------+
-- | any other case,  |                       | @NULL@           |
-- | not covered      |                       |                  |
-- | above            |                       |                  |
-- +------------------+-----------------------+------------------+
--
-- 'getInstanceProcAddr' behavior
--
-- [1]
--     \"*\" means any representable value for the parameter (including
--     valid values, invalid values, and @NULL@).
--
-- [2]
--     The global commands are:
--     'Vulkan.Core11.DeviceInitialization.enumerateInstanceVersion',
--     'Vulkan.Core10.ExtensionDiscovery.enumerateInstanceExtensionProperties',
--     'Vulkan.Core10.LayerDiscovery.enumerateInstanceLayerProperties', and
--     'createInstance'. Dispatchable commands are all other commands which
--     are not global.
--
-- [3]
--     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. 'Vulkan.Core10.Handles.Instance',
--     'Vulkan.Core10.Handles.PhysicalDevice',
--     'Vulkan.Core10.Handles.Device', 'Vulkan.Core10.Handles.Queue', or
--     'Vulkan.Core10.Handles.CommandBuffer'.
--
-- [4]
--     An “available device extension” is a device extension supported by
--     any physical device enumerated by @instance@.
--
-- [5]
--     Starting with Vulkan 1.2, 'getInstanceProcAddr' can resolve itself
--     with a @NULL@ instance pointer.
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-vkGetInstanceProcAddr-instance-parameter# If @instance@ is not
--     @NULL@, @instance@ /must/ be a valid
--     'Vulkan.Core10.Handles.Instance' handle
--
-- -   #VUID-vkGetInstanceProcAddr-pName-parameter# @pName@ /must/ be a
--     null-terminated UTF-8 string
--
-- = See Also
--
-- 'Vulkan.Core10.FuncPointers.PFN_vkVoidFunction',
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.Instance'
getInstanceProcAddr :: forall io
                     . (MonadIO io)
                    => -- | @instance@ is the instance that the function pointer will be compatible
                       -- with, or @NULL@ for commands not dependent on any instance.
                       Instance
                    -> -- | @pName@ is the name of the command to obtain.
                       ("name" ::: ByteString)
                    -> io (PFN_vkVoidFunction)
getInstanceProcAddr :: forall (io :: * -> *).
MonadIO io =>
Instance -> ("name" ::: ByteString) -> io PFN_vkVoidFunction
getInstanceProcAddr Instance
instance' "name" ::: ByteString
name = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetInstanceProcAddrPtr :: FunPtr
  (Ptr Instance_T
   -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetInstanceProcAddrPtr = InstanceCmds
-> FunPtr
     (Ptr Instance_T
      -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
pVkGetInstanceProcAddr (case Instance
instance' of Instance{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:Instance :: Instance -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr Instance_T
   -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetInstanceProcAddrPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetInstanceProcAddr is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetInstanceProcAddr' :: Ptr Instance_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
vkGetInstanceProcAddr' = FunPtr
  (Ptr Instance_T
   -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
-> Ptr Instance_T
-> ("pName" ::: Ptr CChar)
-> IO PFN_vkVoidFunction
mkVkGetInstanceProcAddr FunPtr
  (Ptr Instance_T
   -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction)
vkGetInstanceProcAddrPtr
  "pName" ::: Ptr CChar
pName <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
name)
  PFN_vkVoidFunction
r <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetInstanceProcAddr" (Ptr Instance_T -> ("pName" ::: Ptr CChar) -> IO PFN_vkVoidFunction
vkGetInstanceProcAddr'
                                                          (Instance -> Ptr Instance_T
instanceHandle (Instance
instance'))
                                                          "pName" ::: Ptr CChar
pName)
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (PFN_vkVoidFunction
r)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceProperties
  :: FunPtr (Ptr PhysicalDevice_T -> Ptr PhysicalDeviceProperties -> IO ()) -> Ptr PhysicalDevice_T -> Ptr PhysicalDeviceProperties -> IO ()

-- | vkGetPhysicalDeviceProperties - Returns properties of a physical device
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.PhysicalDevice', 'PhysicalDeviceProperties'
getPhysicalDeviceProperties :: forall io
                             . (MonadIO io)
                            => -- | @physicalDevice@ is the handle to the physical device whose properties
                               -- will be queried.
                               --
                               -- #VUID-vkGetPhysicalDeviceProperties-physicalDevice-parameter#
                               -- @physicalDevice@ /must/ be a valid
                               -- 'Vulkan.Core10.Handles.PhysicalDevice' handle
                               PhysicalDevice
                            -> io (PhysicalDeviceProperties)
getPhysicalDeviceProperties :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice -> io PhysicalDeviceProperties
getPhysicalDeviceProperties PhysicalDevice
physicalDevice = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDevicePropertiesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ())
vkGetPhysicalDevicePropertiesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ())
pVkGetPhysicalDeviceProperties (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds :: InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ())
vkGetPhysicalDevicePropertiesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceProperties is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceProperties' :: Ptr PhysicalDevice_T
-> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ()
vkGetPhysicalDeviceProperties' = FunPtr
  (Ptr PhysicalDevice_T
   -> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ())
-> Ptr PhysicalDevice_T
-> ("pProperties" ::: Ptr PhysicalDeviceProperties)
-> IO ()
mkVkGetPhysicalDeviceProperties FunPtr
  (Ptr PhysicalDevice_T
   -> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ())
vkGetPhysicalDevicePropertiesPtr
  "pProperties" ::: Ptr PhysicalDeviceProperties
pPProperties <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (forall a b. ToCStruct a => (Ptr a -> IO b) -> IO b
withZeroCStruct @PhysicalDeviceProperties)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceProperties" (Ptr PhysicalDevice_T
-> ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO ()
vkGetPhysicalDeviceProperties'
                                                             (PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice))
                                                             ("pProperties" ::: Ptr PhysicalDeviceProperties
pPProperties))
  PhysicalDeviceProperties
pProperties <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @PhysicalDeviceProperties "pProperties" ::: Ptr PhysicalDeviceProperties
pPProperties
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (PhysicalDeviceProperties
pProperties)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceQueueFamilyProperties
  :: FunPtr (Ptr PhysicalDevice_T -> Ptr Word32 -> Ptr QueueFamilyProperties -> IO ()) -> Ptr PhysicalDevice_T -> Ptr Word32 -> Ptr QueueFamilyProperties -> IO ()

-- | vkGetPhysicalDeviceQueueFamilyProperties - Reports properties of the
-- queues of the specified physical device
--
-- = Description
--
-- If @pQueueFamilyProperties@ is @NULL@, then the number of queue families
-- available is returned in @pQueueFamilyPropertyCount@. Implementations
-- /must/ support at least one queue family. 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)
--
-- -   #VUID-vkGetPhysicalDeviceQueueFamilyProperties-physicalDevice-parameter#
--     @physicalDevice@ /must/ be a valid
--     'Vulkan.Core10.Handles.PhysicalDevice' handle
--
-- -   #VUID-vkGetPhysicalDeviceQueueFamilyProperties-pQueueFamilyPropertyCount-parameter#
--     @pQueueFamilyPropertyCount@ /must/ be a valid pointer to a
--     @uint32_t@ value
--
-- -   #VUID-vkGetPhysicalDeviceQueueFamilyProperties-pQueueFamilyProperties-parameter#
--     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@
--     'QueueFamilyProperties' structures
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.PhysicalDevice', 'QueueFamilyProperties'
getPhysicalDeviceQueueFamilyProperties :: forall io
                                        . (MonadIO io)
                                       => -- | @physicalDevice@ is the handle to the physical device whose properties
                                          -- will be queried.
                                          PhysicalDevice
                                       -> io (("queueFamilyProperties" ::: Vector QueueFamilyProperties))
getPhysicalDeviceQueueFamilyProperties :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice
-> io ("queueFamilyProperties" ::: Vector QueueFamilyProperties)
getPhysicalDeviceQueueFamilyProperties PhysicalDevice
physicalDevice = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDeviceQueueFamilyPropertiesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
   -> IO ())
vkGetPhysicalDeviceQueueFamilyPropertiesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> ("pPhysicalDeviceCount" ::: Ptr Word32)
      -> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
      -> IO ())
pVkGetPhysicalDeviceQueueFamilyProperties (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
   -> IO ())
vkGetPhysicalDeviceQueueFamilyPropertiesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceQueueFamilyProperties is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceQueueFamilyProperties' :: Ptr PhysicalDevice_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO ()
vkGetPhysicalDeviceQueueFamilyProperties' = FunPtr
  (Ptr PhysicalDevice_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
   -> IO ())
-> Ptr PhysicalDevice_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO ()
mkVkGetPhysicalDeviceQueueFamilyProperties FunPtr
  (Ptr PhysicalDevice_T
   -> ("pPhysicalDeviceCount" ::: Ptr Word32)
   -> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
   -> IO ())
vkGetPhysicalDeviceQueueFamilyPropertiesPtr
  let physicalDevice' :: Ptr PhysicalDevice_T
physicalDevice' = PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice)
  "pPhysicalDeviceCount" ::: Ptr Word32
pPQueueFamilyPropertyCount <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b c. IO a -> (a -> IO b) -> (a -> IO c) -> IO c
bracket (forall a. Int -> IO (Ptr a)
callocBytes @Word32 Int
4) forall a. Ptr a -> IO ()
free
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceQueueFamilyProperties" (Ptr PhysicalDevice_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO ()
vkGetPhysicalDeviceQueueFamilyProperties'
                                                                        Ptr PhysicalDevice_T
physicalDevice'
                                                                        ("pPhysicalDeviceCount" ::: Ptr Word32
pPQueueFamilyPropertyCount)
                                                                        (forall a. Ptr a
nullPtr))
  Word32
pQueueFamilyPropertyCount <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> IO a
peek @Word32 "pPhysicalDeviceCount" ::: Ptr Word32
pPQueueFamilyPropertyCount
  "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
pPQueueFamilyProperties <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b c. IO a -> (a -> IO b) -> (a -> IO c) -> IO c
bracket (forall a. Int -> IO (Ptr a)
callocBytes @QueueFamilyProperties ((forall a b. (Integral a, Num b) => a -> b
fromIntegral (Word32
pQueueFamilyPropertyCount)) forall a. Num a => a -> a -> a
* Int
24)) forall a. Ptr a -> IO ()
free
  [()]
_ <- forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse (\Int
i -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. ToCStruct a => Ptr a -> IO b -> IO b
pokeZeroCStruct ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
pPQueueFamilyProperties forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
i forall a. Num a => a -> a -> a
* Int
24) :: Ptr QueueFamilyProperties) forall b c a. (b -> c) -> (a -> b) -> a -> c
. (forall a b. (a -> b) -> a -> b
$ ())) [Int
0..(forall a b. (Integral a, Num b) => a -> b
fromIntegral (Word32
pQueueFamilyPropertyCount)) forall a. Num a => a -> a -> a
- Int
1]
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceQueueFamilyProperties" (Ptr PhysicalDevice_T
-> ("pPhysicalDeviceCount" ::: Ptr Word32)
-> ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO ()
vkGetPhysicalDeviceQueueFamilyProperties'
                                                                        Ptr PhysicalDevice_T
physicalDevice'
                                                                        ("pPhysicalDeviceCount" ::: Ptr Word32
pPQueueFamilyPropertyCount)
                                                                        (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
pPQueueFamilyProperties)))
  Word32
pQueueFamilyPropertyCount' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> IO a
peek @Word32 "pPhysicalDeviceCount" ::: Ptr Word32
pPQueueFamilyPropertyCount
  "queueFamilyProperties" ::: Vector QueueFamilyProperties
pQueueFamilyProperties' <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a b. (Integral a, Num b) => a -> b
fromIntegral (Word32
pQueueFamilyPropertyCount')) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @QueueFamilyProperties ((("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
pPQueueFamilyProperties) forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
24 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr QueueFamilyProperties)))
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ ("queueFamilyProperties" ::: Vector QueueFamilyProperties
pQueueFamilyProperties')


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceMemoryProperties
  :: FunPtr (Ptr PhysicalDevice_T -> Ptr PhysicalDeviceMemoryProperties -> IO ()) -> Ptr PhysicalDevice_T -> Ptr PhysicalDeviceMemoryProperties -> IO ()

-- | vkGetPhysicalDeviceMemoryProperties - Reports memory information for the
-- specified physical device
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.PhysicalDevice', 'PhysicalDeviceMemoryProperties'
getPhysicalDeviceMemoryProperties :: forall io
                                   . (MonadIO io)
                                  => -- | @physicalDevice@ is the handle to the device to query.
                                     --
                                     -- #VUID-vkGetPhysicalDeviceMemoryProperties-physicalDevice-parameter#
                                     -- @physicalDevice@ /must/ be a valid
                                     -- 'Vulkan.Core10.Handles.PhysicalDevice' handle
                                     PhysicalDevice
                                  -> io (PhysicalDeviceMemoryProperties)
getPhysicalDeviceMemoryProperties :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice -> io PhysicalDeviceMemoryProperties
getPhysicalDeviceMemoryProperties PhysicalDevice
physicalDevice = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDeviceMemoryPropertiesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
   -> IO ())
vkGetPhysicalDeviceMemoryPropertiesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
      -> IO ())
pVkGetPhysicalDeviceMemoryProperties (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
   -> IO ())
vkGetPhysicalDeviceMemoryPropertiesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceMemoryProperties is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceMemoryProperties' :: Ptr PhysicalDevice_T
-> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO ()
vkGetPhysicalDeviceMemoryProperties' = FunPtr
  (Ptr PhysicalDevice_T
   -> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
   -> IO ())
-> Ptr PhysicalDevice_T
-> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO ()
mkVkGetPhysicalDeviceMemoryProperties FunPtr
  (Ptr PhysicalDevice_T
   -> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
   -> IO ())
vkGetPhysicalDeviceMemoryPropertiesPtr
  "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
pPMemoryProperties <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (forall a b. ToCStruct a => (Ptr a -> IO b) -> IO b
withZeroCStruct @PhysicalDeviceMemoryProperties)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceMemoryProperties" (Ptr PhysicalDevice_T
-> ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO ()
vkGetPhysicalDeviceMemoryProperties'
                                                                   (PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice))
                                                                   ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
pPMemoryProperties))
  PhysicalDeviceMemoryProperties
pMemoryProperties <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @PhysicalDeviceMemoryProperties "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
pPMemoryProperties
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (PhysicalDeviceMemoryProperties
pMemoryProperties)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceFeatures
  :: FunPtr (Ptr PhysicalDevice_T -> Ptr PhysicalDeviceFeatures -> IO ()) -> Ptr PhysicalDevice_T -> Ptr PhysicalDeviceFeatures -> IO ()

-- | vkGetPhysicalDeviceFeatures - Reports capabilities of a physical device
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Handles.PhysicalDevice', 'PhysicalDeviceFeatures'
getPhysicalDeviceFeatures :: forall io
                           . (MonadIO io)
                          => -- | @physicalDevice@ is the physical device from which to query the
                             -- supported features.
                             --
                             -- #VUID-vkGetPhysicalDeviceFeatures-physicalDevice-parameter#
                             -- @physicalDevice@ /must/ be a valid
                             -- 'Vulkan.Core10.Handles.PhysicalDevice' handle
                             PhysicalDevice
                          -> io (PhysicalDeviceFeatures)
getPhysicalDeviceFeatures :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice -> io PhysicalDeviceFeatures
getPhysicalDeviceFeatures PhysicalDevice
physicalDevice = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDeviceFeaturesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ())
vkGetPhysicalDeviceFeaturesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ())
pVkGetPhysicalDeviceFeatures (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ())
vkGetPhysicalDeviceFeaturesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceFeatures is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceFeatures' :: Ptr PhysicalDevice_T
-> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ()
vkGetPhysicalDeviceFeatures' = FunPtr
  (Ptr PhysicalDevice_T
   -> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ())
-> Ptr PhysicalDevice_T
-> ("pFeatures" ::: Ptr PhysicalDeviceFeatures)
-> IO ()
mkVkGetPhysicalDeviceFeatures FunPtr
  (Ptr PhysicalDevice_T
   -> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ())
vkGetPhysicalDeviceFeaturesPtr
  "pFeatures" ::: Ptr PhysicalDeviceFeatures
pPFeatures <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (forall a b. ToCStruct a => (Ptr a -> IO b) -> IO b
withZeroCStruct @PhysicalDeviceFeatures)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceFeatures" (Ptr PhysicalDevice_T
-> ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO ()
vkGetPhysicalDeviceFeatures'
                                                           (PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice))
                                                           ("pFeatures" ::: Ptr PhysicalDeviceFeatures
pPFeatures))
  PhysicalDeviceFeatures
pFeatures <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @PhysicalDeviceFeatures "pFeatures" ::: Ptr PhysicalDeviceFeatures
pPFeatures
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (PhysicalDeviceFeatures
pFeatures)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceFormatProperties
  :: FunPtr (Ptr PhysicalDevice_T -> Format -> Ptr FormatProperties -> IO ()) -> Ptr PhysicalDevice_T -> Format -> Ptr FormatProperties -> IO ()

-- | vkGetPhysicalDeviceFormatProperties - Lists physical device’s format
-- capabilities
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Enums.Format.Format', 'FormatProperties',
-- 'Vulkan.Core10.Handles.PhysicalDevice'
getPhysicalDeviceFormatProperties :: forall io
                                   . (MonadIO io)
                                  => -- | @physicalDevice@ is the physical device from which to query the format
                                     -- properties.
                                     --
                                     -- #VUID-vkGetPhysicalDeviceFormatProperties-physicalDevice-parameter#
                                     -- @physicalDevice@ /must/ be a valid
                                     -- 'Vulkan.Core10.Handles.PhysicalDevice' handle
                                     PhysicalDevice
                                  -> -- | @format@ is the format whose properties are queried.
                                     --
                                     -- #VUID-vkGetPhysicalDeviceFormatProperties-format-parameter# @format@
                                     -- /must/ be a valid 'Vulkan.Core10.Enums.Format.Format' value
                                     Format
                                  -> io (FormatProperties)
getPhysicalDeviceFormatProperties :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice -> Format -> io FormatProperties
getPhysicalDeviceFormatProperties PhysicalDevice
physicalDevice
                                    Format
format = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDeviceFormatPropertiesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ("pFormatProperties" ::: Ptr FormatProperties)
   -> IO ())
vkGetPhysicalDeviceFormatPropertiesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> Format
      -> ("pFormatProperties" ::: Ptr FormatProperties)
      -> IO ())
pVkGetPhysicalDeviceFormatProperties (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ("pFormatProperties" ::: Ptr FormatProperties)
   -> IO ())
vkGetPhysicalDeviceFormatPropertiesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceFormatProperties is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceFormatProperties' :: Ptr PhysicalDevice_T
-> Format
-> ("pFormatProperties" ::: Ptr FormatProperties)
-> IO ()
vkGetPhysicalDeviceFormatProperties' = FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ("pFormatProperties" ::: Ptr FormatProperties)
   -> IO ())
-> Ptr PhysicalDevice_T
-> Format
-> ("pFormatProperties" ::: Ptr FormatProperties)
-> IO ()
mkVkGetPhysicalDeviceFormatProperties FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ("pFormatProperties" ::: Ptr FormatProperties)
   -> IO ())
vkGetPhysicalDeviceFormatPropertiesPtr
  "pFormatProperties" ::: Ptr FormatProperties
pPFormatProperties <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (forall a b. ToCStruct a => (Ptr a -> IO b) -> IO b
withZeroCStruct @FormatProperties)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceFormatProperties" (Ptr PhysicalDevice_T
-> Format
-> ("pFormatProperties" ::: Ptr FormatProperties)
-> IO ()
vkGetPhysicalDeviceFormatProperties'
                                                                   (PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice))
                                                                   (Format
format)
                                                                   ("pFormatProperties" ::: Ptr FormatProperties
pPFormatProperties))
  FormatProperties
pFormatProperties <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @FormatProperties "pFormatProperties" ::: Ptr FormatProperties
pPFormatProperties
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (FormatProperties
pFormatProperties)


foreign import ccall
#if !defined(SAFE_FOREIGN_CALLS)
  unsafe
#endif
  "dynamic" mkVkGetPhysicalDeviceImageFormatProperties
  :: FunPtr (Ptr PhysicalDevice_T -> Format -> ImageType -> ImageTiling -> ImageUsageFlags -> ImageCreateFlags -> Ptr ImageFormatProperties -> IO Result) -> Ptr PhysicalDevice_T -> Format -> ImageType -> ImageTiling -> ImageUsageFlags -> ImageCreateFlags -> Ptr ImageFormatProperties -> IO Result

-- | vkGetPhysicalDeviceImageFormatProperties - Lists physical device’s image
-- format capabilities
--
-- = Description
--
-- The @format@, @type@, @tiling@, @usage@, and @flags@ parameters
-- correspond to parameters that would be consumed by
-- 'Vulkan.Core10.Image.createImage' (as members of
-- 'Vulkan.Core10.Image.ImageCreateInfo').
--
-- 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 'getPhysicalDeviceImageFormatProperties' returns
-- 'Vulkan.Core10.Enums.Result.ERROR_FORMAT_NOT_SUPPORTED'.
--
-- The limitations on an image format that are reported by
-- 'getPhysicalDeviceImageFormatProperties' have the following property: if
-- @usage1@ and @usage2@ of type
-- 'Vulkan.Core10.Enums.ImageUsageFlagBits.ImageUsageFlags' are such that
-- the bits set in @usage1@ are a subset of the bits set in @usage2@, and
-- @flags1@ and @flags2@ of type
-- 'Vulkan.Core10.Enums.ImageCreateFlagBits.ImageCreateFlags' 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@.
--
-- If @VK_EXT_host_image_copy@ is supported, @usage@ includes
-- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_SAMPLED_BIT', and
-- @flags@ does not include either of
-- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_BINDING_BIT',
-- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT',
-- or
-- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_ALIASED_BIT',
-- then the result of calls to 'getPhysicalDeviceImageFormatProperties'
-- with identical parameters except for the inclusion of
-- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_HOST_TRANSFER_BIT_EXT'
-- in @usage@ /must/ be identical.
--
-- == Return Codes
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-successcodes Success>]
--
--     -   'Vulkan.Core10.Enums.Result.SUCCESS'
--
-- [<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fundamentals-errorcodes Failure>]
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_HOST_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_OUT_OF_DEVICE_MEMORY'
--
--     -   'Vulkan.Core10.Enums.Result.ERROR_FORMAT_NOT_SUPPORTED'
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Enums.Format.Format',
-- 'Vulkan.Core10.Enums.ImageCreateFlagBits.ImageCreateFlags',
-- 'ImageFormatProperties', 'Vulkan.Core10.Enums.ImageTiling.ImageTiling',
-- 'Vulkan.Core10.Enums.ImageType.ImageType',
-- 'Vulkan.Core10.Enums.ImageUsageFlagBits.ImageUsageFlags',
-- 'Vulkan.Core10.Handles.PhysicalDevice'
getPhysicalDeviceImageFormatProperties :: forall io
                                        . (MonadIO io)
                                       => -- | @physicalDevice@ is the physical device from which to query the image
                                          -- capabilities.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-physicalDevice-parameter#
                                          -- @physicalDevice@ /must/ be a valid
                                          -- 'Vulkan.Core10.Handles.PhysicalDevice' handle
                                          PhysicalDevice
                                       -> -- | @format@ is a 'Vulkan.Core10.Enums.Format.Format' value specifying the
                                          -- image format, corresponding to
                                          -- 'Vulkan.Core10.Image.ImageCreateInfo'::@format@.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-format-parameter#
                                          -- @format@ /must/ be a valid 'Vulkan.Core10.Enums.Format.Format' value
                                          Format
                                       -> -- | @type@ is a 'Vulkan.Core10.Enums.ImageType.ImageType' value specifying
                                          -- the image type, corresponding to
                                          -- 'Vulkan.Core10.Image.ImageCreateInfo'::@imageType@.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-type-parameter# @type@
                                          -- /must/ be a valid 'Vulkan.Core10.Enums.ImageType.ImageType' value
                                          ImageType
                                       -> -- | @tiling@ is a 'Vulkan.Core10.Enums.ImageTiling.ImageTiling' value
                                          -- specifying the image tiling, corresponding to
                                          -- 'Vulkan.Core10.Image.ImageCreateInfo'::@tiling@.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-tiling-02248# @tiling@
                                          -- /must/ not be
                                          -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT'.
                                          -- (Use
                                          -- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.getPhysicalDeviceImageFormatProperties2'
                                          -- instead)
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-tiling-parameter#
                                          -- @tiling@ /must/ be a valid 'Vulkan.Core10.Enums.ImageTiling.ImageTiling'
                                          -- value
                                          ImageTiling
                                       -> -- | @usage@ is a bitmask of
                                          -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.ImageUsageFlagBits' specifying
                                          -- the intended usage of the image, corresponding to
                                          -- 'Vulkan.Core10.Image.ImageCreateInfo'::@usage@.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-usage-parameter# @usage@
                                          -- /must/ be a valid combination of
                                          -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.ImageUsageFlagBits' values
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-usage-requiredbitmask#
                                          -- @usage@ /must/ not be @0@
                                          ImageUsageFlags
                                       -> -- | @flags@ is a bitmask of
                                          -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.ImageCreateFlagBits' specifying
                                          -- additional parameters of the image, corresponding to
                                          -- 'Vulkan.Core10.Image.ImageCreateInfo'::@flags@.
                                          --
                                          -- #VUID-vkGetPhysicalDeviceImageFormatProperties-flags-parameter# @flags@
                                          -- /must/ be a valid combination of
                                          -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.ImageCreateFlagBits' values
                                          ImageCreateFlags
                                       -> io (ImageFormatProperties)
getPhysicalDeviceImageFormatProperties :: forall (io :: * -> *).
MonadIO io =>
PhysicalDevice
-> Format
-> ImageType
-> ImageTiling
-> ImageUsageFlags
-> ImageCreateFlags
-> io ImageFormatProperties
getPhysicalDeviceImageFormatProperties PhysicalDevice
physicalDevice
                                         Format
format
                                         ImageType
type'
                                         ImageTiling
tiling
                                         ImageUsageFlags
usage
                                         ImageCreateFlags
flags = forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
  let vkGetPhysicalDeviceImageFormatPropertiesPtr :: FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ImageType
   -> ImageTiling
   -> ImageUsageFlags
   -> ImageCreateFlags
   -> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
   -> IO Result)
vkGetPhysicalDeviceImageFormatPropertiesPtr = InstanceCmds
-> FunPtr
     (Ptr PhysicalDevice_T
      -> Format
      -> ImageType
      -> ImageTiling
      -> ImageUsageFlags
      -> ImageCreateFlags
      -> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
      -> IO Result)
pVkGetPhysicalDeviceImageFormatProperties (case PhysicalDevice
physicalDevice of PhysicalDevice{InstanceCmds
instanceCmds :: InstanceCmds
$sel:instanceCmds:PhysicalDevice :: PhysicalDevice -> InstanceCmds
instanceCmds} -> InstanceCmds
instanceCmds)
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ImageType
   -> ImageTiling
   -> ImageUsageFlags
   -> ImageCreateFlags
   -> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
   -> IO Result)
vkGetPhysicalDeviceImageFormatPropertiesPtr forall a. Eq a => a -> a -> Bool
/= forall a. FunPtr a
nullFunPtr) forall a b. (a -> b) -> a -> b
$
    forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"The function pointer for vkGetPhysicalDeviceImageFormatProperties is null" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
  let vkGetPhysicalDeviceImageFormatProperties' :: Ptr PhysicalDevice_T
-> Format
-> ImageType
-> ImageTiling
-> ImageUsageFlags
-> ImageCreateFlags
-> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO Result
vkGetPhysicalDeviceImageFormatProperties' = FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ImageType
   -> ImageTiling
   -> ImageUsageFlags
   -> ImageCreateFlags
   -> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
   -> IO Result)
-> Ptr PhysicalDevice_T
-> Format
-> ImageType
-> ImageTiling
-> ImageUsageFlags
-> ImageCreateFlags
-> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO Result
mkVkGetPhysicalDeviceImageFormatProperties FunPtr
  (Ptr PhysicalDevice_T
   -> Format
   -> ImageType
   -> ImageTiling
   -> ImageUsageFlags
   -> ImageCreateFlags
   -> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
   -> IO Result)
vkGetPhysicalDeviceImageFormatPropertiesPtr
  "pImageFormatProperties" ::: Ptr ImageFormatProperties
pPImageFormatProperties <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT (forall a b. ToCStruct a => (Ptr a -> IO b) -> IO b
withZeroCStruct @ImageFormatProperties)
  Result
r <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. String -> IO a -> IO a
traceAroundEvent String
"vkGetPhysicalDeviceImageFormatProperties" (Ptr PhysicalDevice_T
-> Format
-> ImageType
-> ImageTiling
-> ImageUsageFlags
-> ImageCreateFlags
-> ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO Result
vkGetPhysicalDeviceImageFormatProperties'
                                                                             (PhysicalDevice -> Ptr PhysicalDevice_T
physicalDeviceHandle (PhysicalDevice
physicalDevice))
                                                                             (Format
format)
                                                                             (ImageType
type')
                                                                             (ImageTiling
tiling)
                                                                             (ImageUsageFlags
usage)
                                                                             (ImageCreateFlags
flags)
                                                                             ("pImageFormatProperties" ::: Ptr ImageFormatProperties
pPImageFormatProperties))
  forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Result
r forall a. Ord a => a -> a -> Bool
< Result
SUCCESS) (forall e a. Exception e => e -> IO a
throwIO (Result -> VulkanException
VulkanException Result
r))
  ImageFormatProperties
pImageFormatProperties <- forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ImageFormatProperties "pImageFormatProperties" ::: Ptr ImageFormatProperties
pPImageFormatProperties
  forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ (ImageFormatProperties
pImageFormatProperties)


-- | VkPhysicalDeviceProperties - Structure specifying physical device
-- properties
--
-- = Description
--
-- Note
--
-- The value of @apiVersion@ /may/ be different than the version returned
-- by 'Vulkan.Core11.DeviceInitialization.enumerateInstanceVersion'; either
-- higher or lower. In such cases, the application /must/ not use
-- functionality that exceeds the version of Vulkan associated with a given
-- object. The @pApiVersion@ parameter returned by
-- 'Vulkan.Core11.DeviceInitialization.enumerateInstanceVersion' is the
-- version associated with a 'Vulkan.Core10.Handles.Instance' and its
-- children, except for a 'Vulkan.Core10.Handles.PhysicalDevice' and its
-- children. 'PhysicalDeviceProperties'::@apiVersion@ is the version
-- associated with a 'Vulkan.Core10.Handles.PhysicalDevice' and its
-- children.
--
-- Note
--
-- The encoding of @driverVersion@ is implementation-defined. It /may/ not
-- use the same encoding as @apiVersion@. Applications should follow
-- information from the /vendor/ on how to extract the version information
-- from @driverVersion@.
--
-- On implementations that claim support for the
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#roadmap-2022 Roadmap 2022>
-- profile, the major and minor version expressed by @apiVersion@ /must/ be
-- at least Vulkan 1.3.
--
-- 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
-- 'Vulkan.Core10.Handles.PhysicalDevice' 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
-- <https://pcisig.com/membership/member-companies 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
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#vulkan-styleguide Vulkan Documentation and Extensions: Procedures and Conventions>
-- 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. Khronos vendor IDs are symbolically defined
-- in the 'Vulkan.Core10.Enums.VendorId.VendorId' type.
--
-- The vendor is also responsible for the value returned in @deviceID@. If
-- the implementation is driven primarily by a
-- <https://pcisig.com/ PCI device> with a
-- <https://pcisig.com/ 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
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'PhysicalDeviceLimits',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceProperties2',
-- 'PhysicalDeviceSparseProperties',
-- 'Vulkan.Core10.Enums.PhysicalDeviceType.PhysicalDeviceType',
-- 'getPhysicalDeviceProperties'
data PhysicalDeviceProperties = PhysicalDeviceProperties
  { -- | @apiVersion@ is the version of Vulkan supported by the device, encoded
    -- as described in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#extendingvulkan-coreversions-versionnumbers>.
    PhysicalDeviceProperties -> Word32
apiVersion :: Word32
  , -- | @driverVersion@ is the vendor-specified version of the driver.
    PhysicalDeviceProperties -> Word32
driverVersion :: Word32
  , -- | @vendorID@ is a unique identifier for the /vendor/ (see below) of the
    -- physical device.
    PhysicalDeviceProperties -> Word32
vendorID :: Word32
  , -- | @deviceID@ is a unique identifier for the physical device among devices
    -- available from the vendor.
    PhysicalDeviceProperties -> Word32
deviceID :: Word32
  , -- | @deviceType@ is a
    -- 'Vulkan.Core10.Enums.PhysicalDeviceType.PhysicalDeviceType' specifying
    -- the type of device.
    PhysicalDeviceProperties -> PhysicalDeviceType
deviceType :: PhysicalDeviceType
  , -- | @deviceName@ is an array of
    -- 'Vulkan.Core10.APIConstants.MAX_PHYSICAL_DEVICE_NAME_SIZE' @char@
    -- containing a null-terminated UTF-8 string which is the name of the
    -- device.
    PhysicalDeviceProperties -> "name" ::: ByteString
deviceName :: ByteString
  , -- | @pipelineCacheUUID@ is an array of
    -- 'Vulkan.Core10.APIConstants.UUID_SIZE' @uint8_t@ values representing a
    -- universally unique identifier for the device.
    PhysicalDeviceProperties -> "name" ::: ByteString
pipelineCacheUUID :: ByteString
  , -- | @limits@ is the 'PhysicalDeviceLimits' structure specifying
    -- device-specific limits of the physical device. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits Limits>
    -- for details.
    PhysicalDeviceProperties -> PhysicalDeviceLimits
limits :: PhysicalDeviceLimits
  , -- | @sparseProperties@ is the 'PhysicalDeviceSparseProperties' structure
    -- specifying various sparse related properties of the physical device. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#sparsememory-physicalprops Sparse Properties>
    -- for details.
    PhysicalDeviceProperties -> PhysicalDeviceSparseProperties
sparseProperties :: PhysicalDeviceSparseProperties
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceProperties)
#endif
deriving instance Show PhysicalDeviceProperties

instance ToCStruct PhysicalDeviceProperties where
  withCStruct :: forall b.
PhysicalDeviceProperties
-> (("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO b)
-> IO b
withCStruct PhysicalDeviceProperties
x ("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
824 forall a b. (a -> b) -> a -> b
$ \"pProperties" ::: Ptr PhysicalDeviceProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pProperties" ::: Ptr PhysicalDeviceProperties
p PhysicalDeviceProperties
x (("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO b
f "pProperties" ::: Ptr PhysicalDeviceProperties
p)
  pokeCStruct :: forall b.
("pProperties" ::: Ptr PhysicalDeviceProperties)
-> PhysicalDeviceProperties -> IO b -> IO b
pokeCStruct "pProperties" ::: Ptr PhysicalDeviceProperties
p PhysicalDeviceProperties{Word32
"name" ::: ByteString
PhysicalDeviceSparseProperties
PhysicalDeviceLimits
PhysicalDeviceType
sparseProperties :: PhysicalDeviceSparseProperties
limits :: PhysicalDeviceLimits
pipelineCacheUUID :: "name" ::: ByteString
deviceName :: "name" ::: ByteString
deviceType :: PhysicalDeviceType
deviceID :: Word32
vendorID :: Word32
driverVersion :: Word32
apiVersion :: Word32
$sel:sparseProperties:PhysicalDeviceProperties :: PhysicalDeviceProperties -> PhysicalDeviceSparseProperties
$sel:limits:PhysicalDeviceProperties :: PhysicalDeviceProperties -> PhysicalDeviceLimits
$sel:pipelineCacheUUID:PhysicalDeviceProperties :: PhysicalDeviceProperties -> "name" ::: ByteString
$sel:deviceName:PhysicalDeviceProperties :: PhysicalDeviceProperties -> "name" ::: ByteString
$sel:deviceType:PhysicalDeviceProperties :: PhysicalDeviceProperties -> PhysicalDeviceType
$sel:deviceID:PhysicalDeviceProperties :: PhysicalDeviceProperties -> Word32
$sel:vendorID:PhysicalDeviceProperties :: PhysicalDeviceProperties -> Word32
$sel:driverVersion:PhysicalDeviceProperties :: PhysicalDeviceProperties -> Word32
$sel:apiVersion:PhysicalDeviceProperties :: PhysicalDeviceProperties -> Word32
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (Word32
apiVersion)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (Word32
driverVersion)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (Word32
vendorID)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (Word32
deviceID)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr PhysicalDeviceType)) (PhysicalDeviceType
deviceType)
    forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n CChar) -> ("name" ::: ByteString) -> IO ()
pokeFixedLengthNullTerminatedByteString (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr (FixedArray MAX_PHYSICAL_DEVICE_NAME_SIZE CChar))) ("name" ::: ByteString
deviceName)
    forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n Word8) -> ("name" ::: ByteString) -> IO ()
pokeFixedLengthByteString (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr (FixedArray UUID_SIZE Word8))) ("name" ::: ByteString
pipelineCacheUUID)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr PhysicalDeviceLimits)) (PhysicalDeviceLimits
limits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
800 :: Ptr PhysicalDeviceSparseProperties)) (PhysicalDeviceSparseProperties
sparseProperties)
    IO b
f
  cStructSize :: Int
cStructSize = Int
824
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b.
("pProperties" ::: Ptr PhysicalDeviceProperties) -> IO b -> IO b
pokeZeroCStruct "pProperties" ::: Ptr PhysicalDeviceProperties
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr PhysicalDeviceType)) (forall a. Zero a => a
zero)
    forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n CChar) -> ("name" ::: ByteString) -> IO ()
pokeFixedLengthNullTerminatedByteString (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr (FixedArray MAX_PHYSICAL_DEVICE_NAME_SIZE CChar))) (forall a. Monoid a => a
mempty)
    forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n Word8) -> ("name" ::: ByteString) -> IO ()
pokeFixedLengthByteString (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr (FixedArray UUID_SIZE Word8))) (forall a. Monoid a => a
mempty)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr PhysicalDeviceLimits)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
800 :: Ptr PhysicalDeviceSparseProperties)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct PhysicalDeviceProperties where
  peekCStruct :: ("pProperties" ::: Ptr PhysicalDeviceProperties)
-> IO PhysicalDeviceProperties
peekCStruct "pProperties" ::: Ptr PhysicalDeviceProperties
p = do
    Word32
apiVersion <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32))
    Word32
driverVersion <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32))
    Word32
vendorID <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32))
    Word32
deviceID <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32))
    PhysicalDeviceType
deviceType <- forall a. Storable a => Ptr a -> IO a
peek @PhysicalDeviceType (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr PhysicalDeviceType))
    "name" ::: ByteString
deviceName <- ("pName" ::: Ptr CChar) -> IO ("name" ::: ByteString)
packCString (forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr (FixedArray MAX_PHYSICAL_DEVICE_NAME_SIZE CChar))))
    "name" ::: ByteString
pipelineCacheUUID <- forall (n :: Nat).
KnownNat n =>
Ptr (FixedArray n Word8) -> IO ("name" ::: ByteString)
peekByteStringFromSizedVectorPtr (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr (FixedArray UUID_SIZE Word8)))
    PhysicalDeviceLimits
limits <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @PhysicalDeviceLimits (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr PhysicalDeviceLimits))
    PhysicalDeviceSparseProperties
sparseProperties <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @PhysicalDeviceSparseProperties (("pProperties" ::: Ptr PhysicalDeviceProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
800 :: Ptr PhysicalDeviceSparseProperties))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Word32
-> Word32
-> Word32
-> Word32
-> PhysicalDeviceType
-> ("name" ::: ByteString)
-> ("name" ::: ByteString)
-> PhysicalDeviceLimits
-> PhysicalDeviceSparseProperties
-> PhysicalDeviceProperties
PhysicalDeviceProperties
             Word32
apiVersion
             Word32
driverVersion
             Word32
vendorID
             Word32
deviceID
             PhysicalDeviceType
deviceType
             "name" ::: ByteString
deviceName
             "name" ::: ByteString
pipelineCacheUUID
             PhysicalDeviceLimits
limits
             PhysicalDeviceSparseProperties
sparseProperties

instance Storable PhysicalDeviceProperties where
  sizeOf :: PhysicalDeviceProperties -> Int
sizeOf ~PhysicalDeviceProperties
_ = Int
824
  alignment :: PhysicalDeviceProperties -> Int
alignment ~PhysicalDeviceProperties
_ = Int
8
  peek :: ("pProperties" ::: Ptr PhysicalDeviceProperties)
-> IO PhysicalDeviceProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pProperties" ::: Ptr PhysicalDeviceProperties)
-> PhysicalDeviceProperties -> IO ()
poke "pProperties" ::: Ptr PhysicalDeviceProperties
ptr PhysicalDeviceProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pProperties" ::: Ptr PhysicalDeviceProperties
ptr PhysicalDeviceProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero PhysicalDeviceProperties where
  zero :: PhysicalDeviceProperties
zero = Word32
-> Word32
-> Word32
-> Word32
-> PhysicalDeviceType
-> ("name" ::: ByteString)
-> ("name" ::: ByteString)
-> PhysicalDeviceLimits
-> PhysicalDeviceSparseProperties
-> PhysicalDeviceProperties
PhysicalDeviceProperties
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Monoid a => a
mempty
           forall a. Monoid a => a
mempty
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkApplicationInfo - Structure specifying application information
--
-- = Description
--
-- Vulkan 1.0 implementations were required to return
-- 'Vulkan.Core10.Enums.Result.ERROR_INCOMPATIBLE_DRIVER' if @apiVersion@
-- was larger than 1.0. Implementations that support Vulkan 1.1 or later
-- /must/ not return 'Vulkan.Core10.Enums.Result.ERROR_INCOMPATIBLE_DRIVER'
-- for any value of @apiVersion@ .
--
-- Note
--
-- Because Vulkan 1.0 implementations /may/ fail with
-- 'Vulkan.Core10.Enums.Result.ERROR_INCOMPATIBLE_DRIVER', applications
-- /should/ determine the version of Vulkan available before calling
-- 'createInstance'. If the 'getInstanceProcAddr' returns @NULL@ for
-- 'Vulkan.Core11.DeviceInitialization.enumerateInstanceVersion', it is a
-- Vulkan 1.0 implementation. Otherwise, the application /can/ call
-- 'Vulkan.Core11.DeviceInitialization.enumerateInstanceVersion' to
-- determine the version of Vulkan.
--
-- As long as the instance supports at least Vulkan 1.1, an application
-- /can/ use different versions of Vulkan with an instance than it does
-- with a device or physical device.
--
-- Note
--
-- The Khronos validation layers will treat @apiVersion@ as the highest API
-- version the application targets, and will validate API usage against the
-- minimum of that version and the implementation version (instance or
-- device, depending on context). If an application tries to use
-- functionality from a greater version than this, a validation error will
-- be triggered.
--
-- For example, if the instance supports Vulkan 1.1 and three physical
-- devices support Vulkan 1.0, Vulkan 1.1, and Vulkan 1.2, respectively,
-- and if the application sets @apiVersion@ to 1.2, the application /can/
-- use the following versions of Vulkan:
--
-- -   Vulkan 1.0 /can/ be used with the instance and with all physical
--     devices.
--
-- -   Vulkan 1.1 /can/ be used with the instance and with the physical
--     devices that support Vulkan 1.1 and Vulkan 1.2.
--
-- -   Vulkan 1.2 /can/ be used with the physical device that supports
--     Vulkan 1.2.
--
-- If we modify the above example so that the application sets @apiVersion@
-- to 1.1, then the application /must/ not use Vulkan 1.2 functionality on
-- the physical device that supports Vulkan 1.2.
--
-- Note
--
-- Providing a @NULL@ 'InstanceCreateInfo'::@pApplicationInfo@ or providing
-- an @apiVersion@ of 0 is equivalent to providing an @apiVersion@ of
-- @VK_MAKE_API_VERSION(0,1,0,0)@.
--
-- == Valid Usage
--
-- -   #VUID-VkApplicationInfo-apiVersion-04010# If @apiVersion@ is not
--     @0@, then it /must/ be greater than or equal to
--     'Vulkan.Core10.API_VERSION_1_0'
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-VkApplicationInfo-sType-sType# @sType@ /must/ be
--     'Vulkan.Core10.Enums.StructureType.STRUCTURE_TYPE_APPLICATION_INFO'
--
-- -   #VUID-VkApplicationInfo-pNext-pNext# @pNext@ /must/ be @NULL@
--
-- -   #VUID-VkApplicationInfo-pApplicationName-parameter# If
--     @pApplicationName@ is not @NULL@, @pApplicationName@ /must/ be a
--     null-terminated UTF-8 string
--
-- -   #VUID-VkApplicationInfo-pEngineName-parameter# If @pEngineName@ is
--     not @NULL@, @pEngineName@ /must/ be a null-terminated UTF-8 string
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'InstanceCreateInfo', 'Vulkan.Core10.Enums.StructureType.StructureType'
data ApplicationInfo = ApplicationInfo
  { -- | @pApplicationName@ is @NULL@ or is a pointer to a null-terminated UTF-8
    -- string containing the name of the application.
    ApplicationInfo -> Maybe ("name" ::: ByteString)
applicationName :: Maybe ByteString
  , -- | @applicationVersion@ is an unsigned integer variable containing the
    -- developer-supplied version number of the application.
    ApplicationInfo -> Word32
applicationVersion :: 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.
    ApplicationInfo -> Maybe ("name" ::: ByteString)
engineName :: Maybe ByteString
  , -- | @engineVersion@ is an unsigned integer variable containing the
    -- developer-supplied version number of the engine used to create the
    -- application.
    ApplicationInfo -> Word32
engineVersion :: Word32
  , -- | @apiVersion@ /must/ be the highest version of Vulkan that the
    -- application is designed to use, encoded as described in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#extendingvulkan-coreversions-versionnumbers>.
    -- The patch version number specified in @apiVersion@ is ignored when
    -- creating an instance object. The variant version of the instance /must/
    -- match that requested in @apiVersion@.
    ApplicationInfo -> Word32
apiVersion :: Word32
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (ApplicationInfo)
#endif
deriving instance Show ApplicationInfo

instance ToCStruct ApplicationInfo where
  withCStruct :: forall b. ApplicationInfo -> (Ptr ApplicationInfo -> IO b) -> IO b
withCStruct ApplicationInfo
x Ptr ApplicationInfo -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
48 forall a b. (a -> b) -> a -> b
$ \Ptr ApplicationInfo
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr ApplicationInfo
p ApplicationInfo
x (Ptr ApplicationInfo -> IO b
f Ptr ApplicationInfo
p)
  pokeCStruct :: forall b. Ptr ApplicationInfo -> ApplicationInfo -> IO b -> IO b
pokeCStruct Ptr ApplicationInfo
p ApplicationInfo{Maybe ("name" ::: ByteString)
Word32
apiVersion :: Word32
engineVersion :: Word32
engineName :: Maybe ("name" ::: ByteString)
applicationVersion :: Word32
applicationName :: Maybe ("name" ::: ByteString)
$sel:apiVersion:ApplicationInfo :: ApplicationInfo -> Word32
$sel:engineVersion:ApplicationInfo :: ApplicationInfo -> Word32
$sel:engineName:ApplicationInfo :: ApplicationInfo -> Maybe ("name" ::: ByteString)
$sel:applicationVersion:ApplicationInfo :: ApplicationInfo -> Word32
$sel:applicationName:ApplicationInfo :: ApplicationInfo -> Maybe ("name" ::: ByteString)
..} IO b
f = forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_APPLICATION_INFO)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (forall a. Ptr a
nullPtr)
    "pName" ::: Ptr CChar
pApplicationName'' <- case (Maybe ("name" ::: ByteString)
applicationName) of
      Maybe ("name" ::: ByteString)
Nothing -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Ptr a
nullPtr
      Just "name" ::: ByteString
j -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
j)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr CChar))) "pName" ::: Ptr CChar
pApplicationName''
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Word32
applicationVersion)
    "pName" ::: Ptr CChar
pEngineName'' <- case (Maybe ("name" ::: ByteString)
engineName) of
      Maybe ("name" ::: ByteString)
Nothing -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Ptr a
nullPtr
      Just "name" ::: ByteString
j -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
j)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr (Ptr CChar))) "pName" ::: Ptr CChar
pEngineName''
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32)) (Word32
engineVersion)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Word32)) (Word32
apiVersion)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ IO b
f
  cStructSize :: Int
cStructSize = Int
48
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b. Ptr ApplicationInfo -> IO b -> IO b
pokeZeroCStruct Ptr ApplicationInfo
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_APPLICATION_INFO)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (forall a. Ptr a
nullPtr)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Word32)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct ApplicationInfo where
  peekCStruct :: Ptr ApplicationInfo -> IO ApplicationInfo
peekCStruct Ptr ApplicationInfo
p = do
    "pName" ::: Ptr CChar
pApplicationName <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr CChar) ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr (Ptr CChar)))
    Maybe ("name" ::: ByteString)
pApplicationName' <- forall a b. (Ptr a -> IO b) -> Ptr a -> IO (Maybe b)
maybePeek (\"pName" ::: Ptr CChar
j -> ("pName" ::: Ptr CChar) -> IO ("name" ::: ByteString)
packCString ("pName" ::: Ptr CChar
j)) "pName" ::: Ptr CChar
pApplicationName
    Word32
applicationVersion <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32))
    "pName" ::: Ptr CChar
pEngineName <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr CChar) ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr (Ptr CChar)))
    Maybe ("name" ::: ByteString)
pEngineName' <- forall a b. (Ptr a -> IO b) -> Ptr a -> IO (Maybe b)
maybePeek (\"pName" ::: Ptr CChar
j -> ("pName" ::: Ptr CChar) -> IO ("name" ::: ByteString)
packCString ("pName" ::: Ptr CChar
j)) "pName" ::: Ptr CChar
pEngineName
    Word32
engineVersion <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32))
    Word32
apiVersion <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr ApplicationInfo
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Word32))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Maybe ("name" ::: ByteString)
-> Word32
-> Maybe ("name" ::: ByteString)
-> Word32
-> Word32
-> ApplicationInfo
ApplicationInfo
             Maybe ("name" ::: ByteString)
pApplicationName'
             Word32
applicationVersion
             Maybe ("name" ::: ByteString)
pEngineName'
             Word32
engineVersion
             Word32
apiVersion

instance Zero ApplicationInfo where
  zero :: ApplicationInfo
zero = Maybe ("name" ::: ByteString)
-> Word32
-> Maybe ("name" ::: ByteString)
-> Word32
-> Word32
-> ApplicationInfo
ApplicationInfo
           forall a. Maybe a
Nothing
           forall a. Zero a => a
zero
           forall a. Maybe a
Nothing
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkInstanceCreateInfo - Structure specifying parameters of a newly
-- created instance
--
-- = Description
--
-- To capture events that occur while creating or destroying an instance,
-- an application /can/ link a
-- 'Vulkan.Extensions.VK_EXT_debug_report.DebugReportCallbackCreateInfoEXT'
-- structure or a
-- 'Vulkan.Extensions.VK_EXT_debug_utils.DebugUtilsMessengerCreateInfoEXT'
-- structure to the @pNext@ element of the 'InstanceCreateInfo' structure
-- given to 'createInstance'. This callback is only valid for the duration
-- of the 'createInstance' and the 'destroyInstance' call. Use
-- 'Vulkan.Extensions.VK_EXT_debug_report.createDebugReportCallbackEXT' or
-- 'Vulkan.Extensions.VK_EXT_debug_utils.createDebugUtilsMessengerEXT' to
-- create persistent callback objects.
--
-- An application can add additional drivers by including the
-- 'Vulkan.Extensions.VK_LUNARG_direct_driver_loading.DirectDriverLoadingListLUNARG'
-- struct to the @pNext@ element of the 'InstanceCreateInfo' structure
-- given to 'createInstance'.
--
-- Note
--
-- 'Vulkan.Extensions.VK_LUNARG_direct_driver_loading.DirectDriverLoadingListLUNARG'
-- allows applications to ship drivers with themselves. Only drivers that
-- are designed to work with it should be used, such as drivers that
-- implement Vulkan in software or that implement Vulkan by translating it
-- to a different API. Any driver that requires installation should not be
-- used, such as hardware drivers.
--
-- == Valid Usage
--
-- -   #VUID-VkInstanceCreateInfo-pNext-04925# If the @pNext@ chain of
--     'InstanceCreateInfo' includes a
--     'Vulkan.Extensions.VK_EXT_debug_report.DebugReportCallbackCreateInfoEXT'
--     structure, the list of enabled extensions in
--     @ppEnabledExtensionNames@ /must/ contain @VK_EXT_debug_report@
--
-- -   #VUID-VkInstanceCreateInfo-pNext-04926# If the @pNext@ chain of
--     'InstanceCreateInfo' includes a
--     'Vulkan.Extensions.VK_EXT_debug_utils.DebugUtilsMessengerCreateInfoEXT'
--     structure, the list of enabled extensions in
--     @ppEnabledExtensionNames@ /must/ contain @VK_EXT_debug_utils@
--
-- -   #VUID-VkInstanceCreateInfo-pNext-06779# If the @pNext@ chain
--     includes a
--     'Vulkan.Extensions.VK_EXT_metal_objects.ExportMetalObjectCreateInfoEXT'
--     structure, its @exportObjectType@ member /must/ be either
--     'Vulkan.Extensions.VK_EXT_metal_objects.EXPORT_METAL_OBJECT_TYPE_METAL_DEVICE_BIT_EXT'
--     or
--     'Vulkan.Extensions.VK_EXT_metal_objects.EXPORT_METAL_OBJECT_TYPE_METAL_COMMAND_QUEUE_BIT_EXT'
--
-- -   #VUID-VkInstanceCreateInfo-flags-06559# If @flags@ has the
--     'Vulkan.Core10.Enums.InstanceCreateFlagBits.INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR'
--     bit set, the list of enabled extensions in @ppEnabledExtensionNames@
--     /must/ contain @VK_KHR_portability_enumeration@
--
-- -   #VUID-VkInstanceCreateInfo-pNext-09400# If the @pNext@ chain of
--     'InstanceCreateInfo' includes a
--     'Vulkan.Extensions.VK_LUNARG_direct_driver_loading.DirectDriverLoadingListLUNARG'
--     structure, the list of enabled extensions in
--     @ppEnabledExtensionNames@ /must/ contain
--     <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_LUNARG_direct_driver_loading VK_LUNARG_direct_driver_loading>
--
-- == Valid Usage (Implicit)
--
-- -   #VUID-VkInstanceCreateInfo-sType-sType# @sType@ /must/ be
--     'Vulkan.Core10.Enums.StructureType.STRUCTURE_TYPE_INSTANCE_CREATE_INFO'
--
-- -   #VUID-VkInstanceCreateInfo-pNext-pNext# 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
--     'Vulkan.Extensions.VK_EXT_debug_report.DebugReportCallbackCreateInfoEXT',
--     'Vulkan.Extensions.VK_EXT_debug_utils.DebugUtilsMessengerCreateInfoEXT',
--     'Vulkan.Extensions.VK_LUNARG_direct_driver_loading.DirectDriverLoadingListLUNARG',
--     'Vulkan.Extensions.VK_EXT_metal_objects.ExportMetalObjectCreateInfoEXT',
--     'Vulkan.Extensions.VK_EXT_validation_features.ValidationFeaturesEXT',
--     or 'Vulkan.Extensions.VK_EXT_validation_flags.ValidationFlagsEXT'
--
-- -   #VUID-VkInstanceCreateInfo-sType-unique# The @sType@ value of each
--     struct in the @pNext@ chain /must/ be unique, with the exception of
--     structures of type
--     'Vulkan.Extensions.VK_EXT_debug_utils.DebugUtilsMessengerCreateInfoEXT'
--     or
--     'Vulkan.Extensions.VK_EXT_metal_objects.ExportMetalObjectCreateInfoEXT'
--
-- -   #VUID-VkInstanceCreateInfo-flags-parameter# @flags@ /must/ be a
--     valid combination of
--     'Vulkan.Core10.Enums.InstanceCreateFlagBits.InstanceCreateFlagBits'
--     values
--
-- -   #VUID-VkInstanceCreateInfo-pApplicationInfo-parameter# If
--     @pApplicationInfo@ is not @NULL@, @pApplicationInfo@ /must/ be a
--     valid pointer to a valid 'ApplicationInfo' structure
--
-- -   #VUID-VkInstanceCreateInfo-ppEnabledLayerNames-parameter# If
--     @enabledLayerCount@ is not @0@, @ppEnabledLayerNames@ /must/ be a
--     valid pointer to an array of @enabledLayerCount@ null-terminated
--     UTF-8 strings
--
-- -   #VUID-VkInstanceCreateInfo-ppEnabledExtensionNames-parameter# If
--     @enabledExtensionCount@ is not @0@, @ppEnabledExtensionNames@ /must/
--     be a valid pointer to an array of @enabledExtensionCount@
--     null-terminated UTF-8 strings
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'ApplicationInfo',
-- 'Vulkan.Core10.Enums.InstanceCreateFlagBits.InstanceCreateFlags',
-- 'Vulkan.Core10.Enums.StructureType.StructureType', 'createInstance'
data InstanceCreateInfo (es :: [Type]) = InstanceCreateInfo
  { -- | @pNext@ is @NULL@ or a pointer to a structure extending this structure.
    forall (es :: [*]). InstanceCreateInfo es -> Chain es
next :: Chain es
  , -- | @flags@ is a bitmask of
    -- 'Vulkan.Core10.Enums.InstanceCreateFlagBits.InstanceCreateFlagBits'
    -- indicating the behavior of the instance.
    forall (es :: [*]). InstanceCreateInfo es -> InstanceCreateFlags
flags :: InstanceCreateFlags
  , -- | @pApplicationInfo@ is @NULL@ or a pointer to a 'ApplicationInfo'
    -- structure. If not @NULL@, this information helps implementations
    -- recognize behavior inherent to classes of applications.
    -- 'ApplicationInfo' is defined in detail below.
    forall (es :: [*]). InstanceCreateInfo es -> Maybe ApplicationInfo
applicationInfo :: Maybe ApplicationInfo
  , -- | @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. The layers are loaded in the order they are
    -- listed in this array, with the first array element being the closest to
    -- the application, and the last array element being the closest to the
    -- driver. See the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#extendingvulkan-layers>
    -- section for further details.
    forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
enabledLayerNames :: Vector ByteString
  , -- | @ppEnabledExtensionNames@ is a pointer to an array of
    -- @enabledExtensionCount@ null-terminated UTF-8 strings containing the
    -- names of extensions to enable.
    forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
enabledExtensionNames :: Vector ByteString
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (InstanceCreateInfo (es :: [Type]))
#endif
deriving instance Show (Chain es) => Show (InstanceCreateInfo es)

instance Extensible InstanceCreateInfo where
  extensibleTypeName :: String
extensibleTypeName = String
"InstanceCreateInfo"
  setNext :: forall (ds :: [*]) (es :: [*]).
InstanceCreateInfo ds -> Chain es -> InstanceCreateInfo es
setNext InstanceCreateInfo{Maybe ApplicationInfo
Vector ("name" ::: ByteString)
Chain ds
InstanceCreateFlags
enabledExtensionNames :: Vector ("name" ::: ByteString)
enabledLayerNames :: Vector ("name" ::: ByteString)
applicationInfo :: Maybe ApplicationInfo
flags :: InstanceCreateFlags
next :: Chain ds
$sel:enabledExtensionNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:enabledLayerNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:applicationInfo:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Maybe ApplicationInfo
$sel:flags:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> InstanceCreateFlags
$sel:next:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Chain es
..} Chain es
next' = InstanceCreateInfo{$sel:next:InstanceCreateInfo :: Chain es
next = Chain es
next', Maybe ApplicationInfo
Vector ("name" ::: ByteString)
InstanceCreateFlags
enabledExtensionNames :: Vector ("name" ::: ByteString)
enabledLayerNames :: Vector ("name" ::: ByteString)
applicationInfo :: Maybe ApplicationInfo
flags :: InstanceCreateFlags
$sel:enabledExtensionNames:InstanceCreateInfo :: Vector ("name" ::: ByteString)
$sel:enabledLayerNames:InstanceCreateInfo :: Vector ("name" ::: ByteString)
$sel:applicationInfo:InstanceCreateInfo :: Maybe ApplicationInfo
$sel:flags:InstanceCreateInfo :: InstanceCreateFlags
..}
  getNext :: forall (es :: [*]). InstanceCreateInfo es -> Chain es
getNext InstanceCreateInfo{Maybe ApplicationInfo
Vector ("name" ::: ByteString)
Chain es
InstanceCreateFlags
enabledExtensionNames :: Vector ("name" ::: ByteString)
enabledLayerNames :: Vector ("name" ::: ByteString)
applicationInfo :: Maybe ApplicationInfo
flags :: InstanceCreateFlags
next :: Chain es
$sel:enabledExtensionNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:enabledLayerNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:applicationInfo:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Maybe ApplicationInfo
$sel:flags:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> InstanceCreateFlags
$sel:next:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Chain es
..} = Chain es
next
  extends :: forall e b proxy. Typeable e => proxy e -> (Extends InstanceCreateInfo e => b) -> Maybe b
  extends :: forall e b (proxy :: * -> *).
Typeable e =>
proxy e -> (Extends InstanceCreateInfo e => b) -> Maybe b
extends proxy e
_ Extends InstanceCreateInfo e => b
f
    | Just e :~: DirectDriverLoadingListLUNARG
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @DirectDriverLoadingListLUNARG = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Just e :~: ExportMetalObjectCreateInfoEXT
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @ExportMetalObjectCreateInfoEXT = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Just e :~: DebugUtilsMessengerCreateInfoEXT
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @DebugUtilsMessengerCreateInfoEXT = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Just e :~: ValidationFeaturesEXT
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @ValidationFeaturesEXT = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Just e :~: ValidationFlagsEXT
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @ValidationFlagsEXT = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Just e :~: DebugReportCallbackCreateInfoEXT
Refl <- forall {k} (a :: k) (b :: k).
(Typeable a, Typeable b) =>
Maybe (a :~: b)
eqT @e @DebugReportCallbackCreateInfoEXT = forall a. a -> Maybe a
Just Extends InstanceCreateInfo e => b
f
    | Bool
otherwise = forall a. Maybe a
Nothing

instance ( Extendss InstanceCreateInfo es
         , PokeChain es ) => ToCStruct (InstanceCreateInfo es) where
  withCStruct :: forall b.
InstanceCreateInfo es
-> (Ptr (InstanceCreateInfo es) -> IO b) -> IO b
withCStruct InstanceCreateInfo es
x Ptr (InstanceCreateInfo es) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
64 forall a b. (a -> b) -> a -> b
$ \Ptr (InstanceCreateInfo es)
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr (InstanceCreateInfo es)
p InstanceCreateInfo es
x (Ptr (InstanceCreateInfo es) -> IO b
f Ptr (InstanceCreateInfo es)
p)
  pokeCStruct :: forall b.
Ptr (InstanceCreateInfo es)
-> InstanceCreateInfo es -> IO b -> IO b
pokeCStruct Ptr (InstanceCreateInfo es)
p InstanceCreateInfo{Maybe ApplicationInfo
Vector ("name" ::: ByteString)
Chain es
InstanceCreateFlags
enabledExtensionNames :: Vector ("name" ::: ByteString)
enabledLayerNames :: Vector ("name" ::: ByteString)
applicationInfo :: Maybe ApplicationInfo
flags :: InstanceCreateFlags
next :: Chain es
$sel:enabledExtensionNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:enabledLayerNames:InstanceCreateInfo :: forall (es :: [*]).
InstanceCreateInfo es -> Vector ("name" ::: ByteString)
$sel:applicationInfo:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Maybe ApplicationInfo
$sel:flags:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> InstanceCreateFlags
$sel:next:InstanceCreateInfo :: forall (es :: [*]). InstanceCreateInfo es -> Chain es
..} IO b
f = forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_INSTANCE_CREATE_INFO)
    Ptr ()
pNext'' <- forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a b. Ptr a -> Ptr b
castPtr forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall (es :: [*]) a.
PokeChain es =>
Chain es -> (Ptr (Chain es) -> IO a) -> IO a
withChain (Chain es
next)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) Ptr ()
pNext''
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr InstanceCreateFlags)) (InstanceCreateFlags
flags)
    Ptr ApplicationInfo
pApplicationInfo'' <- case (Maybe ApplicationInfo
applicationInfo) of
      Maybe ApplicationInfo
Nothing -> forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a. Ptr a
nullPtr
      Just ApplicationInfo
j -> forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. ToCStruct a => a -> (Ptr a -> IO b) -> IO b
withCStruct (ApplicationInfo
j)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr (Ptr ApplicationInfo))) Ptr ApplicationInfo
pApplicationInfo''
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32)) ((forall a b. (Integral a, Num b) => a -> b
fromIntegral (forall a. Vector a -> Int
Data.Vector.length forall a b. (a -> b) -> a -> b
$ (Vector ("name" ::: ByteString)
enabledLayerNames)) :: Word32))
    Ptr ("pName" ::: Ptr CChar)
pPpEnabledLayerNames' <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @(Ptr CChar) ((forall a. Vector a -> Int
Data.Vector.length (Vector ("name" ::: ByteString)
enabledLayerNames)) forall a. Num a => a -> a -> a
* Int
8)
    forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i "name" ::: ByteString
e -> do
      "pName" ::: Ptr CChar
ppEnabledLayerNames'' <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
e)
      forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr ("pName" ::: Ptr CChar)
pPpEnabledLayerNames' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr (Ptr CChar)) "pName" ::: Ptr CChar
ppEnabledLayerNames'') (Vector ("name" ::: ByteString)
enabledLayerNames)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr (Ptr CChar)))) (Ptr ("pName" ::: Ptr CChar)
pPpEnabledLayerNames')
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Word32)) ((forall a b. (Integral a, Num b) => a -> b
fromIntegral (forall a. Vector a -> Int
Data.Vector.length forall a b. (a -> b) -> a -> b
$ (Vector ("name" ::: ByteString)
enabledExtensionNames)) :: Word32))
    Ptr ("pName" ::: Ptr CChar)
pPpEnabledExtensionNames' <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes @(Ptr CChar) ((forall a. Vector a -> Int
Data.Vector.length (Vector ("name" ::: ByteString)
enabledExtensionNames)) forall a. Num a => a -> a -> a
* Int
8)
    forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i "name" ::: ByteString
e -> do
      "pName" ::: Ptr CChar
ppEnabledExtensionNames'' <- forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall a.
("name" ::: ByteString)
-> (("pName" ::: Ptr CChar) -> IO a) -> IO a
useAsCString ("name" ::: ByteString
e)
      forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr ("pName" ::: Ptr CChar)
pPpEnabledExtensionNames' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr (Ptr CChar)) "pName" ::: Ptr CChar
ppEnabledExtensionNames'') (Vector ("name" ::: ByteString)
enabledExtensionNames)
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr (Ptr (Ptr CChar)))) (Ptr ("pName" ::: Ptr CChar)
pPpEnabledExtensionNames')
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ IO b
f
  cStructSize :: Int
cStructSize = Int
64
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b. Ptr (InstanceCreateInfo es) -> IO b -> IO b
pokeZeroCStruct Ptr (InstanceCreateInfo es)
p IO b
f = forall (m :: * -> *) r. Monad m => ContT r m r -> m r
evalContT forall a b. (a -> b) -> a -> b
$ do
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_INSTANCE_CREATE_INFO)
    Ptr ()
pNext' <- forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap forall a b. Ptr a -> Ptr b
castPtr forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall {k} (r :: k) (m :: k -> *) a.
((a -> m r) -> m r) -> ContT r m a
ContT forall a b. (a -> b) -> a -> b
$ forall (es :: [*]) a.
PokeChain es =>
(Ptr (Chain es) -> IO a) -> IO a
withZeroChain @es
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) Ptr ()
pNext'
    forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift forall a b. (a -> b) -> a -> b
$ IO b
f

instance ( Extendss InstanceCreateInfo es
         , PeekChain es ) => FromCStruct (InstanceCreateInfo es) where
  peekCStruct :: Ptr (InstanceCreateInfo es) -> IO (InstanceCreateInfo es)
peekCStruct Ptr (InstanceCreateInfo es)
p = do
    Ptr ()
pNext <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ()) ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ())))
    Chain es
next <- forall (es :: [*]). PeekChain es => Ptr (Chain es) -> IO (Chain es)
peekChain (forall a b. Ptr a -> Ptr b
castPtr Ptr ()
pNext)
    InstanceCreateFlags
flags <- forall a. Storable a => Ptr a -> IO a
peek @InstanceCreateFlags ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr InstanceCreateFlags))
    Ptr ApplicationInfo
pApplicationInfo <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr ApplicationInfo) ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr (Ptr ApplicationInfo)))
    Maybe ApplicationInfo
pApplicationInfo' <- forall a b. (Ptr a -> IO b) -> Ptr a -> IO (Maybe b)
maybePeek (\Ptr ApplicationInfo
j -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @ApplicationInfo (Ptr ApplicationInfo
j)) Ptr ApplicationInfo
pApplicationInfo
    Word32
enabledLayerCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32))
    Ptr ("pName" ::: Ptr CChar)
ppEnabledLayerNames <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr (Ptr CChar)) ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr (Ptr (Ptr CChar))))
    Vector ("name" ::: ByteString)
ppEnabledLayerNames' <- forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a b. (Integral a, Num b) => a -> b
fromIntegral Word32
enabledLayerCount) (\Int
i -> ("pName" ::: Ptr CChar) -> IO ("name" ::: ByteString)
packCString forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< forall a. Storable a => Ptr a -> IO a
peek ((Ptr ("pName" ::: Ptr CChar)
ppEnabledLayerNames forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr (Ptr CChar))))
    Word32
enabledExtensionCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Word32))
    Ptr ("pName" ::: Ptr CChar)
ppEnabledExtensionNames <- forall a. Storable a => Ptr a -> IO a
peek @(Ptr (Ptr CChar)) ((Ptr (InstanceCreateInfo es)
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr (Ptr (Ptr CChar))))
    Vector ("name" ::: ByteString)
ppEnabledExtensionNames' <- forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a b. (Integral a, Num b) => a -> b
fromIntegral Word32
enabledExtensionCount) (\Int
i -> ("pName" ::: Ptr CChar) -> IO ("name" ::: ByteString)
packCString forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< forall a. Storable a => Ptr a -> IO a
peek ((Ptr ("pName" ::: Ptr CChar)
ppEnabledExtensionNames forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr (Ptr CChar))))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ forall (es :: [*]).
Chain es
-> InstanceCreateFlags
-> Maybe ApplicationInfo
-> Vector ("name" ::: ByteString)
-> Vector ("name" ::: ByteString)
-> InstanceCreateInfo es
InstanceCreateInfo
             Chain es
next
             InstanceCreateFlags
flags
             Maybe ApplicationInfo
pApplicationInfo'
             Vector ("name" ::: ByteString)
ppEnabledLayerNames'
             Vector ("name" ::: ByteString)
ppEnabledExtensionNames'

instance es ~ '[] => Zero (InstanceCreateInfo es) where
  zero :: InstanceCreateInfo es
zero = forall (es :: [*]).
Chain es
-> InstanceCreateFlags
-> Maybe ApplicationInfo
-> Vector ("name" ::: ByteString)
-> Vector ("name" ::: ByteString)
-> InstanceCreateInfo es
InstanceCreateInfo
           ()
           forall a. Zero a => a
zero
           forall a. Maybe a
Nothing
           forall a. Monoid a => a
mempty
           forall a. Monoid a => a
mempty


-- | 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) specifies 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
--         'Vulkan.Core10.FundamentalTypes.Offset3D' parameter /must/
--         always be zero.
--
--     -   The @width@, @height@, and @depth@ members of a
--         'Vulkan.Core10.FundamentalTypes.Extent3D' 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 'Vulkan.Core10.FundamentalTypes.Offset3D'
--         parameter /must/ be integer multiples of Ax, Ay, and Az,
--         respectively.
--
--     -   @width@ of a 'Vulkan.Core10.FundamentalTypes.Extent3D' 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 'Vulkan.Core10.FundamentalTypes.Extent3D'
--         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 'Vulkan.Core10.FundamentalTypes.Extent3D' 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
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-device Device Memory>
-- section describes memory properties queried from the physical device.
--
-- For physical device feature queries see the
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features Features>
-- chapter.
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.Extent3D',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.QueueFamilyProperties2',
-- 'Vulkan.Core10.Enums.QueueFlagBits.QueueFlags',
-- 'getPhysicalDeviceQueueFamilyProperties'
data QueueFamilyProperties = QueueFamilyProperties
  { -- | @queueFlags@ is a bitmask of
    -- 'Vulkan.Core10.Enums.QueueFlagBits.QueueFlagBits' indicating
    -- capabilities of the queues in this queue family.
    QueueFamilyProperties -> QueueFlags
queueFlags :: QueueFlags
  , -- | @queueCount@ is the unsigned integer count of queues in this queue
    -- family. Each queue family /must/ support at least one queue.
    QueueFamilyProperties -> Word32
queueCount :: Word32
  , -- | @timestampValidBits@ is the unsigned integer count of meaningful bits in
    -- the timestamps written via
    -- 'Vulkan.Core13.Promoted_From_VK_KHR_synchronization2.cmdWriteTimestamp2'
    -- or 'Vulkan.Core10.CommandBufferBuilding.cmdWriteTimestamp'. The valid
    -- range for the count is 36 to 64 bits, or a value of 0, indicating no
    -- support for timestamps. Bits outside the valid range are guaranteed to
    -- be zeros.
    QueueFamilyProperties -> Word32
timestampValidBits :: Word32
  , -- | @minImageTransferGranularity@ is the minimum granularity supported for
    -- image transfer operations on the queues in this queue family.
    QueueFamilyProperties -> Extent3D
minImageTransferGranularity :: Extent3D
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (QueueFamilyProperties)
#endif
deriving instance Show QueueFamilyProperties

instance ToCStruct QueueFamilyProperties where
  withCStruct :: forall b.
QueueFamilyProperties
-> (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
    -> IO b)
-> IO b
withCStruct QueueFamilyProperties
x ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 forall a b. (a -> b) -> a -> b
$ \"pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p QueueFamilyProperties
x (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties) -> IO b
f "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p)
  pokeCStruct :: forall b.
("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> QueueFamilyProperties -> IO b -> IO b
pokeCStruct "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p QueueFamilyProperties{Word32
Extent3D
QueueFlags
minImageTransferGranularity :: Extent3D
timestampValidBits :: Word32
queueCount :: Word32
queueFlags :: QueueFlags
$sel:minImageTransferGranularity:QueueFamilyProperties :: QueueFamilyProperties -> Extent3D
$sel:timestampValidBits:QueueFamilyProperties :: QueueFamilyProperties -> Word32
$sel:queueCount:QueueFamilyProperties :: QueueFamilyProperties -> Word32
$sel:queueFlags:QueueFamilyProperties :: QueueFamilyProperties -> QueueFlags
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr QueueFlags)) (QueueFlags
queueFlags)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (Word32
queueCount)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (Word32
timestampValidBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Extent3D)) (Extent3D
minImageTransferGranularity)
    IO b
f
  cStructSize :: Int
cStructSize = Int
24
  cStructAlignment :: Int
cStructAlignment = Int
4
  pokeZeroCStruct :: forall b.
("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO b -> IO b
pokeZeroCStruct "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Extent3D)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct QueueFamilyProperties where
  peekCStruct :: ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO QueueFamilyProperties
peekCStruct "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p = do
    QueueFlags
queueFlags <- forall a. Storable a => Ptr a -> IO a
peek @QueueFlags (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr QueueFlags))
    Word32
queueCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32))
    Word32
timestampValidBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32))
    Extent3D
minImageTransferGranularity <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Extent3D (("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Extent3D))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ QueueFlags -> Word32 -> Word32 -> Extent3D -> QueueFamilyProperties
QueueFamilyProperties
             QueueFlags
queueFlags
             Word32
queueCount
             Word32
timestampValidBits
             Extent3D
minImageTransferGranularity

instance Storable QueueFamilyProperties where
  sizeOf :: QueueFamilyProperties -> Int
sizeOf ~QueueFamilyProperties
_ = Int
24
  alignment :: QueueFamilyProperties -> Int
alignment ~QueueFamilyProperties
_ = Int
4
  peek :: ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> IO QueueFamilyProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pQueueFamilyProperties" ::: Ptr QueueFamilyProperties)
-> QueueFamilyProperties -> IO ()
poke "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
ptr QueueFamilyProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pQueueFamilyProperties" ::: Ptr QueueFamilyProperties
ptr QueueFamilyProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero QueueFamilyProperties where
  zero :: QueueFamilyProperties
zero = QueueFlags -> Word32 -> Word32 -> Extent3D -> QueueFamilyProperties
QueueFamilyProperties
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkPhysicalDeviceMemoryProperties - Structure specifying physical device
-- memory properties
--
-- = Description
--
-- The 'PhysicalDeviceMemoryProperties' 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 'Vulkan.Core10.APIConstants.MAX_MEMORY_HEAPS'. Each
-- heap is described by an element of the @memoryHeaps@ array as a
-- 'MemoryHeap' structure. The number of memory types available across all
-- memory heaps is given by @memoryTypeCount@ and is less than or equal to
-- 'Vulkan.Core10.APIConstants.MAX_MEMORY_TYPES'. Each memory type is
-- described by an element of the @memoryTypes@ array as a 'MemoryType'
-- structure.
--
-- At least one heap /must/ include
-- 'Vulkan.Core10.Enums.MemoryHeapFlagBits.MEMORY_HEAP_DEVICE_LOCAL_BIT' in
-- 'MemoryHeap'::@flags@. If there are multiple heaps that all have similar
-- performance characteristics, they /may/ all include
-- 'Vulkan.Core10.Enums.MemoryHeapFlagBits.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 'getPhysicalDeviceMemoryProperties' /must/
-- have its @propertyFlags@ set to one of the following values:
--
-- -   0
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_LAZILY_ALLOCATED_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_PROTECTED_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_PROTECTED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_CACHED_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--
-- -   'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
--     |
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_RDMA_CAPABLE_BIT_NV'
--
-- There /must/ be at least one memory type with both the
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
-- and
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT'
-- bits set in its @propertyFlags@. There /must/ be at least one memory
-- type with the
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
-- bit set in its @propertyFlags@. If the
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-deviceCoherentMemory deviceCoherentMemory>
-- feature is enabled, there /must/ be at least one memory type with the
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
-- 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:
--
-- -   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) ; or
--
-- -   the @propertyFlags@ members of __Y__ includes
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_COHERENT_BIT_AMD'
--     or
--     'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_UNCACHED_BIT_AMD'
--     and __X__ does not
--
-- 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
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-device-bitmask-list list of all allowed memory property flag combinations>
-- is written in a valid order. But if instead
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_DEVICE_LOCAL_BIT'
-- was before
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_VISIBLE_BIT'
-- |
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MEMORY_PROPERTY_HOST_COHERENT_BIT',
-- the list would still be in a valid order.
--
-- There may be a performance penalty for using device coherent or uncached
-- device memory types, and using these accidentally is undesirable. In
-- order to avoid this, memory types with these properties always appear at
-- the end of the list; but are subject to the same rules otherwise.
--
-- 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
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'MemoryHeap', 'MemoryType',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceMemoryProperties2',
-- 'getPhysicalDeviceMemoryProperties'
data PhysicalDeviceMemoryProperties = PhysicalDeviceMemoryProperties
  { -- | @memoryTypeCount@ is the number of valid elements in the @memoryTypes@
    -- array.
    PhysicalDeviceMemoryProperties -> Word32
memoryTypeCount :: Word32
  , -- | @memoryTypes@ is an array of
    -- 'Vulkan.Core10.APIConstants.MAX_MEMORY_TYPES' 'MemoryType' structures
    -- describing the /memory types/ that /can/ be used to access memory
    -- allocated from the heaps specified by @memoryHeaps@.
    PhysicalDeviceMemoryProperties -> Vector MemoryType
memoryTypes :: Vector MemoryType
  , -- | @memoryHeapCount@ is the number of valid elements in the @memoryHeaps@
    -- array.
    PhysicalDeviceMemoryProperties -> Word32
memoryHeapCount :: Word32
  , -- | @memoryHeaps@ is an array of
    -- 'Vulkan.Core10.APIConstants.MAX_MEMORY_HEAPS' 'MemoryHeap' structures
    -- describing the /memory heaps/ from which memory /can/ be allocated.
    PhysicalDeviceMemoryProperties -> Vector MemoryHeap
memoryHeaps :: Vector MemoryHeap
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceMemoryProperties)
#endif
deriving instance Show PhysicalDeviceMemoryProperties

instance ToCStruct PhysicalDeviceMemoryProperties where
  withCStruct :: forall b.
PhysicalDeviceMemoryProperties
-> (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
    -> IO b)
-> IO b
withCStruct PhysicalDeviceMemoryProperties
x ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
520 forall a b. (a -> b) -> a -> b
$ \"pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p PhysicalDeviceMemoryProperties
x (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO b
f "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p)
  pokeCStruct :: forall b.
("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> PhysicalDeviceMemoryProperties -> IO b -> IO b
pokeCStruct "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p PhysicalDeviceMemoryProperties{Word32
Vector MemoryType
Vector MemoryHeap
memoryHeaps :: Vector MemoryHeap
memoryHeapCount :: Word32
memoryTypes :: Vector MemoryType
memoryTypeCount :: Word32
$sel:memoryHeaps:PhysicalDeviceMemoryProperties :: PhysicalDeviceMemoryProperties -> Vector MemoryHeap
$sel:memoryHeapCount:PhysicalDeviceMemoryProperties :: PhysicalDeviceMemoryProperties -> Word32
$sel:memoryTypes:PhysicalDeviceMemoryProperties :: PhysicalDeviceMemoryProperties -> Vector MemoryType
$sel:memoryTypeCount:PhysicalDeviceMemoryProperties :: PhysicalDeviceMemoryProperties -> Word32
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (Word32
memoryTypeCount)
    forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless ((forall a. Vector a -> Int
Data.Vector.length forall a b. (a -> b) -> a -> b
$ (Vector MemoryType
memoryTypes)) forall a. Ord a => a -> a -> Bool
<= forall a. Integral a => a
MAX_MEMORY_TYPES) forall a b. (a -> b) -> a -> b
$
      forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"memoryTypes is too long, a maximum of MAX_MEMORY_TYPES elements are allowed" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
    forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i MemoryType
e -> forall a. Storable a => Ptr a -> a -> IO ()
poke ((forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr (FixedArray MAX_MEMORY_TYPES MemoryType)))) forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryType) (MemoryType
e)) (Vector MemoryType
memoryTypes)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32)) (Word32
memoryHeapCount)
    forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless ((forall a. Vector a -> Int
Data.Vector.length forall a b. (a -> b) -> a -> b
$ (Vector MemoryHeap
memoryHeaps)) forall a. Ord a => a -> a -> Bool
<= forall a. Integral a => a
MAX_MEMORY_HEAPS) forall a b. (a -> b) -> a -> b
$
      forall e a. Exception e => e -> IO a
throwIO forall a b. (a -> b) -> a -> b
$ Maybe Handle
-> IOErrorType
-> String
-> String
-> Maybe CInt
-> Maybe String
-> IOException
IOError forall a. Maybe a
Nothing IOErrorType
InvalidArgument String
"" String
"memoryHeaps is too long, a maximum of MAX_MEMORY_HEAPS elements are allowed" forall a. Maybe a
Nothing forall a. Maybe a
Nothing
    forall (m :: * -> *) a b.
Monad m =>
(Int -> a -> m b) -> Vector a -> m ()
Data.Vector.imapM_ (\Int
i MemoryHeap
e -> forall a. Storable a => Ptr a -> a -> IO ()
poke ((forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
264 :: Ptr (FixedArray MAX_MEMORY_HEAPS MemoryHeap)))) forall a b. Ptr a -> Int -> Ptr b
`plusPtr` (Int
16 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryHeap) (MemoryHeap
e)) (Vector MemoryHeap
memoryHeaps)
    IO b
f
  cStructSize :: Int
cStructSize = Int
520
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b.
("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO b -> IO b
pokeZeroCStruct "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct PhysicalDeviceMemoryProperties where
  peekCStruct :: ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO PhysicalDeviceMemoryProperties
peekCStruct "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p = do
    Word32
memoryTypeCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32))
    Vector MemoryType
memoryTypes <- forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a. Integral a => a
MAX_MEMORY_TYPES) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @MemoryType (((forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @MemoryType (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr (FixedArray MAX_MEMORY_TYPES MemoryType)))) forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
8 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryType)))
    Word32
memoryHeapCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32))
    Vector MemoryHeap
memoryHeaps <- forall (m :: * -> *) a.
Monad m =>
Int -> (Int -> m a) -> m (Vector a)
generateM (forall a. Integral a => a
MAX_MEMORY_HEAPS) (\Int
i -> forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @MemoryHeap (((forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @MemoryHeap (("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
264 :: Ptr (FixedArray MAX_MEMORY_HEAPS MemoryHeap)))) forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` (Int
16 forall a. Num a => a -> a -> a
* (Int
i)) :: Ptr MemoryHeap)))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Word32
-> Vector MemoryType
-> Word32
-> Vector MemoryHeap
-> PhysicalDeviceMemoryProperties
PhysicalDeviceMemoryProperties
             Word32
memoryTypeCount Vector MemoryType
memoryTypes Word32
memoryHeapCount Vector MemoryHeap
memoryHeaps

instance Storable PhysicalDeviceMemoryProperties where
  sizeOf :: PhysicalDeviceMemoryProperties -> Int
sizeOf ~PhysicalDeviceMemoryProperties
_ = Int
520
  alignment :: PhysicalDeviceMemoryProperties -> Int
alignment ~PhysicalDeviceMemoryProperties
_ = Int
8
  peek :: ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> IO PhysicalDeviceMemoryProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties)
-> PhysicalDeviceMemoryProperties -> IO ()
poke "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
ptr PhysicalDeviceMemoryProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pMemoryProperties" ::: Ptr PhysicalDeviceMemoryProperties
ptr PhysicalDeviceMemoryProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero PhysicalDeviceMemoryProperties where
  zero :: PhysicalDeviceMemoryProperties
zero = Word32
-> Vector MemoryType
-> Word32
-> Vector MemoryHeap
-> PhysicalDeviceMemoryProperties
PhysicalDeviceMemoryProperties
           forall a. Zero a => a
zero
           forall a. Monoid a => a
mempty
           forall a. Zero a => a
zero
           forall a. Monoid a => a
mempty


-- | VkMemoryType - Structure specifying memory type
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MemoryPropertyFlags',
-- 'PhysicalDeviceMemoryProperties'
data MemoryType = MemoryType
  { -- | @propertyFlags@ is a bitmask of
    -- 'Vulkan.Core10.Enums.MemoryPropertyFlagBits.MemoryPropertyFlagBits' of
    -- properties for this memory type.
    MemoryType -> MemoryPropertyFlags
propertyFlags :: MemoryPropertyFlags
  , -- | @heapIndex@ describes which memory heap this memory type corresponds to,
    -- and /must/ be less than @memoryHeapCount@ from the
    -- 'PhysicalDeviceMemoryProperties' structure.
    MemoryType -> Word32
heapIndex :: Word32
  }
  deriving (Typeable, MemoryType -> MemoryType -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: MemoryType -> MemoryType -> Bool
$c/= :: MemoryType -> MemoryType -> Bool
== :: MemoryType -> MemoryType -> Bool
$c== :: MemoryType -> MemoryType -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (MemoryType)
#endif
deriving instance Show MemoryType

instance ToCStruct MemoryType where
  withCStruct :: forall b. MemoryType -> (Ptr MemoryType -> IO b) -> IO b
withCStruct MemoryType
x Ptr MemoryType -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
8 forall a b. (a -> b) -> a -> b
$ \Ptr MemoryType
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryType
p MemoryType
x (Ptr MemoryType -> IO b
f Ptr MemoryType
p)
  pokeCStruct :: forall b. Ptr MemoryType -> MemoryType -> IO b -> IO b
pokeCStruct Ptr MemoryType
p MemoryType{Word32
MemoryPropertyFlags
heapIndex :: Word32
propertyFlags :: MemoryPropertyFlags
$sel:heapIndex:MemoryType :: MemoryType -> Word32
$sel:propertyFlags:MemoryType :: MemoryType -> MemoryPropertyFlags
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryType
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr MemoryPropertyFlags)) (MemoryPropertyFlags
propertyFlags)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryType
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (Word32
heapIndex)
    IO b
f
  cStructSize :: Int
cStructSize = Int
8
  cStructAlignment :: Int
cStructAlignment = Int
4
  pokeZeroCStruct :: forall b. Ptr MemoryType -> IO b -> IO b
pokeZeroCStruct Ptr MemoryType
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryType
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct MemoryType where
  peekCStruct :: Ptr MemoryType -> IO MemoryType
peekCStruct Ptr MemoryType
p = do
    MemoryPropertyFlags
propertyFlags <- forall a. Storable a => Ptr a -> IO a
peek @MemoryPropertyFlags ((Ptr MemoryType
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr MemoryPropertyFlags))
    Word32
heapIndex <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr MemoryType
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ MemoryPropertyFlags -> Word32 -> MemoryType
MemoryType
             MemoryPropertyFlags
propertyFlags Word32
heapIndex

instance Storable MemoryType where
  sizeOf :: MemoryType -> Int
sizeOf ~MemoryType
_ = Int
8
  alignment :: MemoryType -> Int
alignment ~MemoryType
_ = Int
4
  peek :: Ptr MemoryType -> IO MemoryType
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: Ptr MemoryType -> MemoryType -> IO ()
poke Ptr MemoryType
ptr MemoryType
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryType
ptr MemoryType
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero MemoryType where
  zero :: MemoryType
zero = MemoryPropertyFlags -> Word32 -> MemoryType
MemoryType
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkMemoryHeap - Structure specifying a memory heap
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.DeviceSize',
-- 'Vulkan.Core10.Enums.MemoryHeapFlagBits.MemoryHeapFlags',
-- 'PhysicalDeviceMemoryProperties'
data MemoryHeap = MemoryHeap
  { -- | @size@ is the total memory size in bytes in the heap.
    MemoryHeap -> DeviceSize
size :: DeviceSize
  , -- | @flags@ is a bitmask of
    -- 'Vulkan.Core10.Enums.MemoryHeapFlagBits.MemoryHeapFlagBits' specifying
    -- attribute flags for the heap.
    MemoryHeap -> MemoryHeapFlags
flags :: MemoryHeapFlags
  }
  deriving (Typeable, MemoryHeap -> MemoryHeap -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: MemoryHeap -> MemoryHeap -> Bool
$c/= :: MemoryHeap -> MemoryHeap -> Bool
== :: MemoryHeap -> MemoryHeap -> Bool
$c== :: MemoryHeap -> MemoryHeap -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (MemoryHeap)
#endif
deriving instance Show MemoryHeap

instance ToCStruct MemoryHeap where
  withCStruct :: forall b. MemoryHeap -> (Ptr MemoryHeap -> IO b) -> IO b
withCStruct MemoryHeap
x Ptr MemoryHeap -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
16 forall a b. (a -> b) -> a -> b
$ \Ptr MemoryHeap
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryHeap
p MemoryHeap
x (Ptr MemoryHeap -> IO b
f Ptr MemoryHeap
p)
  pokeCStruct :: forall b. Ptr MemoryHeap -> MemoryHeap -> IO b -> IO b
pokeCStruct Ptr MemoryHeap
p MemoryHeap{DeviceSize
MemoryHeapFlags
flags :: MemoryHeapFlags
size :: DeviceSize
$sel:flags:MemoryHeap :: MemoryHeap -> MemoryHeapFlags
$sel:size:MemoryHeap :: MemoryHeap -> DeviceSize
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryHeap
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr DeviceSize)) (DeviceSize
size)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryHeap
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr MemoryHeapFlags)) (MemoryHeapFlags
flags)
    IO b
f
  cStructSize :: Int
cStructSize = Int
16
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b. Ptr MemoryHeap -> IO b -> IO b
pokeZeroCStruct Ptr MemoryHeap
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr MemoryHeap
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct MemoryHeap where
  peekCStruct :: Ptr MemoryHeap -> IO MemoryHeap
peekCStruct Ptr MemoryHeap
p = do
    DeviceSize
size <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr MemoryHeap
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr DeviceSize))
    MemoryHeapFlags
flags <- forall a. Storable a => Ptr a -> IO a
peek @MemoryHeapFlags ((Ptr MemoryHeap
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr MemoryHeapFlags))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ DeviceSize -> MemoryHeapFlags -> MemoryHeap
MemoryHeap
             DeviceSize
size MemoryHeapFlags
flags

instance Storable MemoryHeap where
  sizeOf :: MemoryHeap -> Int
sizeOf ~MemoryHeap
_ = Int
16
  alignment :: MemoryHeap -> Int
alignment ~MemoryHeap
_ = Int
8
  peek :: Ptr MemoryHeap -> IO MemoryHeap
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: Ptr MemoryHeap -> MemoryHeap -> IO ()
poke Ptr MemoryHeap
ptr MemoryHeap
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr MemoryHeap
ptr MemoryHeap
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero MemoryHeap where
  zero :: MemoryHeap
zero = DeviceSize -> MemoryHeapFlags -> MemoryHeap
MemoryHeap
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | 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-compressed format, then @bufferFeatures@ /must/
-- not support any features for the format.
--
-- If @format@ is not a multi-plane format then @linearTilingFeatures@ and
-- @optimalTilingFeatures@ /must/ not contain
-- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_DISJOINT_BIT'.
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FormatFeatureFlags',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.FormatProperties2',
-- 'getPhysicalDeviceFormatProperties'
data FormatProperties = FormatProperties
  { -- | @linearTilingFeatures@ is a bitmask of
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FormatFeatureFlagBits'
    -- specifying features supported by images created with a @tiling@
    -- parameter of 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_LINEAR'.
    FormatProperties -> FormatFeatureFlags
linearTilingFeatures :: FormatFeatureFlags
  , -- | @optimalTilingFeatures@ is a bitmask of
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FormatFeatureFlagBits'
    -- specifying features supported by images created with a @tiling@
    -- parameter of 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL'.
    FormatProperties -> FormatFeatureFlags
optimalTilingFeatures :: FormatFeatureFlags
  , -- | @bufferFeatures@ is a bitmask of
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FormatFeatureFlagBits'
    -- specifying features supported by buffers.
    FormatProperties -> FormatFeatureFlags
bufferFeatures :: FormatFeatureFlags
  }
  deriving (Typeable, FormatProperties -> FormatProperties -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: FormatProperties -> FormatProperties -> Bool
$c/= :: FormatProperties -> FormatProperties -> Bool
== :: FormatProperties -> FormatProperties -> Bool
$c== :: FormatProperties -> FormatProperties -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (FormatProperties)
#endif
deriving instance Show FormatProperties

instance ToCStruct FormatProperties where
  withCStruct :: forall b.
FormatProperties
-> (("pFormatProperties" ::: Ptr FormatProperties) -> IO b) -> IO b
withCStruct FormatProperties
x ("pFormatProperties" ::: Ptr FormatProperties) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
12 forall a b. (a -> b) -> a -> b
$ \"pFormatProperties" ::: Ptr FormatProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pFormatProperties" ::: Ptr FormatProperties
p FormatProperties
x (("pFormatProperties" ::: Ptr FormatProperties) -> IO b
f "pFormatProperties" ::: Ptr FormatProperties
p)
  pokeCStruct :: forall b.
("pFormatProperties" ::: Ptr FormatProperties)
-> FormatProperties -> IO b -> IO b
pokeCStruct "pFormatProperties" ::: Ptr FormatProperties
p FormatProperties{FormatFeatureFlags
bufferFeatures :: FormatFeatureFlags
optimalTilingFeatures :: FormatFeatureFlags
linearTilingFeatures :: FormatFeatureFlags
$sel:bufferFeatures:FormatProperties :: FormatProperties -> FormatFeatureFlags
$sel:optimalTilingFeatures:FormatProperties :: FormatProperties -> FormatFeatureFlags
$sel:linearTilingFeatures:FormatProperties :: FormatProperties -> FormatFeatureFlags
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr FormatFeatureFlags)) (FormatFeatureFlags
linearTilingFeatures)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr FormatFeatureFlags)) (FormatFeatureFlags
optimalTilingFeatures)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr FormatFeatureFlags)) (FormatFeatureFlags
bufferFeatures)
    IO b
f
  cStructSize :: Int
cStructSize = Int
12
  cStructAlignment :: Int
cStructAlignment = Int
4
  pokeZeroCStruct :: forall b.
("pFormatProperties" ::: Ptr FormatProperties) -> IO b -> IO b
pokeZeroCStruct "pFormatProperties" ::: Ptr FormatProperties
_ IO b
f = IO b
f

instance FromCStruct FormatProperties where
  peekCStruct :: ("pFormatProperties" ::: Ptr FormatProperties)
-> IO FormatProperties
peekCStruct "pFormatProperties" ::: Ptr FormatProperties
p = do
    FormatFeatureFlags
linearTilingFeatures <- forall a. Storable a => Ptr a -> IO a
peek @FormatFeatureFlags (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr FormatFeatureFlags))
    FormatFeatureFlags
optimalTilingFeatures <- forall a. Storable a => Ptr a -> IO a
peek @FormatFeatureFlags (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr FormatFeatureFlags))
    FormatFeatureFlags
bufferFeatures <- forall a. Storable a => Ptr a -> IO a
peek @FormatFeatureFlags (("pFormatProperties" ::: Ptr FormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr FormatFeatureFlags))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ FormatFeatureFlags
-> FormatFeatureFlags -> FormatFeatureFlags -> FormatProperties
FormatProperties
             FormatFeatureFlags
linearTilingFeatures FormatFeatureFlags
optimalTilingFeatures FormatFeatureFlags
bufferFeatures

instance Storable FormatProperties where
  sizeOf :: FormatProperties -> Int
sizeOf ~FormatProperties
_ = Int
12
  alignment :: FormatProperties -> Int
alignment ~FormatProperties
_ = Int
4
  peek :: ("pFormatProperties" ::: Ptr FormatProperties)
-> IO FormatProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pFormatProperties" ::: Ptr FormatProperties)
-> FormatProperties -> IO ()
poke "pFormatProperties" ::: Ptr FormatProperties
ptr FormatProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pFormatProperties" ::: Ptr FormatProperties
ptr FormatProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero FormatProperties where
  zero :: FormatProperties
zero = FormatFeatureFlags
-> FormatFeatureFlags -> FormatFeatureFlags -> FormatProperties
FormatProperties
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkImageFormatProperties - Structure specifying an image format
-- properties
--
-- = Members
--
-- -   @maxExtent@ are the maximum image dimensions. See the
--     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-extentperimagetype 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 the number of levels in the
--     complete mipmap chain based on the @maxExtent.width@,
--     @maxExtent.height@, and @maxExtent.depth@, except when one of the
--     following conditions is true, in which case it /may/ instead be @1@:
--
--     -   'getPhysicalDeviceImageFormatProperties'::@tiling@ was
--         'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_LINEAR'
--
--     -   'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceImageFormatInfo2'::@tiling@
--         was
--         'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT'
--
--     -   the
--         'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceImageFormatInfo2'::@pNext@
--         chain included a
--         'Vulkan.Core11.Promoted_From_VK_KHR_external_memory_capabilities.PhysicalDeviceExternalImageFormatInfo'
--         structure with a handle type included in the @handleTypes@
--         member for which mipmap image support is not required
--
--     -   image @format@ is one of the
--         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#formats-requiring-sampler-ycbcr-conversion formats that require a sampler Y′CBCR conversion>
--
--     -   @flags@ contains
--         'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SUBSAMPLED_BIT_EXT'
--
-- -   @maxArrayLayers@ is the maximum number of array layers.
--     @maxArrayLayers@ /must/ be no less than
--     'PhysicalDeviceLimits'::@maxImageArrayLayers@, except when one of
--     the following conditions is true, in which case it /may/ instead be
--     @1@:
--
--     -   @tiling@ is
--         'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_LINEAR'
--
--     -   @tiling@ is
--         'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL' and
--         @type@ is 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_3D'
--
--     -   @format@ is one of the
--         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#formats-requiring-sampler-ycbcr-conversion formats that require a sampler Y′CBCR conversion>
--
-- -   If @tiling@ is
--     'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_DRM_FORMAT_MODIFIER_EXT',
--     then @maxArrayLayers@ /must/ not be 0.
--
-- -   @sampleCounts@ is a bitmask of
--     'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits'
--     specifying all the supported sample counts for this image as
--     described
--     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-supported-sample-counts 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 'Vulkan.Core10.Image.createImage' will return
-- 'Vulkan.Core10.Enums.Result.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
-- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_1D'.
--
-- If the combination of parameters to
-- 'getPhysicalDeviceImageFormatProperties' is not supported by the
-- implementation for use in 'Vulkan.Core10.Image.createImage', 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.
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.DeviceSize',
-- 'Vulkan.Core10.FundamentalTypes.Extent3D',
-- 'Vulkan.Extensions.VK_NV_external_memory_capabilities.ExternalImageFormatPropertiesNV',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.ImageFormatProperties2',
-- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlags',
-- 'getPhysicalDeviceImageFormatProperties'
data ImageFormatProperties = ImageFormatProperties
  { -- No documentation found for Nested "VkImageFormatProperties" "maxExtent"
    ImageFormatProperties -> Extent3D
maxExtent :: Extent3D
  , -- No documentation found for Nested "VkImageFormatProperties" "maxMipLevels"
    ImageFormatProperties -> Word32
maxMipLevels :: Word32
  , -- No documentation found for Nested "VkImageFormatProperties" "maxArrayLayers"
    ImageFormatProperties -> Word32
maxArrayLayers :: Word32
  , -- No documentation found for Nested "VkImageFormatProperties" "sampleCounts"
    ImageFormatProperties -> SampleCountFlags
sampleCounts :: SampleCountFlags
  , -- No documentation found for Nested "VkImageFormatProperties" "maxResourceSize"
    ImageFormatProperties -> DeviceSize
maxResourceSize :: DeviceSize
  }
  deriving (Typeable)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (ImageFormatProperties)
#endif
deriving instance Show ImageFormatProperties

instance ToCStruct ImageFormatProperties where
  withCStruct :: forall b.
ImageFormatProperties
-> (("pImageFormatProperties" ::: Ptr ImageFormatProperties)
    -> IO b)
-> IO b
withCStruct ImageFormatProperties
x ("pImageFormatProperties" ::: Ptr ImageFormatProperties) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
32 forall a b. (a -> b) -> a -> b
$ \"pImageFormatProperties" ::: Ptr ImageFormatProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pImageFormatProperties" ::: Ptr ImageFormatProperties
p ImageFormatProperties
x (("pImageFormatProperties" ::: Ptr ImageFormatProperties) -> IO b
f "pImageFormatProperties" ::: Ptr ImageFormatProperties
p)
  pokeCStruct :: forall b.
("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> ImageFormatProperties -> IO b -> IO b
pokeCStruct "pImageFormatProperties" ::: Ptr ImageFormatProperties
p ImageFormatProperties{Word32
DeviceSize
SampleCountFlags
Extent3D
maxResourceSize :: DeviceSize
sampleCounts :: SampleCountFlags
maxArrayLayers :: Word32
maxMipLevels :: Word32
maxExtent :: Extent3D
$sel:maxResourceSize:ImageFormatProperties :: ImageFormatProperties -> DeviceSize
$sel:sampleCounts:ImageFormatProperties :: ImageFormatProperties -> SampleCountFlags
$sel:maxArrayLayers:ImageFormatProperties :: ImageFormatProperties -> Word32
$sel:maxMipLevels:ImageFormatProperties :: ImageFormatProperties -> Word32
$sel:maxExtent:ImageFormatProperties :: ImageFormatProperties -> Extent3D
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Extent3D)) (Extent3D
maxExtent)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (Word32
maxMipLevels)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (Word32
maxArrayLayers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr SampleCountFlags)) (SampleCountFlags
sampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr DeviceSize)) (DeviceSize
maxResourceSize)
    IO b
f
  cStructSize :: Int
cStructSize = Int
32
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b.
("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO b -> IO b
pokeZeroCStruct "pImageFormatProperties" ::: Ptr ImageFormatProperties
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Extent3D)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct ImageFormatProperties where
  peekCStruct :: ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO ImageFormatProperties
peekCStruct "pImageFormatProperties" ::: Ptr ImageFormatProperties
p = do
    Extent3D
maxExtent <- forall a. FromCStruct a => Ptr a -> IO a
peekCStruct @Extent3D (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Extent3D))
    Word32
maxMipLevels <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32))
    Word32
maxArrayLayers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32))
    SampleCountFlags
sampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr SampleCountFlags))
    DeviceSize
maxResourceSize <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize (("pImageFormatProperties" ::: Ptr ImageFormatProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr DeviceSize))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Extent3D
-> Word32
-> Word32
-> SampleCountFlags
-> DeviceSize
-> ImageFormatProperties
ImageFormatProperties
             Extent3D
maxExtent Word32
maxMipLevels Word32
maxArrayLayers SampleCountFlags
sampleCounts DeviceSize
maxResourceSize

instance Storable ImageFormatProperties where
  sizeOf :: ImageFormatProperties -> Int
sizeOf ~ImageFormatProperties
_ = Int
32
  alignment :: ImageFormatProperties -> Int
alignment ~ImageFormatProperties
_ = Int
8
  peek :: ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> IO ImageFormatProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pImageFormatProperties" ::: Ptr ImageFormatProperties)
-> ImageFormatProperties -> IO ()
poke "pImageFormatProperties" ::: Ptr ImageFormatProperties
ptr ImageFormatProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pImageFormatProperties" ::: Ptr ImageFormatProperties
ptr ImageFormatProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero ImageFormatProperties where
  zero :: ImageFormatProperties
zero = Extent3D
-> Word32
-> Word32
-> SampleCountFlags
-> DeviceSize
-> ImageFormatProperties
ImageFormatProperties
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkPhysicalDeviceFeatures - Structure describing the fine-grained
-- features that can be supported by an implementation
--
-- = Members
--
-- This structure describes the following features:
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.Bool32',
-- 'Vulkan.Core10.Device.DeviceCreateInfo',
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceFeatures2',
-- 'getPhysicalDeviceFeatures'
data PhysicalDeviceFeatures = PhysicalDeviceFeatures
  { -- | #features-robustBufferAccess# @robustBufferAccess@ specifies that
    -- accesses to buffers are bounds-checked against the range of the buffer
    -- descriptor (as determined by
    -- 'Vulkan.Core10.DescriptorSet.DescriptorBufferInfo'::@range@,
    -- 'Vulkan.Core10.BufferView.BufferViewCreateInfo'::@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. Buffer accesses through buffer device addresses are
    --         not bounds-checked.
    --
    --     -   If the
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-cooperativeMatrixRobustBufferAccess-NV ::cooperativeMatrixRobustBufferAccess>
    --         feature is not enabled, then accesses using
    --         @OpCooperativeMatrixLoadNV@ and @OpCooperativeMatrixStoreNV@
    --         /may/ not be bounds-checked.
    --
    --     -   If the
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-cooperativeMatrixRobustBufferAccess ::cooperativeMatrixRobustBufferAccess>
    --         feature is not enabled, then accesses using
    --         @OpCooperativeMatrixLoadKHR@ and @OpCooperativeMatrixStoreKHR@
    --         /may/ not be bounds-checked.
    --
    --         Note
    --
    --         If 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
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is not enabled and any buffer access is determined to be out of
    --         bounds, then any other access of the same type (load, store, or
    --         atomic) to the same buffer that accesses an address less than 16
    --         bytes away from the out of bounds address /may/ also be
    --         considered out of bounds.
    --
    --     -   If the access is a load that reads from the same memory
    --         locations as a prior store in the same shader invocation, with
    --         no other intervening accesses to the same memory locations in
    --         that shader invocation, then the result of the load /may/ be the
    --         value stored by the store instruction, even if the access is out
    --         of bounds. If the load is @Volatile@, then an out of bounds load
    --         /must/ return the appropriate out of bounds value.
    --
    -- -   Accesses to descriptors written with a
    --     'Vulkan.Core10.APIConstants.NULL_HANDLE' resource or view are not
    --     considered to be out of bounds. Instead, each type of descriptor
    --     access defines a specific behavior for accesses to a null
    --     descriptor.
    --
    -- -   Out-of-bounds buffer loads will return any of the following values:
    --
    --     -   If the access is to a uniform buffer and
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, loads of offsets between the end of the descriptor
    --         range and the end of the descriptor range rounded up to a
    --         multiple of
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-robustUniformBufferAccessSizeAlignment robustUniformBufferAccessSizeAlignment>
    --         bytes /must/ return either zero values or the contents of the
    --         memory at the offset being loaded. Loads of offsets past the
    --         descriptor range rounded up to a multiple of
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-robustUniformBufferAccessSizeAlignment robustUniformBufferAccessSizeAlignment>
    --         bytes /must/ return zero values.
    --
    --     -   If the access is to a storage buffer and
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, loads of offsets between the end of the descriptor
    --         range and the end of the descriptor range rounded up to a
    --         multiple of
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-robustStorageBufferAccessSizeAlignment robustStorageBufferAccessSizeAlignment>
    --         bytes /must/ return either zero values or the contents of the
    --         memory at the offset being loaded. Loads of offsets past the
    --         descriptor range rounded up to a multiple of
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-robustStorageBufferAccessSizeAlignment robustStorageBufferAccessSizeAlignment>
    --         bytes /must/ return zero values. Similarly, stores to addresses
    --         between the end of the descriptor range and the end of the
    --         descriptor range rounded up to a multiple of
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-robustStorageBufferAccessSizeAlignment robustStorageBufferAccessSizeAlignment>
    --         bytes /may/ be discarded.
    --
    --     -   Non-atomic accesses to storage buffers that are a multiple of 32
    --         bits /may/ be decomposed into 32-bit accesses that are
    --         individually bounds-checked.
    --
    --     -   If the access is to an index buffer and
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, zero values /must/ be returned.
    --
    --     -   If the access is to a uniform texel buffer or storage texel
    --         buffer and
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, zero values /must/ be returned, and then
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#textures-conversion-to-rgba Conversion to RGBA>
    --         is applied based on the buffer view’s format.
    --
    --     -   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.
    --
    --     -   If
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, out of bounds writes /must/ not modify any 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.
    --
    --     -   If
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --         is enabled, out of bounds atomics /must/ not modify any memory,
    --         and return an undefined value.
    --
    -- -   If
    --     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --     is disabled, 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
    --     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-robustBufferAccess2 robustBufferAccess2>
    --     is enabled, 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 the byte size of the
    --     memory range bound to the vertex buffer binding.
    --
    --     -   If a vertex input attribute is out of bounds, the
    --         <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-input-extraction raw data>
    --         extracted are zero values, and missing G, B, or A components are
    --         <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#fxvertex-input-extraction filled with (0,0,1)>.
    --
    -- -   If @robustBufferAccess@ is not enabled, applications /must/ not
    --     perform out of bounds accesses except under the conditions enabled
    --     by the
    --     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-pipelineRobustness pipelineRobustness>
    --     feature .
    PhysicalDeviceFeatures -> Bool
robustBufferAccess :: Bool
  , -- | #features-fullDrawIndexUint32# @fullDrawIndexUint32@ specifies the full
    -- 32-bit range of indices is supported for indexed draw calls when using a
    -- 'Vulkan.Core10.Enums.IndexType.IndexType' of
    -- 'Vulkan.Core10.Enums.IndexType.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
    -- 'Vulkan.Core10.Enums.IndexType.IndexType' is
    -- 'Vulkan.Core10.Enums.IndexType.INDEX_TYPE_UINT32'). If this feature is
    -- supported, @maxDrawIndexedIndexValue@ /must/ be 232-1; otherwise it
    -- /must/ be no smaller than 224-1. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-maxDrawIndexedIndexValue maxDrawIndexedIndexValue>.
    PhysicalDeviceFeatures -> Bool
fullDrawIndexUint32 :: Bool
  , -- | #features-imageCubeArray# @imageCubeArray@ specifies whether image views
    -- with a 'Vulkan.Core10.Enums.ImageViewType.ImageViewType' of
    -- 'Vulkan.Core10.Enums.ImageViewType.IMAGE_VIEW_TYPE_CUBE_ARRAY' /can/ be
    -- created, and that the corresponding @SampledCubeArray@ and
    -- @ImageCubeArray@ SPIR-V capabilities /can/ be used in shader code.
    PhysicalDeviceFeatures -> Bool
imageCubeArray :: Bool
  , -- | #features-independentBlend# @independentBlend@ specifies whether the
    -- 'Vulkan.Core10.Pipeline.PipelineColorBlendAttachmentState' settings are
    -- controlled independently per-attachment. If this feature is not enabled,
    -- the 'Vulkan.Core10.Pipeline.PipelineColorBlendAttachmentState' settings
    -- for all color attachments /must/ be identical. Otherwise, a different
    -- 'Vulkan.Core10.Pipeline.PipelineColorBlendAttachmentState' /can/ be
    -- provided for each bound color attachment.
    PhysicalDeviceFeatures -> Bool
independentBlend :: Bool
  , -- | #features-geometryShader# @geometryShader@ specifies whether geometry
    -- shaders are supported. If this feature is not enabled, the
    -- 'Vulkan.Core10.Enums.ShaderStageFlagBits.SHADER_STAGE_GEOMETRY_BIT' and
    -- 'Vulkan.Core10.Enums.PipelineStageFlagBits.PIPELINE_STAGE_GEOMETRY_SHADER_BIT'
    -- enum values /must/ not be used. This also specifies whether shader
    -- modules /can/ declare the @Geometry@ capability.
    PhysicalDeviceFeatures -> Bool
geometryShader :: Bool
  , -- | #features-tessellationShader# @tessellationShader@ specifies whether
    -- tessellation control and evaluation shaders are supported. If this
    -- feature is not enabled, the
    -- 'Vulkan.Core10.Enums.ShaderStageFlagBits.SHADER_STAGE_TESSELLATION_CONTROL_BIT',
    -- 'Vulkan.Core10.Enums.ShaderStageFlagBits.SHADER_STAGE_TESSELLATION_EVALUATION_BIT',
    -- 'Vulkan.Core10.Enums.PipelineStageFlagBits.PIPELINE_STAGE_TESSELLATION_CONTROL_SHADER_BIT',
    -- 'Vulkan.Core10.Enums.PipelineStageFlagBits.PIPELINE_STAGE_TESSELLATION_EVALUATION_SHADER_BIT',
    -- and
    -- 'Vulkan.Core10.Enums.StructureType.STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO'
    -- enum values /must/ not be used. This also specifies whether shader
    -- modules /can/ declare the @Tessellation@ capability.
    PhysicalDeviceFeatures -> Bool
tessellationShader :: Bool
  , -- | #features-sampleRateShading# @sampleRateShading@ specifies whether
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#primsrast-sampleshading Sample Shading>
    -- and multisample interpolation are supported. If this feature is not
    -- enabled, the @sampleShadingEnable@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineMultisampleStateCreateInfo' structure
    -- /must/ be set to 'Vulkan.Core10.FundamentalTypes.FALSE' and the
    -- @minSampleShading@ member is ignored. This also specifies whether shader
    -- modules /can/ declare the @SampleRateShading@ capability.
    PhysicalDeviceFeatures -> Bool
sampleRateShading :: Bool
  , -- | #features-dualSrcBlend# @dualSrcBlend@ specifies whether blend
    -- operations which take two sources are supported. If this feature is not
    -- enabled, the 'Vulkan.Core10.Enums.BlendFactor.BLEND_FACTOR_SRC1_COLOR',
    -- 'Vulkan.Core10.Enums.BlendFactor.BLEND_FACTOR_ONE_MINUS_SRC1_COLOR',
    -- 'Vulkan.Core10.Enums.BlendFactor.BLEND_FACTOR_SRC1_ALPHA', and
    -- 'Vulkan.Core10.Enums.BlendFactor.BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA' enum
    -- values /must/ not be used as source or destination blending factors. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#framebuffer-dsb>.
    PhysicalDeviceFeatures -> Bool
dualSrcBlend :: Bool
  , -- | #features-logicOp# @logicOp@ specifies whether logic operations are
    -- supported. If this feature is not enabled, the @logicOpEnable@ member of
    -- the 'Vulkan.Core10.Pipeline.PipelineColorBlendStateCreateInfo' structure
    -- /must/ be set to 'Vulkan.Core10.FundamentalTypes.FALSE', and the
    -- @logicOp@ member is ignored.
    PhysicalDeviceFeatures -> Bool
logicOp :: Bool
  , -- | #features-multiDrawIndirect# @multiDrawIndirect@ specifies whether
    -- multiple draw indirect is supported. If this feature is not enabled, the
    -- @drawCount@ parameter to the
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdDrawIndirect' and
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdDrawIndexedIndirect' commands
    -- /must/ be 0 or 1. The @maxDrawIndirectCount@ member of the
    -- 'PhysicalDeviceLimits' structure /must/ also be 1 if this feature is not
    -- supported. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-maxDrawIndirectCount maxDrawIndirectCount>.
    PhysicalDeviceFeatures -> Bool
multiDrawIndirect :: Bool
  , -- | #features-drawIndirectFirstInstance# @drawIndirectFirstInstance@
    -- specifies whether indirect drawing calls support the @firstInstance@
    -- parameter. If this feature is not enabled, the @firstInstance@ member of
    -- all 'Vulkan.Core10.OtherTypes.DrawIndirectCommand' and
    -- 'Vulkan.Core10.OtherTypes.DrawIndexedIndirectCommand' structures that
    -- are provided to the
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdDrawIndirect' and
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdDrawIndexedIndirect' commands
    -- /must/ be 0.
    PhysicalDeviceFeatures -> Bool
drawIndirectFirstInstance :: Bool
  , -- | #features-depthClamp# @depthClamp@ specifies whether depth clamping is
    -- supported. If this feature is not enabled, the @depthClampEnable@ member
    -- of the 'Vulkan.Core10.Pipeline.PipelineRasterizationStateCreateInfo'
    -- structure /must/ be set to 'Vulkan.Core10.FundamentalTypes.FALSE'.
    -- Otherwise, setting @depthClampEnable@ to
    -- 'Vulkan.Core10.FundamentalTypes.TRUE' will enable depth clamping.
    PhysicalDeviceFeatures -> Bool
depthClamp :: Bool
  , -- | #features-depthBiasClamp# @depthBiasClamp@ specifies whether depth bias
    -- clamping is supported. If this feature is not enabled, the
    -- @depthBiasClamp@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineRasterizationStateCreateInfo' structure
    -- /must/ be set to 0.0 unless the
    -- 'Vulkan.Core10.Enums.DynamicState.DYNAMIC_STATE_DEPTH_BIAS' dynamic
    -- state is enabled, and the @depthBiasClamp@ parameter to
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdSetDepthBias' /must/ be set to
    -- 0.0.
    PhysicalDeviceFeatures -> Bool
depthBiasClamp :: Bool
  , -- | #features-fillModeNonSolid# @fillModeNonSolid@ specifies whether point
    -- and wireframe fill modes are supported. If this feature is not enabled,
    -- the 'Vulkan.Core10.Enums.PolygonMode.POLYGON_MODE_POINT' and
    -- 'Vulkan.Core10.Enums.PolygonMode.POLYGON_MODE_LINE' enum values /must/
    -- not be used.
    PhysicalDeviceFeatures -> Bool
fillModeNonSolid :: Bool
  , -- | #features-depthBounds# @depthBounds@ specifies whether depth bounds
    -- tests are supported. If this feature is not enabled, the
    -- @depthBoundsTestEnable@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineDepthStencilStateCreateInfo' structure
    -- /must/ be set to 'Vulkan.Core10.FundamentalTypes.FALSE'. When
    -- @depthBoundsTestEnable@ is set to
    -- 'Vulkan.Core10.FundamentalTypes.FALSE', the @minDepthBounds@ and
    -- @maxDepthBounds@ members of the
    -- 'Vulkan.Core10.Pipeline.PipelineDepthStencilStateCreateInfo' structure
    -- are ignored.
    PhysicalDeviceFeatures -> Bool
depthBounds :: Bool
  , -- | #features-wideLines# @wideLines@ specifies whether lines with width
    -- other than 1.0 are supported. If this feature is not enabled, the
    -- @lineWidth@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineRasterizationStateCreateInfo' structure
    -- /must/ be set to 1.0 unless the
    -- 'Vulkan.Core10.Enums.DynamicState.DYNAMIC_STATE_LINE_WIDTH' dynamic
    -- state is enabled, and the @lineWidth@ parameter to
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdSetLineWidth' /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 'PhysicalDeviceLimits' structure,
    -- respectively.
    PhysicalDeviceFeatures -> Bool
wideLines :: Bool
  , -- | #features-largePoints# @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
    -- 'PhysicalDeviceLimits' structure, respectively.
    PhysicalDeviceFeatures -> Bool
largePoints :: Bool
  , -- | #features-alphaToOne# @alphaToOne@ specifies whether the implementation
    -- is able to replace the alpha value of the fragment shader color output
    -- in the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fragops-covg Multisample Coverage>
    -- fragment operation. If this feature is not enabled, then the
    -- @alphaToOneEnable@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineMultisampleStateCreateInfo' structure
    -- /must/ be set to 'Vulkan.Core10.FundamentalTypes.FALSE'. Otherwise
    -- setting @alphaToOneEnable@ to 'Vulkan.Core10.FundamentalTypes.TRUE' will
    -- enable alpha-to-one behavior.
    PhysicalDeviceFeatures -> Bool
alphaToOne :: Bool
  , -- | #features-multiViewport# @multiViewport@ specifies whether more than one
    -- viewport is supported. If this feature is not enabled:
    --
    -- -   The @viewportCount@ and @scissorCount@ members of the
    --     'Vulkan.Core10.Pipeline.PipelineViewportStateCreateInfo' structure
    --     /must/ be set to 1.
    --
    -- -   The @firstViewport@ and @viewportCount@ parameters to the
    --     'Vulkan.Core10.CommandBufferBuilding.cmdSetViewport' command /must/
    --     be set to 0 and 1, respectively.
    --
    -- -   The @firstScissor@ and @scissorCount@ parameters to the
    --     'Vulkan.Core10.CommandBufferBuilding.cmdSetScissor' command /must/
    --     be set to 0 and 1, respectively.
    --
    -- -   The @exclusiveScissorCount@ member of the
    --     'Vulkan.Extensions.VK_NV_scissor_exclusive.PipelineViewportExclusiveScissorStateCreateInfoNV'
    --     structure /must/ be set to 0 or 1.
    --
    -- -   The @firstExclusiveScissor@ and @exclusiveScissorCount@ parameters
    --     to the
    --     'Vulkan.Extensions.VK_NV_scissor_exclusive.cmdSetExclusiveScissorNV'
    --     command /must/ be set to 0 and 1, respectively.
    PhysicalDeviceFeatures -> Bool
multiViewport :: Bool
  , -- | #features-samplerAnisotropy# @samplerAnisotropy@ specifies whether
    -- anisotropic filtering is supported. If this feature is not enabled, the
    -- @anisotropyEnable@ member of the
    -- 'Vulkan.Core10.Sampler.SamplerCreateInfo' structure /must/ be
    -- 'Vulkan.Core10.FundamentalTypes.FALSE'.
    PhysicalDeviceFeatures -> Bool
samplerAnisotropy :: Bool
  , -- | #features-textureCompressionETC2# @textureCompressionETC2@ specifies
    -- whether all of the ETC2 and EAC compressed texture formats are
    -- supported. If this feature is enabled, then the
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_BIT',
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_BLIT_SRC_BIT'
    -- and
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT'
    -- features /must/ be supported in @optimalTilingFeatures@ for the
    -- following formats:
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_EAC_R11_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_EAC_R11_SNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_EAC_R11G11_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_EAC_R11G11_SNORM_BLOCK'
    --
    -- To query for additional properties, or if the feature is not enabled,
    -- 'getPhysicalDeviceFormatProperties' and
    -- 'getPhysicalDeviceImageFormatProperties' /can/ be used to check for
    -- supported properties of individual formats as normal.
    PhysicalDeviceFeatures -> Bool
textureCompressionETC2 :: Bool
  , -- | #features-textureCompressionASTC_LDR# @textureCompressionASTC_LDR@
    -- specifies whether all of the ASTC LDR compressed texture formats are
    -- supported. If this feature is enabled, then the
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_BIT',
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_BLIT_SRC_BIT'
    -- and
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT'
    -- features /must/ be supported in @optimalTilingFeatures@ for the
    -- following formats:
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_4x4_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_4x4_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_5x4_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_5x4_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_5x5_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_5x5_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_6x5_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_6x5_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_6x6_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_6x6_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x5_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x5_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x6_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x6_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x8_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_8x8_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x5_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x5_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x6_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x6_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x8_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x8_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x10_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_10x10_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_12x10_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_12x10_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_12x12_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_ASTC_12x12_SRGB_BLOCK'
    --
    -- To query for additional properties, or if the feature is not enabled,
    -- 'getPhysicalDeviceFormatProperties' and
    -- 'getPhysicalDeviceImageFormatProperties' /can/ be used to check for
    -- supported properties of individual formats as normal.
    PhysicalDeviceFeatures -> Bool
textureCompressionASTC_LDR :: Bool
  , -- | #features-textureCompressionBC# @textureCompressionBC@ specifies whether
    -- all of the BC compressed texture formats are supported. If this feature
    -- is enabled, then the
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_BIT',
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_BLIT_SRC_BIT'
    -- and
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_SAMPLED_IMAGE_FILTER_LINEAR_BIT'
    -- features /must/ be supported in @optimalTilingFeatures@ for the
    -- following formats:
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC1_RGB_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC1_RGB_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC1_RGBA_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC1_RGBA_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC2_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC2_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC3_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC3_SRGB_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC4_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC4_SNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC5_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC5_SNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC6H_UFLOAT_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC6H_SFLOAT_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC7_UNORM_BLOCK'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_BC7_SRGB_BLOCK'
    --
    -- To query for additional properties, or if the feature is not enabled,
    -- 'getPhysicalDeviceFormatProperties' and
    -- 'getPhysicalDeviceImageFormatProperties' /can/ be used to check for
    -- supported properties of individual formats as normal.
    PhysicalDeviceFeatures -> Bool
textureCompressionBC :: Bool
  , -- | #features-occlusionQueryPrecise# @occlusionQueryPrecise@ specifies
    -- whether occlusion queries returning actual sample counts are supported.
    -- Occlusion queries are created in a 'Vulkan.Core10.Handles.QueryPool' by
    -- specifying the @queryType@ of
    -- 'Vulkan.Core10.Enums.QueryType.QUERY_TYPE_OCCLUSION' in the
    -- 'Vulkan.Core10.Query.QueryPoolCreateInfo' structure which is passed to
    -- 'Vulkan.Core10.Query.createQueryPool'. If this feature is enabled,
    -- queries of this type /can/ enable
    -- 'Vulkan.Core10.Enums.QueryControlFlagBits.QUERY_CONTROL_PRECISE_BIT' in
    -- the @flags@ parameter to
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdBeginQuery'. 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
    -- 'Vulkan.Core10.Enums.QueryControlFlagBits.QUERY_CONTROL_PRECISE_BIT' is
    -- set, occlusion queries will report the actual number of samples passed.
    PhysicalDeviceFeatures -> Bool
occlusionQueryPrecise :: Bool
  , -- | #features-pipelineStatisticsQuery# @pipelineStatisticsQuery@ specifies
    -- whether the pipeline statistics queries are supported. If this feature
    -- is not enabled, queries of type
    -- 'Vulkan.Core10.Enums.QueryType.QUERY_TYPE_PIPELINE_STATISTICS' /cannot/
    -- be created, and none of the
    -- 'Vulkan.Core10.Enums.QueryPipelineStatisticFlagBits.QueryPipelineStatisticFlagBits'
    -- bits /can/ be set in the @pipelineStatistics@ member of the
    -- 'Vulkan.Core10.Query.QueryPoolCreateInfo' structure.
    PhysicalDeviceFeatures -> Bool
pipelineStatisticsQuery :: Bool
  , -- | #features-vertexPipelineStoresAndAtomics#
    -- @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 buffer, and storage buffer variables used by these
    -- stages in shader modules /must/ be decorated with the @NonWritable@
    -- decoration (or the @readonly@ memory qualifier in GLSL).
    PhysicalDeviceFeatures -> Bool
vertexPipelineStoresAndAtomics :: Bool
  , -- | #features-fragmentStoresAndAtomics# @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 buffer, and storage buffer variables used
    -- by the fragment stage in shader modules /must/ be decorated with the
    -- @NonWritable@ decoration (or the @readonly@ memory qualifier in GLSL).
    PhysicalDeviceFeatures -> Bool
fragmentStoresAndAtomics :: Bool
  , -- | #features-shaderTessellationAndGeometryPointSize#
    -- @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-tessellationShader tessellationShader>
    -- or
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-geometryShader geometryShader>
    -- features.
    PhysicalDeviceFeatures -> Bool
shaderTessellationAndGeometryPointSize :: Bool
  , -- | #features-shaderImageGatherExtended# @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.
    PhysicalDeviceFeatures -> Bool
shaderImageGatherExtended :: Bool
  , -- | #features-shaderStorageImageExtendedFormats#
    -- @shaderStorageImageExtendedFormats@ specifies whether all the “storage
    -- image extended formats” below are supported; if this feature is
    -- supported, then the
    -- 'Vulkan.Core10.Enums.FormatFeatureFlagBits.FORMAT_FEATURE_STORAGE_IMAGE_BIT'
    -- /must/ be supported in @optimalTilingFeatures@ for the following
    -- formats:
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16_SFLOAT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_B10G11R11_UFLOAT_PACK32'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16_SFLOAT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16B16A16_UNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_A2B10G10R10_UNORM_PACK32'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16_UNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8G8_UNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16_UNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8_UNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16B16A16_SNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16_SNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8G8_SNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16_SNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8_SNORM'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16_SINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8G8_SINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16_SINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8_SINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_A2B10G10R10_UINT_PACK32'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16G16_UINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8G8_UINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R16_UINT'
    --
    -- -   'Vulkan.Core10.Enums.Format.FORMAT_R8_UINT'
    --
    -- Note
    --
    -- @shaderStorageImageExtendedFormats@ feature only adds a guarantee of
    -- format support, which is specified for the whole physical device.
    -- Therefore enabling or disabling the feature via
    -- 'Vulkan.Core10.Device.createDevice' has no practical effect.
    --
    -- To query for additional properties, or if the feature is not supported,
    -- 'getPhysicalDeviceFormatProperties' and
    -- 'getPhysicalDeviceImageFormatProperties' /can/ be used to check for
    -- supported properties of individual formats, as usual rules allow.
    --
    -- 'Vulkan.Core10.Enums.Format.FORMAT_R32G32_UINT',
    -- 'Vulkan.Core10.Enums.Format.FORMAT_R32G32_SINT', and
    -- 'Vulkan.Core10.Enums.Format.FORMAT_R32G32_SFLOAT' from
    -- @StorageImageExtendedFormats@ SPIR-V capability, are already covered by
    -- core Vulkan
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#formats-mandatory-features-32bit mandatory format support>.
    PhysicalDeviceFeatures -> Bool
shaderStorageImageExtendedFormats :: Bool
  , -- | #features-shaderStorageImageMultisample# @shaderStorageImageMultisample@
    -- specifies whether multisampled storage images are supported. If this
    -- feature is not enabled, images that are created with a @usage@ that
    -- includes
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_STORAGE_BIT' /must/
    -- be created with @samples@ equal to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_1_BIT'. This also
    -- specifies whether shader modules /can/ declare the
    -- @StorageImageMultisample@ and @ImageMSArray@ capabilities.
    PhysicalDeviceFeatures -> Bool
shaderStorageImageMultisample :: Bool
  , -- | #features-shaderStorageImageReadWithoutFormat#
    -- @shaderStorageImageReadWithoutFormat@ specifies whether storage images
    -- and storage texel buffers require a format qualifier to be specified
    -- when reading. @shaderStorageImageReadWithoutFormat@ applies only to
    -- formats listed in the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#formats-without-shader-storage-format storage without format>
    -- list.
    PhysicalDeviceFeatures -> Bool
shaderStorageImageReadWithoutFormat :: Bool
  , -- | #features-shaderStorageImageWriteWithoutFormat#
    -- @shaderStorageImageWriteWithoutFormat@ specifies whether storage images
    -- and storage texel buffers require a format qualifier to be specified
    -- when writing. @shaderStorageImageWriteWithoutFormat@ applies only to
    -- formats listed in the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#formats-without-shader-storage-format storage without format>
    -- list.
    PhysicalDeviceFeatures -> Bool
shaderStorageImageWriteWithoutFormat :: Bool
  , -- | #features-shaderUniformBufferArrayDynamicIndexing#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.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.
    PhysicalDeviceFeatures -> Bool
shaderUniformBufferArrayDynamicIndexing :: Bool
  , -- | #features-shaderSampledImageArrayDynamicIndexing#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER',
    -- or 'Vulkan.Core10.Enums.DescriptorType.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.
    PhysicalDeviceFeatures -> Bool
shaderSampledImageArrayDynamicIndexing :: Bool
  , -- | #features-shaderStorageBufferArrayDynamicIndexing#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.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.
    PhysicalDeviceFeatures -> Bool
shaderStorageBufferArrayDynamicIndexing :: Bool
  , -- | #features-shaderStorageImageArrayDynamicIndexing#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.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.
    PhysicalDeviceFeatures -> Bool
shaderStorageImageArrayDynamicIndexing :: Bool
  , -- | #features-shaderClipDistance# @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.
    PhysicalDeviceFeatures -> Bool
shaderClipDistance :: Bool
  , -- | #features-shaderCullDistance# @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.
    PhysicalDeviceFeatures -> Bool
shaderCullDistance :: Bool
  , -- | #features-shaderFloat64# @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.
    -- Declaring and using 64-bit floats is enabled for all storage classes
    -- that SPIR-V allows with the @Float64@ capability.
    PhysicalDeviceFeatures -> Bool
shaderFloat64 :: Bool
  , -- | #features-shaderInt64# @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. Declaring and using 64-bit integers is enabled for all
    -- storage classes that SPIR-V allows with the @Int64@ capability.
    PhysicalDeviceFeatures -> Bool
shaderInt64 :: Bool
  , -- | #features-shaderInt16# @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. However, this only enables a subset of the storage classes
    -- that SPIR-V allows for the @Int16@ SPIR-V capability: Declaring and
    -- using 16-bit integers in the @Private@, @Workgroup@ (for non-Block
    -- variables), and @Function@ storage classes is enabled, while declaring
    -- them in the interface storage classes (e.g., @UniformConstant@,
    -- @Uniform@, @StorageBuffer@, @Input@, @Output@, and @PushConstant@) is
    -- not enabled.
    PhysicalDeviceFeatures -> Bool
shaderInt16 :: Bool
  , -- | #features-shaderResourceResidency# @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.
    PhysicalDeviceFeatures -> Bool
shaderResourceResidency :: Bool
  , -- | #features-shaderResourceMinLod# @shaderResourceMinLod@ specifies whether
    -- image operations specifying 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.
    PhysicalDeviceFeatures -> Bool
shaderResourceMinLod :: Bool
  , -- | #features-sparseBinding# @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
    -- 'Vulkan.Core10.MemoryManagement.bindBufferMemory' and
    -- 'Vulkan.Core10.MemoryManagement.bindImageMemory' commands. In this case,
    -- buffers and images /must/ not be created with
    -- 'Vulkan.Core10.Enums.BufferCreateFlagBits.BUFFER_CREATE_SPARSE_BINDING_BIT'
    -- and
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_BINDING_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Buffer.BufferCreateInfo'
    -- and 'Vulkan.Core10.Image.ImageCreateInfo' structures, respectively.
    -- Otherwise resource memory /can/ be managed as described in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#sparsememory-sparseresourcefeatures Sparse Resource Features>.
    PhysicalDeviceFeatures -> Bool
sparseBinding :: Bool
  , -- | #features-sparseResidencyBuffer# @sparseResidencyBuffer@ specifies
    -- whether the device /can/ access partially resident buffers. If this
    -- feature is not enabled, buffers /must/ not be created with
    -- 'Vulkan.Core10.Enums.BufferCreateFlagBits.BUFFER_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Buffer.BufferCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidencyBuffer :: Bool
  , -- | #features-sparseResidencyImage2D# @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 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and
    -- @samples@ set to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_1_BIT' /must/ not
    -- be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidencyImage2D :: Bool
  , -- | #features-sparseResidencyImage3D# @sparseResidencyImage3D@ specifies
    -- whether the device /can/ access partially resident 3D images. If this
    -- feature is not enabled, images with an @imageType@ of
    -- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_3D' /must/ not be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidencyImage3D :: Bool
  , -- | #features-sparseResidency2Samples# @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 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and
    -- @samples@ set to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_2_BIT' /must/ not
    -- be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidency2Samples :: Bool
  , -- | #features-sparseResidency4Samples# @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 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and
    -- @samples@ set to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_4_BIT' /must/ not
    -- be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidency4Samples :: Bool
  , -- | #features-sparseResidency8Samples# @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 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and
    -- @samples@ set to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_8_BIT' /must/ not
    -- be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidency8Samples :: Bool
  , -- | #features-sparseResidency16Samples# @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 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and
    -- @samples@ set to
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SAMPLE_COUNT_16_BIT' /must/ not
    -- be created with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_RESIDENCY_BIT'
    -- set in the @flags@ member of the 'Vulkan.Core10.Image.ImageCreateInfo'
    -- structure.
    PhysicalDeviceFeatures -> Bool
sparseResidency16Samples :: Bool
  , -- | #features-sparseResidencyAliased# @sparseResidencyAliased@ specifies
    -- whether the physical device /can/ correctly access data aliased into
    -- multiple locations. If this feature is not enabled, the
    -- 'Vulkan.Core10.Enums.BufferCreateFlagBits.BUFFER_CREATE_SPARSE_ALIASED_BIT'
    -- and
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_SPARSE_ALIASED_BIT'
    -- enum values /must/ not be used in @flags@ members of the
    -- 'Vulkan.Core10.Buffer.BufferCreateInfo' and
    -- 'Vulkan.Core10.Image.ImageCreateInfo' structures, respectively.
    PhysicalDeviceFeatures -> Bool
sparseResidencyAliased :: Bool
  , -- | #features-variableMultisampleRate# @variableMultisampleRate@ specifies
    -- whether all pipelines that will be bound to a command buffer during a
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#renderpass-noattachments subpass which uses no attachments>
    -- /must/ have the same value for
    -- 'Vulkan.Core10.Pipeline.PipelineMultisampleStateCreateInfo'::@rasterizationSamples@.
    -- If set to 'Vulkan.Core10.FundamentalTypes.TRUE', the implementation
    -- supports variable multisample rates in a subpass which uses no
    -- attachments. If set to 'Vulkan.Core10.FundamentalTypes.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.
    PhysicalDeviceFeatures -> Bool
variableMultisampleRate :: Bool
  , -- | #features-inheritedQueries# @inheritedQueries@ specifies whether a
    -- secondary command buffer /may/ be executed while a query is active.
    PhysicalDeviceFeatures -> Bool
inheritedQueries :: Bool
  }
  deriving (Typeable, PhysicalDeviceFeatures -> PhysicalDeviceFeatures -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PhysicalDeviceFeatures -> PhysicalDeviceFeatures -> Bool
$c/= :: PhysicalDeviceFeatures -> PhysicalDeviceFeatures -> Bool
== :: PhysicalDeviceFeatures -> PhysicalDeviceFeatures -> Bool
$c== :: PhysicalDeviceFeatures -> PhysicalDeviceFeatures -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceFeatures)
#endif
deriving instance Show PhysicalDeviceFeatures

instance ToCStruct PhysicalDeviceFeatures where
  withCStruct :: forall b.
PhysicalDeviceFeatures
-> (("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO b) -> IO b
withCStruct PhysicalDeviceFeatures
x ("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
220 forall a b. (a -> b) -> a -> b
$ \"pFeatures" ::: Ptr PhysicalDeviceFeatures
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pFeatures" ::: Ptr PhysicalDeviceFeatures
p PhysicalDeviceFeatures
x (("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO b
f "pFeatures" ::: Ptr PhysicalDeviceFeatures
p)
  pokeCStruct :: forall b.
("pFeatures" ::: Ptr PhysicalDeviceFeatures)
-> PhysicalDeviceFeatures -> IO b -> IO b
pokeCStruct "pFeatures" ::: Ptr PhysicalDeviceFeatures
p PhysicalDeviceFeatures{Bool
inheritedQueries :: Bool
variableMultisampleRate :: Bool
sparseResidencyAliased :: Bool
sparseResidency16Samples :: Bool
sparseResidency8Samples :: Bool
sparseResidency4Samples :: Bool
sparseResidency2Samples :: Bool
sparseResidencyImage3D :: Bool
sparseResidencyImage2D :: Bool
sparseResidencyBuffer :: Bool
sparseBinding :: Bool
shaderResourceMinLod :: Bool
shaderResourceResidency :: Bool
shaderInt16 :: Bool
shaderInt64 :: Bool
shaderFloat64 :: Bool
shaderCullDistance :: Bool
shaderClipDistance :: Bool
shaderStorageImageArrayDynamicIndexing :: Bool
shaderStorageBufferArrayDynamicIndexing :: Bool
shaderSampledImageArrayDynamicIndexing :: Bool
shaderUniformBufferArrayDynamicIndexing :: Bool
shaderStorageImageWriteWithoutFormat :: Bool
shaderStorageImageReadWithoutFormat :: Bool
shaderStorageImageMultisample :: Bool
shaderStorageImageExtendedFormats :: Bool
shaderImageGatherExtended :: Bool
shaderTessellationAndGeometryPointSize :: Bool
fragmentStoresAndAtomics :: Bool
vertexPipelineStoresAndAtomics :: Bool
pipelineStatisticsQuery :: Bool
occlusionQueryPrecise :: Bool
textureCompressionBC :: Bool
textureCompressionASTC_LDR :: Bool
textureCompressionETC2 :: Bool
samplerAnisotropy :: Bool
multiViewport :: Bool
alphaToOne :: Bool
largePoints :: Bool
wideLines :: Bool
depthBounds :: Bool
fillModeNonSolid :: Bool
depthBiasClamp :: Bool
depthClamp :: Bool
drawIndirectFirstInstance :: Bool
multiDrawIndirect :: Bool
logicOp :: Bool
dualSrcBlend :: Bool
sampleRateShading :: Bool
tessellationShader :: Bool
geometryShader :: Bool
independentBlend :: Bool
imageCubeArray :: Bool
fullDrawIndexUint32 :: Bool
robustBufferAccess :: Bool
$sel:inheritedQueries:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:variableMultisampleRate:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidencyAliased:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidency16Samples:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidency8Samples:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidency4Samples:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidency2Samples:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidencyImage3D:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidencyImage2D:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseResidencyBuffer:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sparseBinding:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderResourceMinLod:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderResourceResidency:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderInt16:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderInt64:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderFloat64:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderCullDistance:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderClipDistance:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageImageArrayDynamicIndexing:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageBufferArrayDynamicIndexing:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderSampledImageArrayDynamicIndexing:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderUniformBufferArrayDynamicIndexing:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageImageWriteWithoutFormat:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageImageReadWithoutFormat:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageImageMultisample:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderStorageImageExtendedFormats:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderImageGatherExtended:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:shaderTessellationAndGeometryPointSize:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:fragmentStoresAndAtomics:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:vertexPipelineStoresAndAtomics:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:pipelineStatisticsQuery:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:occlusionQueryPrecise:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:textureCompressionBC:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:textureCompressionASTC_LDR:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:textureCompressionETC2:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:samplerAnisotropy:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:multiViewport:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:alphaToOne:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:largePoints:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:wideLines:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:depthBounds:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:fillModeNonSolid:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:depthBiasClamp:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:depthClamp:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:drawIndirectFirstInstance:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:multiDrawIndirect:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:logicOp:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:dualSrcBlend:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:sampleRateShading:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:tessellationShader:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:geometryShader:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:independentBlend:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:imageCubeArray:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:fullDrawIndexUint32:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
$sel:robustBufferAccess:PhysicalDeviceFeatures :: PhysicalDeviceFeatures -> Bool
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
robustBufferAccess))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
fullDrawIndexUint32))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
imageCubeArray))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
independentBlend))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
geometryShader))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
tessellationShader))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sampleRateShading))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
dualSrcBlend))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
logicOp))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
multiDrawIndirect))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
drawIndirectFirstInstance))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
depthClamp))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
depthBiasClamp))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
52 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
fillModeNonSolid))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
depthBounds))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
wideLines))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
largePoints))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
alphaToOne))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
multiViewport))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
samplerAnisotropy))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
textureCompressionETC2))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
textureCompressionASTC_LDR))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
textureCompressionBC))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
occlusionQueryPrecise))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
pipelineStatisticsQuery))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
vertexPipelineStoresAndAtomics))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
fragmentStoresAndAtomics))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderTessellationAndGeometryPointSize))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderImageGatherExtended))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageImageExtendedFormats))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageImageMultisample))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageImageReadWithoutFormat))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageImageWriteWithoutFormat))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderUniformBufferArrayDynamicIndexing))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderSampledImageArrayDynamicIndexing))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageBufferArrayDynamicIndexing))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderStorageImageArrayDynamicIndexing))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderClipDistance))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderCullDistance))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderFloat64))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderInt64))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderInt16))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderResourceResidency))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderResourceMinLod))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseBinding))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidencyBuffer))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidencyImage2D))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidencyImage3D))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidency2Samples))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidency4Samples))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidency8Samples))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidency16Samples))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
sparseResidencyAliased))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
variableMultisampleRate))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
inheritedQueries))
    IO b
f
  cStructSize :: Int
cStructSize = Int
220
  cStructAlignment :: Int
cStructAlignment = Int
4
  pokeZeroCStruct :: forall b.
("pFeatures" ::: Ptr PhysicalDeviceFeatures) -> IO b -> IO b
pokeZeroCStruct "pFeatures" ::: Ptr PhysicalDeviceFeatures
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
52 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    IO b
f

instance FromCStruct PhysicalDeviceFeatures where
  peekCStruct :: ("pFeatures" ::: Ptr PhysicalDeviceFeatures)
-> IO PhysicalDeviceFeatures
peekCStruct "pFeatures" ::: Ptr PhysicalDeviceFeatures
p = do
    Bool32
robustBufferAccess <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32))
    Bool32
fullDrawIndexUint32 <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32))
    Bool32
imageCubeArray <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32))
    Bool32
independentBlend <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32))
    Bool32
geometryShader <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
    Bool32
tessellationShader <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Bool32))
    Bool32
sampleRateShading <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Bool32))
    Bool32
dualSrcBlend <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Bool32))
    Bool32
logicOp <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Bool32))
    Bool32
multiDrawIndirect <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Bool32))
    Bool32
drawIndirectFirstInstance <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Bool32))
    Bool32
depthClamp <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
44 :: Ptr Bool32))
    Bool32
depthBiasClamp <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr Bool32))
    Bool32
fillModeNonSolid <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
52 :: Ptr Bool32))
    Bool32
depthBounds <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr Bool32))
    Bool32
wideLines <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
60 :: Ptr Bool32))
    Bool32
largePoints <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Bool32))
    Bool32
alphaToOne <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Bool32))
    Bool32
multiViewport <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Bool32))
    Bool32
samplerAnisotropy <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Bool32))
    Bool32
textureCompressionETC2 <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Bool32))
    Bool32
textureCompressionASTC_LDR <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Bool32))
    Bool32
textureCompressionBC <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Bool32))
    Bool32
occlusionQueryPrecise <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Bool32))
    Bool32
pipelineStatisticsQuery <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Bool32))
    Bool32
vertexPipelineStoresAndAtomics <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Bool32))
    Bool32
fragmentStoresAndAtomics <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Bool32))
    Bool32
shaderTessellationAndGeometryPointSize <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Bool32))
    Bool32
shaderImageGatherExtended <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Bool32))
    Bool32
shaderStorageImageExtendedFormats <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Bool32))
    Bool32
shaderStorageImageMultisample <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Bool32))
    Bool32
shaderStorageImageReadWithoutFormat <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Bool32))
    Bool32
shaderStorageImageWriteWithoutFormat <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Bool32))
    Bool32
shaderUniformBufferArrayDynamicIndexing <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Bool32))
    Bool32
shaderSampledImageArrayDynamicIndexing <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Bool32))
    Bool32
shaderStorageBufferArrayDynamicIndexing <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Bool32))
    Bool32
shaderStorageImageArrayDynamicIndexing <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Bool32))
    Bool32
shaderClipDistance <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Bool32))
    Bool32
shaderCullDistance <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Bool32))
    Bool32
shaderFloat64 <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Bool32))
    Bool32
shaderInt64 <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Bool32))
    Bool32
shaderInt16 <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Bool32))
    Bool32
shaderResourceResidency <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Bool32))
    Bool32
shaderResourceMinLod <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Bool32))
    Bool32
sparseBinding <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Bool32))
    Bool32
sparseResidencyBuffer <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Bool32))
    Bool32
sparseResidencyImage2D <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Bool32))
    Bool32
sparseResidencyImage3D <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Bool32))
    Bool32
sparseResidency2Samples <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Bool32))
    Bool32
sparseResidency4Samples <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Bool32))
    Bool32
sparseResidency8Samples <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Bool32))
    Bool32
sparseResidency16Samples <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Bool32))
    Bool32
sparseResidencyAliased <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Bool32))
    Bool32
variableMultisampleRate <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Bool32))
    Bool32
inheritedQueries <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 (("pFeatures" ::: Ptr PhysicalDeviceFeatures
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Bool32))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> PhysicalDeviceFeatures
PhysicalDeviceFeatures
             (Bool32 -> Bool
bool32ToBool Bool32
robustBufferAccess)
             (Bool32 -> Bool
bool32ToBool Bool32
fullDrawIndexUint32)
             (Bool32 -> Bool
bool32ToBool Bool32
imageCubeArray)
             (Bool32 -> Bool
bool32ToBool Bool32
independentBlend)
             (Bool32 -> Bool
bool32ToBool Bool32
geometryShader)
             (Bool32 -> Bool
bool32ToBool Bool32
tessellationShader)
             (Bool32 -> Bool
bool32ToBool Bool32
sampleRateShading)
             (Bool32 -> Bool
bool32ToBool Bool32
dualSrcBlend)
             (Bool32 -> Bool
bool32ToBool Bool32
logicOp)
             (Bool32 -> Bool
bool32ToBool Bool32
multiDrawIndirect)
             (Bool32 -> Bool
bool32ToBool Bool32
drawIndirectFirstInstance)
             (Bool32 -> Bool
bool32ToBool Bool32
depthClamp)
             (Bool32 -> Bool
bool32ToBool Bool32
depthBiasClamp)
             (Bool32 -> Bool
bool32ToBool Bool32
fillModeNonSolid)
             (Bool32 -> Bool
bool32ToBool Bool32
depthBounds)
             (Bool32 -> Bool
bool32ToBool Bool32
wideLines)
             (Bool32 -> Bool
bool32ToBool Bool32
largePoints)
             (Bool32 -> Bool
bool32ToBool Bool32
alphaToOne)
             (Bool32 -> Bool
bool32ToBool Bool32
multiViewport)
             (Bool32 -> Bool
bool32ToBool Bool32
samplerAnisotropy)
             (Bool32 -> Bool
bool32ToBool Bool32
textureCompressionETC2)
             (Bool32 -> Bool
bool32ToBool Bool32
textureCompressionASTC_LDR)
             (Bool32 -> Bool
bool32ToBool Bool32
textureCompressionBC)
             (Bool32 -> Bool
bool32ToBool Bool32
occlusionQueryPrecise)
             (Bool32 -> Bool
bool32ToBool Bool32
pipelineStatisticsQuery)
             (Bool32 -> Bool
bool32ToBool Bool32
vertexPipelineStoresAndAtomics)
             (Bool32 -> Bool
bool32ToBool Bool32
fragmentStoresAndAtomics)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderTessellationAndGeometryPointSize)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderImageGatherExtended)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageImageExtendedFormats)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageImageMultisample)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageImageReadWithoutFormat)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageImageWriteWithoutFormat)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderUniformBufferArrayDynamicIndexing)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderSampledImageArrayDynamicIndexing)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageBufferArrayDynamicIndexing)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderStorageImageArrayDynamicIndexing)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderClipDistance)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderCullDistance)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderFloat64)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderInt64)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderInt16)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderResourceResidency)
             (Bool32 -> Bool
bool32ToBool Bool32
shaderResourceMinLod)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseBinding)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidencyBuffer)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidencyImage2D)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidencyImage3D)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidency2Samples)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidency4Samples)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidency8Samples)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidency16Samples)
             (Bool32 -> Bool
bool32ToBool Bool32
sparseResidencyAliased)
             (Bool32 -> Bool
bool32ToBool Bool32
variableMultisampleRate)
             (Bool32 -> Bool
bool32ToBool Bool32
inheritedQueries)

instance Storable PhysicalDeviceFeatures where
  sizeOf :: PhysicalDeviceFeatures -> Int
sizeOf ~PhysicalDeviceFeatures
_ = Int
220
  alignment :: PhysicalDeviceFeatures -> Int
alignment ~PhysicalDeviceFeatures
_ = Int
4
  peek :: ("pFeatures" ::: Ptr PhysicalDeviceFeatures)
-> IO PhysicalDeviceFeatures
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: ("pFeatures" ::: Ptr PhysicalDeviceFeatures)
-> PhysicalDeviceFeatures -> IO ()
poke "pFeatures" ::: Ptr PhysicalDeviceFeatures
ptr PhysicalDeviceFeatures
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct "pFeatures" ::: Ptr PhysicalDeviceFeatures
ptr PhysicalDeviceFeatures
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero PhysicalDeviceFeatures where
  zero :: PhysicalDeviceFeatures
zero = Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> Bool
-> PhysicalDeviceFeatures
PhysicalDeviceFeatures
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkPhysicalDeviceSparseProperties - Structure specifying physical device
-- sparse memory properties
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.Bool32', 'PhysicalDeviceProperties'
data PhysicalDeviceSparseProperties = PhysicalDeviceSparseProperties
  { -- | @residencyStandard2DBlockShape@ is 'Vulkan.Core10.FundamentalTypes.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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#sparsememory-sparseblockshapessingle Standard Sparse Image Block Shapes (Single Sample)>
    -- table. If this property is not supported the value returned in the
    -- @imageGranularity@ member of the
    -- 'Vulkan.Core10.SparseResourceMemoryManagement.SparseImageFormatProperties'
    -- structure for single-sample 2D images is not /required/ to match the
    -- standard sparse image block dimensions listed in the table.
    PhysicalDeviceSparseProperties -> Bool
residencyStandard2DBlockShape :: Bool
  , -- | @residencyStandard2DMultisampleBlockShape@ is
    -- 'Vulkan.Core10.FundamentalTypes.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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#sparsememory-sparseblockshapesmsaa Standard Sparse Image Block Shapes (MSAA)>
    -- table. If this property is not supported, the value returned in the
    -- @imageGranularity@ member of the
    -- 'Vulkan.Core10.SparseResourceMemoryManagement.SparseImageFormatProperties'
    -- structure for multisample 2D images is not /required/ to match the
    -- standard sparse image block dimensions listed in the table.
    PhysicalDeviceSparseProperties -> Bool
residencyStandard2DMultisampleBlockShape :: Bool
  , -- | @residencyStandard3DBlockShape@ is 'Vulkan.Core10.FundamentalTypes.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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#sparsememory-sparseblockshapessingle Standard Sparse Image Block Shapes (Single Sample)>
    -- table. If this property is not supported, the value returned in the
    -- @imageGranularity@ member of the
    -- 'Vulkan.Core10.SparseResourceMemoryManagement.SparseImageFormatProperties'
    -- structure for 3D images is not /required/ to match the standard sparse
    -- image block dimensions listed in the table.
    PhysicalDeviceSparseProperties -> Bool
residencyStandard3DBlockShape :: Bool
  , -- | @residencyAlignedMipSize@ is 'Vulkan.Core10.FundamentalTypes.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
    -- 'Vulkan.Core10.SparseResourceMemoryManagement.SparseImageFormatProperties'
    -- structure will be placed in the mip tail. If this property is reported
    -- the implementation is allowed to return
    -- 'Vulkan.Core10.Enums.SparseImageFormatFlagBits.SPARSE_IMAGE_FORMAT_ALIGNED_MIP_SIZE_BIT'
    -- in the @flags@ member of
    -- 'Vulkan.Core10.SparseResourceMemoryManagement.SparseImageFormatProperties',
    -- 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.
    PhysicalDeviceSparseProperties -> Bool
residencyAlignedMipSize :: Bool
  , -- | @residencyNonResidentStrict@ specifies whether the physical device /can/
    -- consistently access non-resident regions of a resource. If this property
    -- is 'Vulkan.Core10.FundamentalTypes.TRUE', access to non-resident regions
    -- of resources will be guaranteed to return values as if the resource was
    -- populated with 0; writes to non-resident regions will be discarded.
    PhysicalDeviceSparseProperties -> Bool
residencyNonResidentStrict :: Bool
  }
  deriving (Typeable, PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> Bool
$c/= :: PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> Bool
== :: PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> Bool
$c== :: PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceSparseProperties)
#endif
deriving instance Show PhysicalDeviceSparseProperties

instance ToCStruct PhysicalDeviceSparseProperties where
  withCStruct :: forall b.
PhysicalDeviceSparseProperties
-> (Ptr PhysicalDeviceSparseProperties -> IO b) -> IO b
withCStruct PhysicalDeviceSparseProperties
x Ptr PhysicalDeviceSparseProperties -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
20 forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceSparseProperties
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceSparseProperties
p PhysicalDeviceSparseProperties
x (Ptr PhysicalDeviceSparseProperties -> IO b
f Ptr PhysicalDeviceSparseProperties
p)
  pokeCStruct :: forall b.
Ptr PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceSparseProperties
p PhysicalDeviceSparseProperties{Bool
residencyNonResidentStrict :: Bool
residencyAlignedMipSize :: Bool
residencyStandard3DBlockShape :: Bool
residencyStandard2DMultisampleBlockShape :: Bool
residencyStandard2DBlockShape :: Bool
$sel:residencyNonResidentStrict:PhysicalDeviceSparseProperties :: PhysicalDeviceSparseProperties -> Bool
$sel:residencyAlignedMipSize:PhysicalDeviceSparseProperties :: PhysicalDeviceSparseProperties -> Bool
$sel:residencyStandard3DBlockShape:PhysicalDeviceSparseProperties :: PhysicalDeviceSparseProperties -> Bool
$sel:residencyStandard2DMultisampleBlockShape:PhysicalDeviceSparseProperties :: PhysicalDeviceSparseProperties -> Bool
$sel:residencyStandard2DBlockShape:PhysicalDeviceSparseProperties :: PhysicalDeviceSparseProperties -> Bool
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
residencyStandard2DBlockShape))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
residencyStandard2DMultisampleBlockShape))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
residencyStandard3DBlockShape))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
residencyAlignedMipSize))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
residencyNonResidentStrict))
    IO b
f
  cStructSize :: Int
cStructSize = Int
20
  cStructAlignment :: Int
cStructAlignment = Int
4
  pokeZeroCStruct :: forall b. Ptr PhysicalDeviceSparseProperties -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceSparseProperties
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    IO b
f

instance FromCStruct PhysicalDeviceSparseProperties where
  peekCStruct :: Ptr PhysicalDeviceSparseProperties
-> IO PhysicalDeviceSparseProperties
peekCStruct Ptr PhysicalDeviceSparseProperties
p = do
    Bool32
residencyStandard2DBlockShape <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Bool32))
    Bool32
residencyStandard2DMultisampleBlockShape <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Bool32))
    Bool32
residencyStandard3DBlockShape <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Bool32))
    Bool32
residencyAlignedMipSize <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Bool32))
    Bool32
residencyNonResidentStrict <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceSparseProperties
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Bool
-> Bool -> Bool -> Bool -> Bool -> PhysicalDeviceSparseProperties
PhysicalDeviceSparseProperties
             (Bool32 -> Bool
bool32ToBool Bool32
residencyStandard2DBlockShape)
             (Bool32 -> Bool
bool32ToBool Bool32
residencyStandard2DMultisampleBlockShape)
             (Bool32 -> Bool
bool32ToBool Bool32
residencyStandard3DBlockShape)
             (Bool32 -> Bool
bool32ToBool Bool32
residencyAlignedMipSize)
             (Bool32 -> Bool
bool32ToBool Bool32
residencyNonResidentStrict)

instance Storable PhysicalDeviceSparseProperties where
  sizeOf :: PhysicalDeviceSparseProperties -> Int
sizeOf ~PhysicalDeviceSparseProperties
_ = Int
20
  alignment :: PhysicalDeviceSparseProperties -> Int
alignment ~PhysicalDeviceSparseProperties
_ = Int
4
  peek :: Ptr PhysicalDeviceSparseProperties
-> IO PhysicalDeviceSparseProperties
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: Ptr PhysicalDeviceSparseProperties
-> PhysicalDeviceSparseProperties -> IO ()
poke Ptr PhysicalDeviceSparseProperties
ptr PhysicalDeviceSparseProperties
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceSparseProperties
ptr PhysicalDeviceSparseProperties
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero PhysicalDeviceSparseProperties where
  zero :: PhysicalDeviceSparseProperties
zero = Bool
-> Bool -> Bool -> Bool -> Bool -> PhysicalDeviceSparseProperties
PhysicalDeviceSparseProperties
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero


-- | VkPhysicalDeviceLimits - Structure reporting implementation-dependent
-- physical device limits
--
-- = Members
--
-- The 'PhysicalDeviceLimits' are properties of the physical device. These
-- are available in the @limits@ member of the 'PhysicalDeviceProperties'
-- structure which is returned from 'getPhysicalDeviceProperties'.
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_VERSION_1_0 VK_VERSION_1_0>,
-- 'Vulkan.Core10.FundamentalTypes.Bool32',
-- 'Vulkan.Core10.FundamentalTypes.DeviceSize', 'PhysicalDeviceProperties',
-- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlags'
data PhysicalDeviceLimits = PhysicalDeviceLimits
  { -- | #limits-maxImageDimension1D# @maxImageDimension1D@ is the largest
    -- dimension (@width@) that is guaranteed to be supported for all images
    -- created with an @imageType@ of
    -- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_1D'. Some combinations of
    -- image parameters (format, usage, etc.) /may/ allow support for larger
    -- dimensions, which /can/ be queried using
    -- 'getPhysicalDeviceImageFormatProperties'.
    PhysicalDeviceLimits -> Word32
maxImageDimension1D :: Word32
  , -- | #limits-maxImageDimension2D# @maxImageDimension2D@ is the largest
    -- dimension (@width@ or @height@) that is guaranteed to be supported for
    -- all images created with an @imageType@ of
    -- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and without
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_CUBE_COMPATIBLE_BIT'
    -- set in @flags@. Some combinations of image parameters (format, usage,
    -- etc.) /may/ allow support for larger dimensions, which /can/ be queried
    -- using 'getPhysicalDeviceImageFormatProperties'.
    PhysicalDeviceLimits -> Word32
maxImageDimension2D :: Word32
  , -- | #limits-maxImageDimension3D# @maxImageDimension3D@ is the largest
    -- dimension (@width@, @height@, or @depth@) that is guaranteed to be
    -- supported for all images created with an @imageType@ of
    -- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_3D'. Some combinations of
    -- image parameters (format, usage, etc.) /may/ allow support for larger
    -- dimensions, which /can/ be queried using
    -- 'getPhysicalDeviceImageFormatProperties'.
    PhysicalDeviceLimits -> Word32
maxImageDimension3D :: Word32
  , -- | #limits-maxImageDimensionCube# @maxImageDimensionCube@ is the largest
    -- dimension (@width@ or @height@) that is guaranteed to be supported for
    -- all images created with an @imageType@ of
    -- 'Vulkan.Core10.Enums.ImageType.IMAGE_TYPE_2D' and with
    -- 'Vulkan.Core10.Enums.ImageCreateFlagBits.IMAGE_CREATE_CUBE_COMPATIBLE_BIT'
    -- set in @flags@. Some combinations of image parameters (format, usage,
    -- etc.) /may/ allow support for larger dimensions, which /can/ be queried
    -- using 'getPhysicalDeviceImageFormatProperties'.
    PhysicalDeviceLimits -> Word32
maxImageDimensionCube :: Word32
  , -- | #limits-maxImageArrayLayers# @maxImageArrayLayers@ is the maximum number
    -- of layers (@arrayLayers@) for an image.
    PhysicalDeviceLimits -> Word32
maxImageArrayLayers :: Word32
  , -- | #limits-maxTexelBufferElements# @maxTexelBufferElements@ is the maximum
    -- number of addressable texels for a buffer view created on a buffer which
    -- was created with the
    -- 'Vulkan.Core10.Enums.BufferUsageFlagBits.BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT'
    -- or
    -- 'Vulkan.Core10.Enums.BufferUsageFlagBits.BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT'
    -- set in the @usage@ member of the 'Vulkan.Core10.Buffer.BufferCreateInfo'
    -- structure.
    PhysicalDeviceLimits -> Word32
maxTexelBufferElements :: Word32
  , -- | #limits-maxUniformBufferRange# @maxUniformBufferRange@ is the maximum
    -- value that /can/ be specified in the @range@ member of a
    -- 'Vulkan.Core10.DescriptorSet.DescriptorBufferInfo' structure passed to
    -- 'Vulkan.Core10.DescriptorSet.updateDescriptorSets' for descriptors of
    -- type 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER'
    -- or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC'.
    PhysicalDeviceLimits -> Word32
maxUniformBufferRange :: Word32
  , -- | #limits-maxStorageBufferRange# @maxStorageBufferRange@ is the maximum
    -- value that /can/ be specified in the @range@ member of a
    -- 'Vulkan.Core10.DescriptorSet.DescriptorBufferInfo' structure passed to
    -- 'Vulkan.Core10.DescriptorSet.updateDescriptorSets' for descriptors of
    -- type 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER'
    -- or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC'.
    PhysicalDeviceLimits -> Word32
maxStorageBufferRange :: Word32
  , -- | #limits-maxPushConstantsSize# @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 'Vulkan.Core10.PipelineLayout.PipelineLayoutCreateInfo' structure,
    -- (@offset@ + @size@) /must/ be less than or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxPushConstantsSize :: Word32
  , -- | #limits-maxMemoryAllocationCount# @maxMemoryAllocationCount@ is the
    -- maximum number of device memory allocations, as created by
    -- 'Vulkan.Core10.Memory.allocateMemory', which /can/ simultaneously exist.
    PhysicalDeviceLimits -> Word32
maxMemoryAllocationCount :: Word32
  , -- | #limits-maxSamplerAllocationCount# @maxSamplerAllocationCount@ is the
    -- maximum number of sampler objects, as created by
    -- 'Vulkan.Core10.Sampler.createSampler', which /can/ simultaneously exist
    -- on a device.
    PhysicalDeviceLimits -> Word32
maxSamplerAllocationCount :: Word32
  , -- | #limits-bufferImageGranularity# @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
    -- 'Vulkan.Core10.Handles.DeviceMemory' object without aliasing. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#resources-bufferimagegranularity Buffer-Image Granularity>
    -- for more details.
    PhysicalDeviceLimits -> DeviceSize
bufferImageGranularity :: DeviceSize
  , -- | #limits-sparseAddressSpaceSize# @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 sizes of all sparse
    -- resources, regardless of whether any memory is bound to them. If the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-extendedSparseAddressSpace extendedSparseAddressSpace>
    -- feature is enabled, then the difference between
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-extendedSparseAddressSpaceSize extendedSparseAddressSpaceSize>
    -- and @sparseAddressSpaceSize@ can also be used, by
    -- 'Vulkan.Core10.Handles.Image' created with the @usage@ member of
    -- 'Vulkan.Core10.Image.ImageCreateInfo' only containing bits in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-extendedSparseImageUsageFlags extendedSparseImageUsageFlags>
    -- and 'Vulkan.Core10.Handles.Buffer' created with the @usage@ member of
    -- 'Vulkan.Core10.Buffer.BufferCreateInfo' only containing bits in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-extendedSparseBufferUsageFlags extendedSparseBufferUsageFlags>.
    PhysicalDeviceLimits -> DeviceSize
sparseAddressSpaceSize :: DeviceSize
  , -- | #limits-maxBoundDescriptorSets# @maxBoundDescriptorSets@ is the maximum
    -- number of descriptor sets that /can/ be simultaneously used by a
    -- pipeline. All 'Vulkan.Core10.Handles.DescriptorSet' decorations in
    -- shader modules /must/ have a value less than @maxBoundDescriptorSets@.
    -- See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-sets>.
    PhysicalDeviceLimits -> Word32
maxBoundDescriptorSets :: Word32
  , -- | #limits-maxPerStageDescriptorSamplers# @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a shader
    -- stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-sampler>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-combinedimagesampler>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorSamplers :: Word32
  , -- | #limits-maxPerStageDescriptorUniformBuffers#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a shader
    -- stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformbuffer>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformbufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorUniformBuffers :: Word32
  , -- | #limits-maxPerStageDescriptorStorageBuffers#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a
    -- pipeline shader stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagebuffer>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagebufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorStorageBuffers :: Word32
  , -- | #limits-maxPerStageDescriptorSampledImages#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLED_IMAGE', or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a
    -- pipeline shader stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-combinedimagesampler>,
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-sampledimage>,
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformtexelbuffer>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorSampledImages :: Word32
  , -- | #limits-maxPerStageDescriptorStorageImages#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_IMAGE', or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a
    -- pipeline shader stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storageimage>,
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagetexelbuffer>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorStorageImages :: Word32
  , -- | #limits-maxPerStageDescriptorInputAttachments#
    -- @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_INPUT_ATTACHMENT'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. A descriptor is accessible to a
    -- pipeline shader stage when the @stageFlags@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorSetLayoutBinding' structure has
    -- the bit for that shader stage set. These are only supported for the
    -- fragment stage. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-inputattachment>.
    PhysicalDeviceLimits -> Word32
maxPerStageDescriptorInputAttachments :: Word32
  , -- | #limits-maxPerStageResources# @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
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLED_IMAGE',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_IMAGE',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC',
    -- or 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_INPUT_ATTACHMENT'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. For the fragment shader stage the
    -- framebuffer color attachments also count against this limit.
    PhysicalDeviceLimits -> Word32
maxPerStageResources :: Word32
  , -- | #limits-maxDescriptorSetSamplers# @maxDescriptorSetSamplers@ is the
    -- maximum number of samplers that /can/ be included in a pipeline layout.
    -- Descriptors with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-sampler>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-combinedimagesampler>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetSamplers :: Word32
  , -- | #limits-maxDescriptorSetUniformBuffers# @maxDescriptorSetUniformBuffers@
    -- is the maximum number of uniform buffers that /can/ be included in a
    -- pipeline layout. Descriptors with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformbuffer>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformbufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetUniformBuffers :: Word32
  , -- | #limits-maxDescriptorSetUniformBuffersDynamic#
    -- @maxDescriptorSetUniformBuffersDynamic@ is the maximum number of dynamic
    -- uniform buffers that /can/ be included in a pipeline layout. Descriptors
    -- with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformbufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetUniformBuffersDynamic :: Word32
  , -- | #limits-maxDescriptorSetStorageBuffers# @maxDescriptorSetStorageBuffers@
    -- is the maximum number of storage buffers that /can/ be included in a
    -- pipeline layout. Descriptors with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagebuffer>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagebufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetStorageBuffers :: Word32
  , -- | #limits-maxDescriptorSetStorageBuffersDynamic#
    -- @maxDescriptorSetStorageBuffersDynamic@ is the maximum number of dynamic
    -- storage buffers that /can/ be included in a pipeline layout. Descriptors
    -- with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagebufferdynamic>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetStorageBuffersDynamic :: Word32
  , -- | #limits-maxDescriptorSetSampledImages# @maxDescriptorSetSampledImages@
    -- is the maximum number of sampled images that /can/ be included in a
    -- pipeline layout. Descriptors with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER',
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_SAMPLED_IMAGE', or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-combinedimagesampler>,
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-sampledimage>,
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-uniformtexelbuffer>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetSampledImages :: Word32
  , -- | #limits-maxDescriptorSetStorageImages# @maxDescriptorSetStorageImages@
    -- is the maximum number of storage images that /can/ be included in a
    -- pipeline layout. Descriptors with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_IMAGE', or
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storageimage>,
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-storagetexelbuffer>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetStorageImages :: Word32
  , -- | #limits-maxDescriptorSetInputAttachments#
    -- @maxDescriptorSetInputAttachments@ is the maximum number of input
    -- attachments that /can/ be included in a pipeline layout. Descriptors
    -- with a type of
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_INPUT_ATTACHMENT'
    -- count against this limit. Only descriptors in descriptor set layouts
    -- created without the
    -- 'Vulkan.Core10.Enums.DescriptorSetLayoutCreateFlagBits.DESCRIPTOR_SET_LAYOUT_CREATE_UPDATE_AFTER_BIND_POOL_BIT'
    -- bit set count against this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#descriptorsets-inputattachment>.
    PhysicalDeviceLimits -> Word32
maxDescriptorSetInputAttachments :: Word32
  , -- | #limits-maxVertexInputAttributes# @maxVertexInputAttributes@ is the
    -- maximum number of vertex input attributes that /can/ be specified for a
    -- graphics pipeline. These are described in the array of
    -- 'Vulkan.Core10.Pipeline.VertexInputAttributeDescription' structures that
    -- are provided at graphics pipeline creation time via the
    -- @pVertexAttributeDescriptions@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineVertexInputStateCreateInfo' structure.
    -- See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-attrib>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-input>.
    PhysicalDeviceLimits -> Word32
maxVertexInputAttributes :: Word32
  , -- | #limits-maxVertexInputBindings# @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
    -- 'Vulkan.Core10.Pipeline.VertexInputBindingDescription' structures that
    -- are provided at graphics pipeline creation time via the
    -- @pVertexBindingDescriptions@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineVertexInputStateCreateInfo' structure.
    -- The @binding@ member of
    -- 'Vulkan.Core10.Pipeline.VertexInputBindingDescription' /must/ be less
    -- than this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-input>.
    PhysicalDeviceLimits -> Word32
maxVertexInputBindings :: Word32
  , -- | #limits-maxVertexInputAttributeOffset# @maxVertexInputAttributeOffset@
    -- is the maximum vertex input attribute offset that /can/ be added to the
    -- vertex input binding stride. The @offset@ member of the
    -- 'Vulkan.Core10.Pipeline.VertexInputAttributeDescription' structure
    -- /must/ be less than or equal to this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-input>.
    PhysicalDeviceLimits -> Word32
maxVertexInputAttributeOffset :: Word32
  , -- | #limits-maxVertexInputBindingStride# @maxVertexInputBindingStride@ is
    -- the maximum vertex input binding stride that /can/ be specified in a
    -- vertex input binding. The @stride@ member of the
    -- 'Vulkan.Core10.Pipeline.VertexInputBindingDescription' structure /must/
    -- be less than or equal to this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#fxvertex-input>.
    PhysicalDeviceLimits -> Word32
maxVertexInputBindingStride :: Word32
  , -- | #limits-maxVertexOutputComponents# @maxVertexOutputComponents@ is the
    -- maximum number of components of output variables which /can/ be output
    -- by a vertex shader. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#shaders-vertex>.
    PhysicalDeviceLimits -> Word32
maxVertexOutputComponents :: Word32
  , -- | #limits-maxTessellationGenerationLevel# @maxTessellationGenerationLevel@
    -- is the maximum tessellation generation level supported by the
    -- fixed-function tessellation primitive generator. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#tessellation>.
    PhysicalDeviceLimits -> Word32
maxTessellationGenerationLevel :: Word32
  , -- | #limits-maxTessellationPatchSize# @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
    -- 'Vulkan.Core10.Pipeline.PipelineTessellationStateCreateInfo' 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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#tessellation>.
    PhysicalDeviceLimits -> Word32
maxTessellationPatchSize :: Word32
  , -- | #limits-maxTessellationControlPerVertexInputComponents#
    -- @maxTessellationControlPerVertexInputComponents@ is the maximum number
    -- of components of input variables which /can/ be provided as per-vertex
    -- inputs to the tessellation control shader stage.
    PhysicalDeviceLimits -> Word32
maxTessellationControlPerVertexInputComponents :: Word32
  , -- | #limits-maxTessellationControlPerVertexOutputComponents#
    -- @maxTessellationControlPerVertexOutputComponents@ is the maximum number
    -- of components of per-vertex output variables which /can/ be output from
    -- the tessellation control shader stage.
    PhysicalDeviceLimits -> Word32
maxTessellationControlPerVertexOutputComponents :: Word32
  , -- | #limits-maxTessellationControlPerPatchOutputComponents#
    -- @maxTessellationControlPerPatchOutputComponents@ is the maximum number
    -- of components of per-patch output variables which /can/ be output from
    -- the tessellation control shader stage.
    PhysicalDeviceLimits -> Word32
maxTessellationControlPerPatchOutputComponents :: Word32
  , -- | #limits-maxTessellationControlTotalOutputComponents#
    -- @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.
    PhysicalDeviceLimits -> Word32
maxTessellationControlTotalOutputComponents :: Word32
  , -- | #limits-maxTessellationEvaluationInputComponents#
    -- @maxTessellationEvaluationInputComponents@ is the maximum number of
    -- components of input variables which /can/ be provided as per-vertex
    -- inputs to the tessellation evaluation shader stage.
    PhysicalDeviceLimits -> Word32
maxTessellationEvaluationInputComponents :: Word32
  , -- | #limits-maxTessellationEvaluationOutputComponents#
    -- @maxTessellationEvaluationOutputComponents@ is the maximum number of
    -- components of per-vertex output variables which /can/ be output from the
    -- tessellation evaluation shader stage.
    PhysicalDeviceLimits -> Word32
maxTessellationEvaluationOutputComponents :: Word32
  , -- | #limits-maxGeometryShaderInvocations# @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#geometry>.
    PhysicalDeviceLimits -> Word32
maxGeometryShaderInvocations :: Word32
  , -- | #limits-maxGeometryInputComponents# @maxGeometryInputComponents@ is the
    -- maximum number of components of input variables which /can/ be provided
    -- as inputs to the geometry shader stage.
    PhysicalDeviceLimits -> Word32
maxGeometryInputComponents :: Word32
  , -- | #limits-maxGeometryOutputComponents# @maxGeometryOutputComponents@ is
    -- the maximum number of components of output variables which /can/ be
    -- output from the geometry shader stage.
    PhysicalDeviceLimits -> Word32
maxGeometryOutputComponents :: Word32
  , -- | #limits-maxGeometryOutputVertices# @maxGeometryOutputVertices@ is the
    -- maximum number of vertices which /can/ be emitted by any geometry
    -- shader.
    PhysicalDeviceLimits -> Word32
maxGeometryOutputVertices :: Word32
  , -- | #limits-maxGeometryTotalOutputComponents#
    -- @maxGeometryTotalOutputComponents@ is the maximum total number of
    -- components of output variables, across all emitted vertices, which /can/
    -- be output from the geometry shader stage.
    PhysicalDeviceLimits -> Word32
maxGeometryTotalOutputComponents :: Word32
  , -- | #limits-maxFragmentInputComponents# @maxFragmentInputComponents@ is the
    -- maximum number of components of input variables which /can/ be provided
    -- as inputs to the fragment shader stage.
    PhysicalDeviceLimits -> Word32
maxFragmentInputComponents :: Word32
  , -- | #limits-maxFragmentOutputAttachments# @maxFragmentOutputAttachments@ is
    -- the maximum number of output attachments which /can/ be written to by
    -- the fragment shader stage.
    PhysicalDeviceLimits -> Word32
maxFragmentOutputAttachments :: Word32
  , -- | #limits-maxFragmentDualSrcAttachments# @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#framebuffer-dsb>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-dualSrcBlend dualSrcBlend>.
    PhysicalDeviceLimits -> Word32
maxFragmentDualSrcAttachments :: Word32
  , -- | #limits-maxFragmentCombinedOutputResources#
    -- @maxFragmentCombinedOutputResources@ is the total number of storage
    -- buffers, storage images, and output @Location@ decorated color
    -- attachments (described in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#interfaces-fragmentoutput Fragment Output Interface>)
    -- which /can/ be used in the fragment shader stage.
    PhysicalDeviceLimits -> Word32
maxFragmentCombinedOutputResources :: Word32
  , -- | #limits-maxComputeSharedMemorySize# @maxComputeSharedMemorySize@ is the
    -- maximum total storage size, in bytes, available for variables declared
    -- with the @Workgroup@ storage class in shader modules (or with the
    -- @shared@ storage qualifier in GLSL) in the compute shader stage.
    PhysicalDeviceLimits -> Word32
maxComputeSharedMemorySize :: Word32
  , -- | #limits-maxComputeWorkGroupCount# @maxComputeWorkGroupCount@[3] is the
    -- maximum number of local workgroups that /can/ be dispatched by a single
    -- dispatching 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 dispatching commands /must/ be less
    -- than or equal to the corresponding limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#dispatch>.
    PhysicalDeviceLimits -> (Word32, Word32, Word32)
maxComputeWorkGroupCount :: (Word32, Word32, Word32)
  , -- | #limits-maxComputeWorkGroupInvocations# @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@ or @LocalSizeId@ execution mode in shader modules or by
    -- the object decorated by the @WorkgroupSize@ decoration, /must/ be less
    -- than or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxComputeWorkGroupInvocations :: Word32
  , -- | #limits-maxComputeWorkGroupSize# @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, as specified by
    -- the @LocalSize@ or @LocalSizeId@ execution mode or by the object
    -- decorated by the @WorkgroupSize@ decoration in shader modules, /must/ be
    -- less than or equal to the corresponding limit.
    PhysicalDeviceLimits -> (Word32, Word32, Word32)
maxComputeWorkGroupSize :: (Word32, Word32, Word32)
  , -- | #limits-subPixelPrecisionBits# @subPixelPrecisionBits@ is the number of
    -- bits of subpixel precision in framebuffer coordinates xf and yf. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#primsrast>.
    PhysicalDeviceLimits -> Word32
subPixelPrecisionBits :: Word32
  , -- | #limits-subTexelPrecisionBits# @subTexelPrecisionBits@ is the number of
    -- bits of precision in the division along an axis of an image used for
    -- minification and magnification filters. 2@subTexelPrecisionBits@ 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.
    PhysicalDeviceLimits -> Word32
subTexelPrecisionBits :: Word32
  , -- | #limits-mipmapPrecisionBits# @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. 2@mipmapPrecisionBits@ is the actual number of
    -- divisions.
    PhysicalDeviceLimits -> Word32
mipmapPrecisionBits :: Word32
  , -- | #limits-maxDrawIndexedIndexValue# @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-fullDrawIndexUint32 fullDrawIndexUint32>.
    PhysicalDeviceLimits -> Word32
maxDrawIndexedIndexValue :: Word32
  , -- | #limits-maxDrawIndirectCount# @maxDrawIndirectCount@ is the maximum draw
    -- count that is supported for indirect drawing calls. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-multiDrawIndirect multiDrawIndirect>.
    PhysicalDeviceLimits -> Word32
maxDrawIndirectCount :: Word32
  , -- | #limits-maxSamplerLodBias# @maxSamplerLodBias@ is the maximum absolute
    -- sampler LOD bias. The sum of the @mipLodBias@ member of the
    -- 'Vulkan.Core10.Sampler.SamplerCreateInfo' 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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#samplers-mipLodBias>.
    PhysicalDeviceLimits -> Float
maxSamplerLodBias :: Float
  , -- | #limits-maxSamplerAnisotropy# @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 'Vulkan.Core10.Sampler.SamplerCreateInfo'
    -- structure and this limit. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#samplers-maxAnisotropy>.
    PhysicalDeviceLimits -> Float
maxSamplerAnisotropy :: Float
  , -- | #limits-maxViewports# @maxViewports@ is the maximum number of active
    -- viewports. The @viewportCount@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineViewportStateCreateInfo' structure that
    -- is provided at pipeline creation /must/ be less than or equal to this
    -- limit.
    PhysicalDeviceLimits -> Word32
maxViewports :: Word32
  , -- | #limits-maxViewportDimensions# @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#vertexpostproc-viewport Controlling the Viewport>.
    PhysicalDeviceLimits -> (Word32, Word32)
maxViewportDimensions :: (Word32, Word32)
  , -- | #limits-viewportboundsrange# @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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#vertexpostproc-viewport Controlling the Viewport>.
    --
    -- Note
    --
    -- The 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.
    PhysicalDeviceLimits -> (Float, Float)
viewportBoundsRange :: (Float, Float)
  , -- | #limits-viewportSubPixelBits# @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.
    PhysicalDeviceLimits -> Word32
viewportSubPixelBits :: Word32
  , -- | #limits-minMemoryMapAlignment# @minMemoryMapAlignment@ is the minimum
    -- /required/ alignment, in bytes, of host visible memory allocations
    -- within the host address space. When mapping a memory allocation with
    -- 'Vulkan.Core10.Memory.mapMemory', subtracting @offset@ bytes from the
    -- returned pointer will always produce an integer multiple of this limit.
    -- See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-device-hostaccess>.
    -- The value /must/ be a power of two.
    PhysicalDeviceLimits -> DeviceSize
minMemoryMapAlignment :: Word64
  , -- | #limits-minTexelBufferOffsetAlignment# @minTexelBufferOffsetAlignment@
    -- is the minimum /required/ alignment, in bytes, for the @offset@ member
    -- of the 'Vulkan.Core10.BufferView.BufferViewCreateInfo' structure for
    -- texel buffers. The value /must/ be a power of two. If
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-texelBufferAlignment texelBufferAlignment>
    -- is enabled, this limit is equivalent to the maximum of the
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-uniformTexelBufferOffsetAlignmentBytes uniformTexelBufferOffsetAlignmentBytes>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-storageTexelBufferOffsetAlignmentBytes storageTexelBufferOffsetAlignmentBytes>
    -- members of
    -- 'Vulkan.Core13.Promoted_From_VK_EXT_texel_buffer_alignment.PhysicalDeviceTexelBufferAlignmentProperties',
    -- but smaller alignment is /optionally/ allowed by
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-storageTexelBufferOffsetSingleTexelAlignment storageTexelBufferOffsetSingleTexelAlignment>
    -- and
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-uniformTexelBufferOffsetSingleTexelAlignment uniformTexelBufferOffsetSingleTexelAlignment>.
    -- If
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-texelBufferAlignment texelBufferAlignment>
    -- is not enabled,
    -- 'Vulkan.Core10.BufferView.BufferViewCreateInfo'::@offset@ /must/ be a
    -- multiple of this value.
    PhysicalDeviceLimits -> DeviceSize
minTexelBufferOffsetAlignment :: DeviceSize
  , -- | #limits-minUniformBufferOffsetAlignment#
    -- @minUniformBufferOffsetAlignment@ is the minimum /required/ alignment,
    -- in bytes, for the @offset@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorBufferInfo' structure for uniform
    -- buffers. When a descriptor of type
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_UNIFORM_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.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. The value /must/ be a power of two.
    PhysicalDeviceLimits -> DeviceSize
minUniformBufferOffsetAlignment :: DeviceSize
  , -- | #limits-minStorageBufferOffsetAlignment#
    -- @minStorageBufferOffsetAlignment@ is the minimum /required/ alignment,
    -- in bytes, for the @offset@ member of the
    -- 'Vulkan.Core10.DescriptorSet.DescriptorBufferInfo' structure for storage
    -- buffers. When a descriptor of type
    -- 'Vulkan.Core10.Enums.DescriptorType.DESCRIPTOR_TYPE_STORAGE_BUFFER' or
    -- 'Vulkan.Core10.Enums.DescriptorType.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. The value /must/ be a power of two.
    PhysicalDeviceLimits -> DeviceSize
minStorageBufferOffsetAlignment :: DeviceSize
  , -- | #limits-minTexelOffset# @minTexelOffset@ is the minimum offset value for
    -- the @ConstOffset@ image operand of any of the @OpImageSample*@ or
    -- @OpImageFetch*@ image instructions.
    PhysicalDeviceLimits -> Int32
minTexelOffset :: Int32
  , -- | #limits-maxTexelOffset# @maxTexelOffset@ is the maximum offset value for
    -- the @ConstOffset@ image operand of any of the @OpImageSample*@ or
    -- @OpImageFetch*@ image instructions.
    PhysicalDeviceLimits -> Word32
maxTexelOffset :: Word32
  , -- | #limits-minTexelGatherOffset# @minTexelGatherOffset@ is the minimum
    -- offset value for the @Offset@, @ConstOffset@, or @ConstOffsets@ image
    -- operands of any of the @OpImage*Gather@ image instructions.
    PhysicalDeviceLimits -> Int32
minTexelGatherOffset :: Int32
  , -- | #limits-maxTexelGatherOffset# @maxTexelGatherOffset@ is the maximum
    -- offset value for the @Offset@, @ConstOffset@, or @ConstOffsets@ image
    -- operands of any of the @OpImage*Gather@ image instructions.
    PhysicalDeviceLimits -> Word32
maxTexelGatherOffset :: Word32
  , -- | #limits-minInterpolationOffset# @minInterpolationOffset@ is the base
    -- minimum (inclusive) negative offset value for the @Offset@ operand of
    -- the @InterpolateAtOffset@ extended instruction.
    PhysicalDeviceLimits -> Float
minInterpolationOffset :: Float
  , -- | #limits-maxInterpolationOffset# @maxInterpolationOffset@ is the base
    -- maximum (inclusive) positive offset value for the @Offset@ operand of
    -- the @InterpolateAtOffset@ extended instruction.
    PhysicalDeviceLimits -> Float
maxInterpolationOffset :: Float
  , -- | #limits-subPixelInterpolationOffsetBits#
    -- @subPixelInterpolationOffsetBits@ is the number of fractional bits that
    -- the @x@ and @y@ offsets to the @InterpolateAtOffset@ extended
    -- instruction /may/ be rounded to as fixed-point values.
    PhysicalDeviceLimits -> Word32
subPixelInterpolationOffsetBits :: Word32
  , -- | #limits-maxFramebufferWidth# @maxFramebufferWidth@ is the maximum width
    -- for a framebuffer. The @width@ member of the
    -- 'Vulkan.Core10.Pass.FramebufferCreateInfo' structure /must/ be less than
    -- or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxFramebufferWidth :: Word32
  , -- | #limits-maxFramebufferHeight# @maxFramebufferHeight@ is the maximum
    -- height for a framebuffer. The @height@ member of the
    -- 'Vulkan.Core10.Pass.FramebufferCreateInfo' structure /must/ be less than
    -- or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxFramebufferHeight :: Word32
  , -- | #limits-maxFramebufferLayers# @maxFramebufferLayers@ is the maximum
    -- layer count for a layered framebuffer. The @layers@ member of the
    -- 'Vulkan.Core10.Pass.FramebufferCreateInfo' structure /must/ be less than
    -- or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxFramebufferLayers :: Word32
  , -- | #limits-framebufferColorSampleCounts# @framebufferColorSampleCounts@ is
    -- a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the color sample counts that are supported for all framebuffer color
    -- attachments with floating- or fixed-point formats. For color attachments
    -- with integer formats, see
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#limits-framebufferIntegerColorSampleCounts framebufferIntegerColorSampleCounts>.
    PhysicalDeviceLimits -> SampleCountFlags
framebufferColorSampleCounts :: SampleCountFlags
  , -- | #limits-framebufferDepthSampleCounts# @framebufferDepthSampleCounts@ is
    -- a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the supported depth sample counts for all framebuffer depth\/stencil
    -- attachments, when the format includes a depth component.
    PhysicalDeviceLimits -> SampleCountFlags
framebufferDepthSampleCounts :: SampleCountFlags
  , -- | #limits-framebufferStencilSampleCounts# @framebufferStencilSampleCounts@
    -- is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the supported stencil sample counts for all framebuffer depth\/stencil
    -- attachments, when the format includes a stencil component.
    PhysicalDeviceLimits -> SampleCountFlags
framebufferStencilSampleCounts :: SampleCountFlags
  , -- | #limits-framebufferNoAttachmentsSampleCounts#
    -- @framebufferNoAttachmentsSampleCounts@ is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the supported sample counts for a
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#renderpass-noattachments subpass which uses no attachments>.
    PhysicalDeviceLimits -> SampleCountFlags
framebufferNoAttachmentsSampleCounts :: SampleCountFlags
  , -- | #limits-maxColorAttachments# @maxColorAttachments@ is the maximum number
    -- of color attachments that /can/ be used by a subpass in a render pass.
    -- The @colorAttachmentCount@ member of the
    -- 'Vulkan.Core10.Pass.SubpassDescription' or
    -- 'Vulkan.Core12.Promoted_From_VK_KHR_create_renderpass2.SubpassDescription2'
    -- structure /must/ be less than or equal to this limit.
    PhysicalDeviceLimits -> Word32
maxColorAttachments :: Word32
  , -- | #limits-sampledImageColorSampleCounts# @sampledImageColorSampleCounts@
    -- is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the sample counts supported for all 2D images created with
    -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL', @usage@
    -- containing
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_SAMPLED_BIT', and a
    -- non-integer color format.
    PhysicalDeviceLimits -> SampleCountFlags
sampledImageColorSampleCounts :: SampleCountFlags
  , -- | #limits-sampledImageIntegerSampleCounts#
    -- @sampledImageIntegerSampleCounts@ is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the sample counts supported for all 2D images created with
    -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL', @usage@
    -- containing
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_SAMPLED_BIT', and an
    -- integer color format.
    PhysicalDeviceLimits -> SampleCountFlags
sampledImageIntegerSampleCounts :: SampleCountFlags
  , -- | #limits-sampledImageDepthSampleCounts# @sampledImageDepthSampleCounts@
    -- is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the sample counts supported for all 2D images created with
    -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL', @usage@
    -- containing
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_SAMPLED_BIT', and a
    -- depth format.
    PhysicalDeviceLimits -> SampleCountFlags
sampledImageDepthSampleCounts :: SampleCountFlags
  , -- | #limits-sampledImageStencilSampleCounts#
    -- @sampledImageStencilSampleCounts@ is a bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the sample counts supported for all 2D images created with
    -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL', @usage@
    -- containing
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_SAMPLED_BIT', and a
    -- stencil format.
    PhysicalDeviceLimits -> SampleCountFlags
sampledImageStencilSampleCounts :: SampleCountFlags
  , -- | #limits-storageImageSampleCounts# @storageImageSampleCounts@ is a
    -- bitmask1 of
    -- 'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits' indicating
    -- the sample counts supported for all 2D images created with
    -- 'Vulkan.Core10.Enums.ImageTiling.IMAGE_TILING_OPTIMAL', and @usage@
    -- containing
    -- 'Vulkan.Core10.Enums.ImageUsageFlagBits.IMAGE_USAGE_STORAGE_BIT'.
    PhysicalDeviceLimits -> SampleCountFlags
storageImageSampleCounts :: SampleCountFlags
  , -- | #limits-maxSampleMaskWords# @maxSampleMaskWords@ is the maximum number
    -- of array elements of a variable decorated with the
    -- 'Vulkan.Core10.FundamentalTypes.SampleMask' built-in decoration.
    PhysicalDeviceLimits -> Word32
maxSampleMaskWords :: Word32
  , -- | #limits-timestampComputeAndGraphics# @timestampComputeAndGraphics@
    -- specifies support for timestamps on all graphics and compute queues. If
    -- this limit is set to 'Vulkan.Core10.FundamentalTypes.TRUE', all queues
    -- that advertise the
    -- 'Vulkan.Core10.Enums.QueueFlagBits.QUEUE_GRAPHICS_BIT' or
    -- 'Vulkan.Core10.Enums.QueueFlagBits.QUEUE_COMPUTE_BIT' in the
    -- 'QueueFamilyProperties'::@queueFlags@ support
    -- 'QueueFamilyProperties'::@timestampValidBits@ of at least 36. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#queries-timestamps Timestamp Queries>.
    PhysicalDeviceLimits -> Bool
timestampComputeAndGraphics :: Bool
  , -- | #limits-timestampPeriod# @timestampPeriod@ is the number of nanoseconds
    -- /required/ for a timestamp query to be incremented by 1. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#queries-timestamps Timestamp Queries>.
    PhysicalDeviceLimits -> Float
timestampPeriod :: Float
  , -- | #limits-maxClipDistances# @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.
    PhysicalDeviceLimits -> Word32
maxClipDistances :: Word32
  , -- | #limits-maxCullDistances# @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.
    PhysicalDeviceLimits -> Word32
maxCullDistances :: Word32
  , -- | #limits-maxCombinedClipAndCullDistances#
    -- @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.
    PhysicalDeviceLimits -> Word32
maxCombinedClipAndCullDistances :: Word32
  , -- | #limits-discreteQueuePriorities# @discreteQueuePriorities@ is the number
    -- of discrete priorities that /can/ be assigned to a queue based on the
    -- value of each member of
    -- 'Vulkan.Core10.Device.DeviceQueueCreateInfo'::@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
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#devsandqueues-priority>.
    PhysicalDeviceLimits -> Word32
discreteQueuePriorities :: Word32
  , -- | #limits-pointSizeRange# @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.
    PhysicalDeviceLimits -> (Float, Float)
pointSizeRange :: (Float, Float)
  , -- | #limits-lineWidthRange# @lineWidthRange@[2] is the range
    -- [@minimum@,@maximum@] of supported widths for lines. Values specified by
    -- the @lineWidth@ member of the
    -- 'Vulkan.Core10.Pipeline.PipelineRasterizationStateCreateInfo' or the
    -- @lineWidth@ parameter to
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdSetLineWidth' are clamped to
    -- this range.
    PhysicalDeviceLimits -> (Float, Float)
lineWidthRange :: (Float, Float)
  , -- | #limits-pointSizeGranularity# @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.
    PhysicalDeviceLimits -> Float
pointSizeGranularity :: Float
  , -- | #limits-lineWidthGranularity# @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.
    PhysicalDeviceLimits -> Float
lineWidthGranularity :: Float
  , -- | #limits-strictLines# @strictLines@ specifies whether lines are
    -- rasterized according to the preferred method of rasterization. If set to
    -- 'Vulkan.Core10.FundamentalTypes.FALSE', lines /may/ be rasterized under
    -- a relaxed set of rules. If set to 'Vulkan.Core10.FundamentalTypes.TRUE',
    -- lines are rasterized as per the strict definition. See
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#primsrast-lines-basic Basic Line Segment Rasterization>.
    PhysicalDeviceLimits -> Bool
strictLines :: Bool
  , -- | #limits-standardSampleLocations# @standardSampleLocations@ specifies
    -- whether rasterization uses the standard sample locations as documented
    -- in
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#primsrast-multisampling Multisampling>.
    -- If set to 'Vulkan.Core10.FundamentalTypes.TRUE', the implementation uses
    -- the documented sample locations. If set to
    -- 'Vulkan.Core10.FundamentalTypes.FALSE', the implementation /may/ use
    -- different sample locations.
    PhysicalDeviceLimits -> Bool
standardSampleLocations :: Bool
  , -- | #limits-optimalBufferCopyOffsetAlignment#
    -- @optimalBufferCopyOffsetAlignment@ is the optimal buffer offset
    -- alignment in bytes for
    -- 'Vulkan.Core13.Promoted_From_VK_KHR_copy_commands2.cmdCopyBufferToImage2',
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdCopyBufferToImage',
    -- 'Vulkan.Core13.Promoted_From_VK_KHR_copy_commands2.cmdCopyImageToBuffer2',
    -- and 'Vulkan.Core10.CommandBufferBuilding.cmdCopyImageToBuffer'. This
    -- value is also the optimal host memory offset alignment in bytes for
    -- 'Vulkan.Extensions.VK_EXT_host_image_copy.copyMemoryToImageEXT' and
    -- 'Vulkan.Extensions.VK_EXT_host_image_copy.copyImageToMemoryEXT'. The per
    -- texel alignment requirements are enforced, but applications /should/ use
    -- the optimal alignment for optimal performance and power use. The value
    -- /must/ be a power of two.
    PhysicalDeviceLimits -> DeviceSize
optimalBufferCopyOffsetAlignment :: DeviceSize
  , -- | #limits-optimalBufferCopyRowPitchAlignment#
    -- @optimalBufferCopyRowPitchAlignment@ is the optimal buffer row pitch
    -- alignment in bytes for
    -- 'Vulkan.Core13.Promoted_From_VK_KHR_copy_commands2.cmdCopyBufferToImage2',
    -- 'Vulkan.Core10.CommandBufferBuilding.cmdCopyBufferToImage',
    -- 'Vulkan.Core13.Promoted_From_VK_KHR_copy_commands2.cmdCopyImageToBuffer2',
    -- and 'Vulkan.Core10.CommandBufferBuilding.cmdCopyImageToBuffer'. This
    -- value is also the optimal host memory row pitch alignment in bytes for
    -- 'Vulkan.Extensions.VK_EXT_host_image_copy.copyMemoryToImageEXT' and
    -- 'Vulkan.Extensions.VK_EXT_host_image_copy.copyImageToMemoryEXT'. 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. The value /must/ be a
    -- power of two.
    PhysicalDeviceLimits -> DeviceSize
optimalBufferCopyRowPitchAlignment :: DeviceSize
  , -- | #limits-nonCoherentAtomSize# @nonCoherentAtomSize@ is the size and
    -- alignment in bytes that bounds concurrent access to
    -- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#memory-device-hostaccess host-mapped device memory>.
    -- The value /must/ be a power of two.
    --
    -- [1]
    --     For all bitmasks of
    --     'Vulkan.Core10.Enums.SampleCountFlagBits.SampleCountFlagBits', the
    --     sample count limits defined above represent the minimum supported
    --     sample counts for each image type. Individual images /may/ support
    --     additional sample counts, which are queried using
    --     'getPhysicalDeviceImageFormatProperties' as described in
    --     <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#features-supported-sample-counts Supported Sample Counts>.
    PhysicalDeviceLimits -> DeviceSize
nonCoherentAtomSize :: DeviceSize
  }
  deriving (Typeable, PhysicalDeviceLimits -> PhysicalDeviceLimits -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PhysicalDeviceLimits -> PhysicalDeviceLimits -> Bool
$c/= :: PhysicalDeviceLimits -> PhysicalDeviceLimits -> Bool
== :: PhysicalDeviceLimits -> PhysicalDeviceLimits -> Bool
$c== :: PhysicalDeviceLimits -> PhysicalDeviceLimits -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceLimits)
#endif
deriving instance Show PhysicalDeviceLimits

instance ToCStruct PhysicalDeviceLimits where
  withCStruct :: forall b.
PhysicalDeviceLimits -> (Ptr PhysicalDeviceLimits -> IO b) -> IO b
withCStruct PhysicalDeviceLimits
x Ptr PhysicalDeviceLimits -> IO b
f = forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
504 forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceLimits
p -> forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceLimits
p PhysicalDeviceLimits
x (Ptr PhysicalDeviceLimits -> IO b
f Ptr PhysicalDeviceLimits
p)
  pokeCStruct :: forall b.
Ptr PhysicalDeviceLimits -> PhysicalDeviceLimits -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceLimits
p PhysicalDeviceLimits{Bool
Float
Int32
Word32
DeviceSize
(Float, Float)
(Word32, Word32)
(Word32, Word32, Word32)
SampleCountFlags
nonCoherentAtomSize :: DeviceSize
optimalBufferCopyRowPitchAlignment :: DeviceSize
optimalBufferCopyOffsetAlignment :: DeviceSize
standardSampleLocations :: Bool
strictLines :: Bool
lineWidthGranularity :: Float
pointSizeGranularity :: Float
lineWidthRange :: (Float, Float)
pointSizeRange :: (Float, Float)
discreteQueuePriorities :: Word32
maxCombinedClipAndCullDistances :: Word32
maxCullDistances :: Word32
maxClipDistances :: Word32
timestampPeriod :: Float
timestampComputeAndGraphics :: Bool
maxSampleMaskWords :: Word32
storageImageSampleCounts :: SampleCountFlags
sampledImageStencilSampleCounts :: SampleCountFlags
sampledImageDepthSampleCounts :: SampleCountFlags
sampledImageIntegerSampleCounts :: SampleCountFlags
sampledImageColorSampleCounts :: SampleCountFlags
maxColorAttachments :: Word32
framebufferNoAttachmentsSampleCounts :: SampleCountFlags
framebufferStencilSampleCounts :: SampleCountFlags
framebufferDepthSampleCounts :: SampleCountFlags
framebufferColorSampleCounts :: SampleCountFlags
maxFramebufferLayers :: Word32
maxFramebufferHeight :: Word32
maxFramebufferWidth :: Word32
subPixelInterpolationOffsetBits :: Word32
maxInterpolationOffset :: Float
minInterpolationOffset :: Float
maxTexelGatherOffset :: Word32
minTexelGatherOffset :: Int32
maxTexelOffset :: Word32
minTexelOffset :: Int32
minStorageBufferOffsetAlignment :: DeviceSize
minUniformBufferOffsetAlignment :: DeviceSize
minTexelBufferOffsetAlignment :: DeviceSize
minMemoryMapAlignment :: DeviceSize
viewportSubPixelBits :: Word32
viewportBoundsRange :: (Float, Float)
maxViewportDimensions :: (Word32, Word32)
maxViewports :: Word32
maxSamplerAnisotropy :: Float
maxSamplerLodBias :: Float
maxDrawIndirectCount :: Word32
maxDrawIndexedIndexValue :: Word32
mipmapPrecisionBits :: Word32
subTexelPrecisionBits :: Word32
subPixelPrecisionBits :: Word32
maxComputeWorkGroupSize :: (Word32, Word32, Word32)
maxComputeWorkGroupInvocations :: Word32
maxComputeWorkGroupCount :: (Word32, Word32, Word32)
maxComputeSharedMemorySize :: Word32
maxFragmentCombinedOutputResources :: Word32
maxFragmentDualSrcAttachments :: Word32
maxFragmentOutputAttachments :: Word32
maxFragmentInputComponents :: Word32
maxGeometryTotalOutputComponents :: Word32
maxGeometryOutputVertices :: Word32
maxGeometryOutputComponents :: Word32
maxGeometryInputComponents :: Word32
maxGeometryShaderInvocations :: Word32
maxTessellationEvaluationOutputComponents :: Word32
maxTessellationEvaluationInputComponents :: Word32
maxTessellationControlTotalOutputComponents :: Word32
maxTessellationControlPerPatchOutputComponents :: Word32
maxTessellationControlPerVertexOutputComponents :: Word32
maxTessellationControlPerVertexInputComponents :: Word32
maxTessellationPatchSize :: Word32
maxTessellationGenerationLevel :: Word32
maxVertexOutputComponents :: Word32
maxVertexInputBindingStride :: Word32
maxVertexInputAttributeOffset :: Word32
maxVertexInputBindings :: Word32
maxVertexInputAttributes :: Word32
maxDescriptorSetInputAttachments :: Word32
maxDescriptorSetStorageImages :: Word32
maxDescriptorSetSampledImages :: Word32
maxDescriptorSetStorageBuffersDynamic :: Word32
maxDescriptorSetStorageBuffers :: Word32
maxDescriptorSetUniformBuffersDynamic :: Word32
maxDescriptorSetUniformBuffers :: Word32
maxDescriptorSetSamplers :: Word32
maxPerStageResources :: Word32
maxPerStageDescriptorInputAttachments :: Word32
maxPerStageDescriptorStorageImages :: Word32
maxPerStageDescriptorSampledImages :: Word32
maxPerStageDescriptorStorageBuffers :: Word32
maxPerStageDescriptorUniformBuffers :: Word32
maxPerStageDescriptorSamplers :: Word32
maxBoundDescriptorSets :: Word32
sparseAddressSpaceSize :: DeviceSize
bufferImageGranularity :: DeviceSize
maxSamplerAllocationCount :: Word32
maxMemoryAllocationCount :: Word32
maxPushConstantsSize :: Word32
maxStorageBufferRange :: Word32
maxUniformBufferRange :: Word32
maxTexelBufferElements :: Word32
maxImageArrayLayers :: Word32
maxImageDimensionCube :: Word32
maxImageDimension3D :: Word32
maxImageDimension2D :: Word32
maxImageDimension1D :: Word32
$sel:nonCoherentAtomSize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:optimalBufferCopyRowPitchAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:optimalBufferCopyOffsetAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:standardSampleLocations:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Bool
$sel:strictLines:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Bool
$sel:lineWidthGranularity:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:pointSizeGranularity:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:lineWidthRange:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Float, Float)
$sel:pointSizeRange:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Float, Float)
$sel:discreteQueuePriorities:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxCombinedClipAndCullDistances:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxCullDistances:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxClipDistances:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:timestampPeriod:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:timestampComputeAndGraphics:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Bool
$sel:maxSampleMaskWords:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:storageImageSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:sampledImageStencilSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:sampledImageDepthSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:sampledImageIntegerSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:sampledImageColorSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:maxColorAttachments:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:framebufferNoAttachmentsSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:framebufferStencilSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:framebufferDepthSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:framebufferColorSampleCounts:PhysicalDeviceLimits :: PhysicalDeviceLimits -> SampleCountFlags
$sel:maxFramebufferLayers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFramebufferHeight:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFramebufferWidth:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:subPixelInterpolationOffsetBits:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxInterpolationOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:minInterpolationOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:maxTexelGatherOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:minTexelGatherOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Int32
$sel:maxTexelOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:minTexelOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Int32
$sel:minStorageBufferOffsetAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:minUniformBufferOffsetAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:minTexelBufferOffsetAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:minMemoryMapAlignment:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:viewportSubPixelBits:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:viewportBoundsRange:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Float, Float)
$sel:maxViewportDimensions:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Word32, Word32)
$sel:maxViewports:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxSamplerAnisotropy:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:maxSamplerLodBias:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Float
$sel:maxDrawIndirectCount:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDrawIndexedIndexValue:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:mipmapPrecisionBits:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:subTexelPrecisionBits:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:subPixelPrecisionBits:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxComputeWorkGroupSize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Word32, Word32, Word32)
$sel:maxComputeWorkGroupInvocations:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxComputeWorkGroupCount:PhysicalDeviceLimits :: PhysicalDeviceLimits -> (Word32, Word32, Word32)
$sel:maxComputeSharedMemorySize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFragmentCombinedOutputResources:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFragmentDualSrcAttachments:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFragmentOutputAttachments:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxFragmentInputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxGeometryTotalOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxGeometryOutputVertices:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxGeometryOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxGeometryInputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxGeometryShaderInvocations:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationEvaluationOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationEvaluationInputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationControlTotalOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationControlPerPatchOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationControlPerVertexOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationControlPerVertexInputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationPatchSize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTessellationGenerationLevel:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxVertexOutputComponents:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxVertexInputBindingStride:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxVertexInputAttributeOffset:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxVertexInputBindings:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxVertexInputAttributes:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetInputAttachments:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetStorageImages:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetSampledImages:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetStorageBuffersDynamic:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetStorageBuffers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetUniformBuffersDynamic:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetUniformBuffers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxDescriptorSetSamplers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageResources:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorInputAttachments:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorStorageImages:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorSampledImages:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorStorageBuffers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorUniformBuffers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPerStageDescriptorSamplers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxBoundDescriptorSets:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:sparseAddressSpaceSize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:bufferImageGranularity:PhysicalDeviceLimits :: PhysicalDeviceLimits -> DeviceSize
$sel:maxSamplerAllocationCount:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxMemoryAllocationCount:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxPushConstantsSize:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxStorageBufferRange:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxUniformBufferRange:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxTexelBufferElements:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxImageArrayLayers:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxImageDimensionCube:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxImageDimension3D:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxImageDimension2D:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
$sel:maxImageDimension1D:PhysicalDeviceLimits :: PhysicalDeviceLimits -> Word32
..} IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (Word32
maxImageDimension1D)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (Word32
maxImageDimension2D)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (Word32
maxImageDimension3D)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (Word32
maxImageDimensionCube)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (Word32
maxImageArrayLayers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Word32)) (Word32
maxTexelBufferElements)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (Word32
maxUniformBufferRange)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (Word32
maxStorageBufferRange)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32)) (Word32
maxPushConstantsSize)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32)) (Word32
maxMemoryAllocationCount)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32)) (Word32
maxSamplerAllocationCount)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr DeviceSize)) (DeviceSize
bufferImageGranularity)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr DeviceSize)) (DeviceSize
sparseAddressSpaceSize)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Word32)) (Word32
maxBoundDescriptorSets)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Word32)) (Word32
maxPerStageDescriptorSamplers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Word32)) (Word32
maxPerStageDescriptorUniformBuffers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Word32)) (Word32
maxPerStageDescriptorStorageBuffers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Word32)) (Word32
maxPerStageDescriptorSampledImages)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Word32)) (Word32
maxPerStageDescriptorStorageImages)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Word32)) (Word32
maxPerStageDescriptorInputAttachments)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Word32)) (Word32
maxPerStageResources)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Word32)) (Word32
maxDescriptorSetSamplers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Word32)) (Word32
maxDescriptorSetUniformBuffers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Word32)) (Word32
maxDescriptorSetUniformBuffersDynamic)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Word32)) (Word32
maxDescriptorSetStorageBuffers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Word32)) (Word32
maxDescriptorSetStorageBuffersDynamic)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Word32)) (Word32
maxDescriptorSetSampledImages)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Word32)) (Word32
maxDescriptorSetStorageImages)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Word32)) (Word32
maxDescriptorSetInputAttachments)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Word32)) (Word32
maxVertexInputAttributes)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Word32)) (Word32
maxVertexInputBindings)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Word32)) (Word32
maxVertexInputAttributeOffset)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Word32)) (Word32
maxVertexInputBindingStride)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Word32)) (Word32
maxVertexOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Word32)) (Word32
maxTessellationGenerationLevel)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Word32)) (Word32
maxTessellationPatchSize)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Word32)) (Word32
maxTessellationControlPerVertexInputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Word32)) (Word32
maxTessellationControlPerVertexOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Word32)) (Word32
maxTessellationControlPerPatchOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Word32)) (Word32
maxTessellationControlTotalOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Word32)) (Word32
maxTessellationEvaluationInputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Word32)) (Word32
maxTessellationEvaluationOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Word32)) (Word32
maxGeometryShaderInvocations)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Word32)) (Word32
maxGeometryInputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Word32)) (Word32
maxGeometryOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Word32)) (Word32
maxGeometryOutputVertices)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Word32)) (Word32
maxGeometryTotalOutputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Word32)) (Word32
maxFragmentInputComponents)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Word32)) (Word32
maxFragmentOutputAttachments)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Word32)) (Word32
maxFragmentDualSrcAttachments)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Word32)) (Word32
maxFragmentCombinedOutputResources)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Word32)) (Word32
maxComputeSharedMemorySize)
    let pMaxComputeWorkGroupCount' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
220 :: Ptr (FixedArray 3 Word32)))
    case ((Word32, Word32, Word32)
maxComputeWorkGroupCount) of
      (Word32
e0, Word32
e1, Word32
e2) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32) (Word32
e2)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
232 :: Ptr Word32)) (Word32
maxComputeWorkGroupInvocations)
    let pMaxComputeWorkGroupSize' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
236 :: Ptr (FixedArray 3 Word32)))
    case ((Word32, Word32, Word32)
maxComputeWorkGroupSize) of
      (Word32
e0, Word32
e1, Word32
e2) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32) (Word32
e2)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
248 :: Ptr Word32)) (Word32
subPixelPrecisionBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
252 :: Ptr Word32)) (Word32
subTexelPrecisionBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
256 :: Ptr Word32)) (Word32
mipmapPrecisionBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32)) (Word32
maxDrawIndexedIndexValue)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
264 :: Ptr Word32)) (Word32
maxDrawIndirectCount)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
268 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
maxSamplerLodBias))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
272 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
maxSamplerAnisotropy))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr Word32)) (Word32
maxViewports)
    let pMaxViewportDimensions' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
280 :: Ptr (FixedArray 2 Word32)))
    case ((Word32, Word32)
maxViewportDimensions) of
      (Word32
e0, Word32
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
    let pViewportBoundsRange' :: Ptr CFloat
pViewportBoundsRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
288 :: Ptr (FixedArray 2 CFloat)))
    case ((Float, Float)
viewportBoundsRange) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pViewportBoundsRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pViewportBoundsRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr Word32)) (Word32
viewportSubPixelBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
304 :: Ptr CSize)) (DeviceSize -> CSize
CSize (DeviceSize
minMemoryMapAlignment))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
312 :: Ptr DeviceSize)) (DeviceSize
minTexelBufferOffsetAlignment)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
320 :: Ptr DeviceSize)) (DeviceSize
minUniformBufferOffsetAlignment)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
328 :: Ptr DeviceSize)) (DeviceSize
minStorageBufferOffsetAlignment)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
336 :: Ptr Int32)) (Int32
minTexelOffset)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
340 :: Ptr Word32)) (Word32
maxTexelOffset)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
344 :: Ptr Int32)) (Int32
minTexelGatherOffset)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
348 :: Ptr Word32)) (Word32
maxTexelGatherOffset)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
352 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
minInterpolationOffset))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
356 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
maxInterpolationOffset))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
360 :: Ptr Word32)) (Word32
subPixelInterpolationOffsetBits)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
364 :: Ptr Word32)) (Word32
maxFramebufferWidth)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
368 :: Ptr Word32)) (Word32
maxFramebufferHeight)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
372 :: Ptr Word32)) (Word32
maxFramebufferLayers)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
376 :: Ptr SampleCountFlags)) (SampleCountFlags
framebufferColorSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
380 :: Ptr SampleCountFlags)) (SampleCountFlags
framebufferDepthSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
384 :: Ptr SampleCountFlags)) (SampleCountFlags
framebufferStencilSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
388 :: Ptr SampleCountFlags)) (SampleCountFlags
framebufferNoAttachmentsSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
392 :: Ptr Word32)) (Word32
maxColorAttachments)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
396 :: Ptr SampleCountFlags)) (SampleCountFlags
sampledImageColorSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
400 :: Ptr SampleCountFlags)) (SampleCountFlags
sampledImageIntegerSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
404 :: Ptr SampleCountFlags)) (SampleCountFlags
sampledImageDepthSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
408 :: Ptr SampleCountFlags)) (SampleCountFlags
sampledImageStencilSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
412 :: Ptr SampleCountFlags)) (SampleCountFlags
storageImageSampleCounts)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
416 :: Ptr Word32)) (Word32
maxSampleMaskWords)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
420 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
timestampComputeAndGraphics))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
424 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
timestampPeriod))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
428 :: Ptr Word32)) (Word32
maxClipDistances)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
432 :: Ptr Word32)) (Word32
maxCullDistances)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
436 :: Ptr Word32)) (Word32
maxCombinedClipAndCullDistances)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
440 :: Ptr Word32)) (Word32
discreteQueuePriorities)
    let pPointSizeRange' :: Ptr CFloat
pPointSizeRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
444 :: Ptr (FixedArray 2 CFloat)))
    case ((Float, Float)
pointSizeRange) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pPointSizeRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pPointSizeRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    let pLineWidthRange' :: Ptr CFloat
pLineWidthRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
452 :: Ptr (FixedArray 2 CFloat)))
    case ((Float, Float)
lineWidthRange) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pLineWidthRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pLineWidthRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
460 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
pointSizeGranularity))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
464 :: Ptr CFloat)) (Float -> CFloat
CFloat (Float
lineWidthGranularity))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
468 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
strictLines))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
472 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
standardSampleLocations))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
480 :: Ptr DeviceSize)) (DeviceSize
optimalBufferCopyOffsetAlignment)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
488 :: Ptr DeviceSize)) (DeviceSize
optimalBufferCopyRowPitchAlignment)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
496 :: Ptr DeviceSize)) (DeviceSize
nonCoherentAtomSize)
    IO b
f
  cStructSize :: Int
cStructSize = Int
504
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b. Ptr PhysicalDeviceLimits -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceLimits
p IO b
f = do
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Word32)) (forall a. Zero a => a
zero)
    let pMaxComputeWorkGroupCount' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
220 :: Ptr (FixedArray 3 Word32)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Word32
e0, Word32
e1, Word32
e2) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupCount' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32) (Word32
e2)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
232 :: Ptr Word32)) (forall a. Zero a => a
zero)
    let pMaxComputeWorkGroupSize' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
236 :: Ptr (FixedArray 3 Word32)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Word32
e0, Word32
e1, Word32
e2) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxComputeWorkGroupSize' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32) (Word32
e2)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
248 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
252 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
256 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
264 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
268 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
272 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr Word32)) (forall a. Zero a => a
zero)
    let pMaxViewportDimensions' :: "pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
280 :: Ptr (FixedArray 2 Word32)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Word32
e0, Word32
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' :: Ptr Word32) (Word32
e0)
        forall a. Storable a => Ptr a -> a -> IO ()
poke ("pPhysicalDeviceCount" ::: Ptr Word32
pMaxViewportDimensions' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32) (Word32
e1)
    let pViewportBoundsRange' :: Ptr CFloat
pViewportBoundsRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
288 :: Ptr (FixedArray 2 CFloat)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pViewportBoundsRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pViewportBoundsRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
304 :: Ptr CSize)) (DeviceSize -> CSize
CSize (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
312 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
320 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
328 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
336 :: Ptr Int32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
340 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
344 :: Ptr Int32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
348 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
352 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
356 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
360 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
364 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
368 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
372 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
392 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
416 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
420 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
424 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
428 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
432 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
436 :: Ptr Word32)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
440 :: Ptr Word32)) (forall a. Zero a => a
zero)
    let pPointSizeRange' :: Ptr CFloat
pPointSizeRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
444 :: Ptr (FixedArray 2 CFloat)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pPointSizeRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pPointSizeRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    let pLineWidthRange' :: Ptr CFloat
pLineWidthRange' = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
452 :: Ptr (FixedArray 2 CFloat)))
    case ((forall a. Zero a => a
zero, forall a. Zero a => a
zero)) of
      (Float
e0, Float
e1) -> do
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pLineWidthRange' :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e0))
        forall a. Storable a => Ptr a -> a -> IO ()
poke (Ptr CFloat
pLineWidthRange' forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr CFloat) (Float -> CFloat
CFloat (Float
e1))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
460 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
464 :: Ptr CFloat)) (Float -> CFloat
CFloat (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
468 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
472 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (forall a. Zero a => a
zero))
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
480 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
488 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
496 :: Ptr DeviceSize)) (forall a. Zero a => a
zero)
    IO b
f

instance FromCStruct PhysicalDeviceLimits where
  peekCStruct :: Ptr PhysicalDeviceLimits -> IO PhysicalDeviceLimits
peekCStruct Ptr PhysicalDeviceLimits
p = do
    Word32
maxImageDimension1D <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr Word32))
    Word32
maxImageDimension2D <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
4 :: Ptr Word32))
    Word32
maxImageDimension3D <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr Word32))
    Word32
maxImageDimensionCube <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
12 :: Ptr Word32))
    Word32
maxImageArrayLayers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Word32))
    Word32
maxTexelBufferElements <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
20 :: Ptr Word32))
    Word32
maxUniformBufferRange <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
24 :: Ptr Word32))
    Word32
maxStorageBufferRange <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
28 :: Ptr Word32))
    Word32
maxPushConstantsSize <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
32 :: Ptr Word32))
    Word32
maxMemoryAllocationCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
36 :: Ptr Word32))
    Word32
maxSamplerAllocationCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
40 :: Ptr Word32))
    DeviceSize
bufferImageGranularity <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
48 :: Ptr DeviceSize))
    DeviceSize
sparseAddressSpaceSize <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
56 :: Ptr DeviceSize))
    Word32
maxBoundDescriptorSets <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
64 :: Ptr Word32))
    Word32
maxPerStageDescriptorSamplers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
68 :: Ptr Word32))
    Word32
maxPerStageDescriptorUniformBuffers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
72 :: Ptr Word32))
    Word32
maxPerStageDescriptorStorageBuffers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
76 :: Ptr Word32))
    Word32
maxPerStageDescriptorSampledImages <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
80 :: Ptr Word32))
    Word32
maxPerStageDescriptorStorageImages <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
84 :: Ptr Word32))
    Word32
maxPerStageDescriptorInputAttachments <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
88 :: Ptr Word32))
    Word32
maxPerStageResources <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
92 :: Ptr Word32))
    Word32
maxDescriptorSetSamplers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
96 :: Ptr Word32))
    Word32
maxDescriptorSetUniformBuffers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
100 :: Ptr Word32))
    Word32
maxDescriptorSetUniformBuffersDynamic <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
104 :: Ptr Word32))
    Word32
maxDescriptorSetStorageBuffers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
108 :: Ptr Word32))
    Word32
maxDescriptorSetStorageBuffersDynamic <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
112 :: Ptr Word32))
    Word32
maxDescriptorSetSampledImages <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
116 :: Ptr Word32))
    Word32
maxDescriptorSetStorageImages <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
120 :: Ptr Word32))
    Word32
maxDescriptorSetInputAttachments <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
124 :: Ptr Word32))
    Word32
maxVertexInputAttributes <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
128 :: Ptr Word32))
    Word32
maxVertexInputBindings <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
132 :: Ptr Word32))
    Word32
maxVertexInputAttributeOffset <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
136 :: Ptr Word32))
    Word32
maxVertexInputBindingStride <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
140 :: Ptr Word32))
    Word32
maxVertexOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
144 :: Ptr Word32))
    Word32
maxTessellationGenerationLevel <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
148 :: Ptr Word32))
    Word32
maxTessellationPatchSize <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
152 :: Ptr Word32))
    Word32
maxTessellationControlPerVertexInputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
156 :: Ptr Word32))
    Word32
maxTessellationControlPerVertexOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
160 :: Ptr Word32))
    Word32
maxTessellationControlPerPatchOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
164 :: Ptr Word32))
    Word32
maxTessellationControlTotalOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
168 :: Ptr Word32))
    Word32
maxTessellationEvaluationInputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
172 :: Ptr Word32))
    Word32
maxTessellationEvaluationOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
176 :: Ptr Word32))
    Word32
maxGeometryShaderInvocations <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
180 :: Ptr Word32))
    Word32
maxGeometryInputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
184 :: Ptr Word32))
    Word32
maxGeometryOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
188 :: Ptr Word32))
    Word32
maxGeometryOutputVertices <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
192 :: Ptr Word32))
    Word32
maxGeometryTotalOutputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
196 :: Ptr Word32))
    Word32
maxFragmentInputComponents <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
200 :: Ptr Word32))
    Word32
maxFragmentOutputAttachments <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
204 :: Ptr Word32))
    Word32
maxFragmentDualSrcAttachments <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
208 :: Ptr Word32))
    Word32
maxFragmentCombinedOutputResources <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
212 :: Ptr Word32))
    Word32
maxComputeSharedMemorySize <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
216 :: Ptr Word32))
    let pmaxComputeWorkGroupCount :: "pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupCount = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
220 :: Ptr (FixedArray 3 Word32)))
    Word32
maxComputeWorkGroupCount0 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupCount forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr Word32))
    Word32
maxComputeWorkGroupCount1 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupCount forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr Word32))
    Word32
maxComputeWorkGroupCount2 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupCount forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
8 :: Ptr Word32))
    Word32
maxComputeWorkGroupInvocations <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
232 :: Ptr Word32))
    let pmaxComputeWorkGroupSize :: "pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupSize = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
236 :: Ptr (FixedArray 3 Word32)))
    Word32
maxComputeWorkGroupSize0 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupSize forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr Word32))
    Word32
maxComputeWorkGroupSize1 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupSize forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr Word32))
    Word32
maxComputeWorkGroupSize2 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxComputeWorkGroupSize forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
8 :: Ptr Word32))
    Word32
subPixelPrecisionBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
248 :: Ptr Word32))
    Word32
subTexelPrecisionBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
252 :: Ptr Word32))
    Word32
mipmapPrecisionBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
256 :: Ptr Word32))
    Word32
maxDrawIndexedIndexValue <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
260 :: Ptr Word32))
    Word32
maxDrawIndirectCount <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
264 :: Ptr Word32))
    CFloat
maxSamplerLodBias <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
268 :: Ptr CFloat))
    CFloat
maxSamplerAnisotropy <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
272 :: Ptr CFloat))
    Word32
maxViewports <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
276 :: Ptr Word32))
    let pmaxViewportDimensions :: "pPhysicalDeviceCount" ::: Ptr Word32
pmaxViewportDimensions = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
280 :: Ptr (FixedArray 2 Word32)))
    Word32
maxViewportDimensions0 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxViewportDimensions forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr Word32))
    Word32
maxViewportDimensions1 <- forall a. Storable a => Ptr a -> IO a
peek @Word32 (("pPhysicalDeviceCount" ::: Ptr Word32
pmaxViewportDimensions forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr Word32))
    let pviewportBoundsRange :: Ptr CFloat
pviewportBoundsRange = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
288 :: Ptr (FixedArray 2 CFloat)))
    CFloat
viewportBoundsRange0 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
pviewportBoundsRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr CFloat))
    CFloat
viewportBoundsRange1 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
pviewportBoundsRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr CFloat))
    Word32
viewportSubPixelBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
296 :: Ptr Word32))
    CSize
minMemoryMapAlignment <- forall a. Storable a => Ptr a -> IO a
peek @CSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
304 :: Ptr CSize))
    DeviceSize
minTexelBufferOffsetAlignment <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
312 :: Ptr DeviceSize))
    DeviceSize
minUniformBufferOffsetAlignment <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
320 :: Ptr DeviceSize))
    DeviceSize
minStorageBufferOffsetAlignment <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
328 :: Ptr DeviceSize))
    Int32
minTexelOffset <- forall a. Storable a => Ptr a -> IO a
peek @Int32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
336 :: Ptr Int32))
    Word32
maxTexelOffset <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
340 :: Ptr Word32))
    Int32
minTexelGatherOffset <- forall a. Storable a => Ptr a -> IO a
peek @Int32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
344 :: Ptr Int32))
    Word32
maxTexelGatherOffset <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
348 :: Ptr Word32))
    CFloat
minInterpolationOffset <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
352 :: Ptr CFloat))
    CFloat
maxInterpolationOffset <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
356 :: Ptr CFloat))
    Word32
subPixelInterpolationOffsetBits <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
360 :: Ptr Word32))
    Word32
maxFramebufferWidth <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
364 :: Ptr Word32))
    Word32
maxFramebufferHeight <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
368 :: Ptr Word32))
    Word32
maxFramebufferLayers <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
372 :: Ptr Word32))
    SampleCountFlags
framebufferColorSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
376 :: Ptr SampleCountFlags))
    SampleCountFlags
framebufferDepthSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
380 :: Ptr SampleCountFlags))
    SampleCountFlags
framebufferStencilSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
384 :: Ptr SampleCountFlags))
    SampleCountFlags
framebufferNoAttachmentsSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
388 :: Ptr SampleCountFlags))
    Word32
maxColorAttachments <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
392 :: Ptr Word32))
    SampleCountFlags
sampledImageColorSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
396 :: Ptr SampleCountFlags))
    SampleCountFlags
sampledImageIntegerSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
400 :: Ptr SampleCountFlags))
    SampleCountFlags
sampledImageDepthSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
404 :: Ptr SampleCountFlags))
    SampleCountFlags
sampledImageStencilSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
408 :: Ptr SampleCountFlags))
    SampleCountFlags
storageImageSampleCounts <- forall a. Storable a => Ptr a -> IO a
peek @SampleCountFlags ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
412 :: Ptr SampleCountFlags))
    Word32
maxSampleMaskWords <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
416 :: Ptr Word32))
    Bool32
timestampComputeAndGraphics <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
420 :: Ptr Bool32))
    CFloat
timestampPeriod <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
424 :: Ptr CFloat))
    Word32
maxClipDistances <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
428 :: Ptr Word32))
    Word32
maxCullDistances <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
432 :: Ptr Word32))
    Word32
maxCombinedClipAndCullDistances <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
436 :: Ptr Word32))
    Word32
discreteQueuePriorities <- forall a. Storable a => Ptr a -> IO a
peek @Word32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
440 :: Ptr Word32))
    let ppointSizeRange :: Ptr CFloat
ppointSizeRange = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
444 :: Ptr (FixedArray 2 CFloat)))
    CFloat
pointSizeRange0 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
ppointSizeRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr CFloat))
    CFloat
pointSizeRange1 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
ppointSizeRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr CFloat))
    let plineWidthRange :: Ptr CFloat
plineWidthRange = forall a (n :: Nat). Ptr (FixedArray n a) -> Ptr a
lowerArrayPtr @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
452 :: Ptr (FixedArray 2 CFloat)))
    CFloat
lineWidthRange0 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
plineWidthRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
0 :: Ptr CFloat))
    CFloat
lineWidthRange1 <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr CFloat
plineWidthRange forall a. Ptr a -> Int -> Ptr a
`advancePtrBytes` Int
4 :: Ptr CFloat))
    CFloat
pointSizeGranularity <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
460 :: Ptr CFloat))
    CFloat
lineWidthGranularity <- forall a. Storable a => Ptr a -> IO a
peek @CFloat ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
464 :: Ptr CFloat))
    Bool32
strictLines <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
468 :: Ptr Bool32))
    Bool32
standardSampleLocations <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
472 :: Ptr Bool32))
    DeviceSize
optimalBufferCopyOffsetAlignment <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
480 :: Ptr DeviceSize))
    DeviceSize
optimalBufferCopyRowPitchAlignment <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
488 :: Ptr DeviceSize))
    DeviceSize
nonCoherentAtomSize <- forall a. Storable a => Ptr a -> IO a
peek @DeviceSize ((Ptr PhysicalDeviceLimits
p forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
496 :: Ptr DeviceSize))
    forall (f :: * -> *) a. Applicative f => a -> f a
pure forall a b. (a -> b) -> a -> b
$ Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> DeviceSize
-> DeviceSize
-> 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
-> (Word32, Word32, Word32)
-> Word32
-> (Word32, Word32, Word32)
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Float
-> Float
-> Word32
-> (Word32, Word32)
-> (Float, Float)
-> Word32
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> Int32
-> Word32
-> Int32
-> Word32
-> Float
-> Float
-> Word32
-> Word32
-> Word32
-> Word32
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> Word32
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> Word32
-> Bool
-> Float
-> Word32
-> Word32
-> Word32
-> Word32
-> (Float, Float)
-> (Float, Float)
-> Float
-> Float
-> Bool
-> Bool
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> PhysicalDeviceLimits
PhysicalDeviceLimits
             Word32
maxImageDimension1D
             Word32
maxImageDimension2D
             Word32
maxImageDimension3D
             Word32
maxImageDimensionCube
             Word32
maxImageArrayLayers
             Word32
maxTexelBufferElements
             Word32
maxUniformBufferRange
             Word32
maxStorageBufferRange
             Word32
maxPushConstantsSize
             Word32
maxMemoryAllocationCount
             Word32
maxSamplerAllocationCount
             DeviceSize
bufferImageGranularity
             DeviceSize
sparseAddressSpaceSize
             Word32
maxBoundDescriptorSets
             Word32
maxPerStageDescriptorSamplers
             Word32
maxPerStageDescriptorUniformBuffers
             Word32
maxPerStageDescriptorStorageBuffers
             Word32
maxPerStageDescriptorSampledImages
             Word32
maxPerStageDescriptorStorageImages
             Word32
maxPerStageDescriptorInputAttachments
             Word32
maxPerStageResources
             Word32
maxDescriptorSetSamplers
             Word32
maxDescriptorSetUniformBuffers
             Word32
maxDescriptorSetUniformBuffersDynamic
             Word32
maxDescriptorSetStorageBuffers
             Word32
maxDescriptorSetStorageBuffersDynamic
             Word32
maxDescriptorSetSampledImages
             Word32
maxDescriptorSetStorageImages
             Word32
maxDescriptorSetInputAttachments
             Word32
maxVertexInputAttributes
             Word32
maxVertexInputBindings
             Word32
maxVertexInputAttributeOffset
             Word32
maxVertexInputBindingStride
             Word32
maxVertexOutputComponents
             Word32
maxTessellationGenerationLevel
             Word32
maxTessellationPatchSize
             Word32
maxTessellationControlPerVertexInputComponents
             Word32
maxTessellationControlPerVertexOutputComponents
             Word32
maxTessellationControlPerPatchOutputComponents
             Word32
maxTessellationControlTotalOutputComponents
             Word32
maxTessellationEvaluationInputComponents
             Word32
maxTessellationEvaluationOutputComponents
             Word32
maxGeometryShaderInvocations
             Word32
maxGeometryInputComponents
             Word32
maxGeometryOutputComponents
             Word32
maxGeometryOutputVertices
             Word32
maxGeometryTotalOutputComponents
             Word32
maxFragmentInputComponents
             Word32
maxFragmentOutputAttachments
             Word32
maxFragmentDualSrcAttachments
             Word32
maxFragmentCombinedOutputResources
             Word32
maxComputeSharedMemorySize
             (( Word32
maxComputeWorkGroupCount0
              , Word32
maxComputeWorkGroupCount1
              , Word32
maxComputeWorkGroupCount2 ))
             Word32
maxComputeWorkGroupInvocations
             (( Word32
maxComputeWorkGroupSize0
              , Word32
maxComputeWorkGroupSize1
              , Word32
maxComputeWorkGroupSize2 ))
             Word32
subPixelPrecisionBits
             Word32
subTexelPrecisionBits
             Word32
mipmapPrecisionBits
             Word32
maxDrawIndexedIndexValue
             Word32
maxDrawIndirectCount
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
maxSamplerLodBias)
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
maxSamplerAnisotropy)
             Word32
maxViewports
             ((Word32
maxViewportDimensions0, Word32
maxViewportDimensions1))
             (( (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
viewportBoundsRange0)
              , (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
viewportBoundsRange1) ))
             Word32
viewportSubPixelBits
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CSize @Word64 CSize
minMemoryMapAlignment)
             DeviceSize
minTexelBufferOffsetAlignment
             DeviceSize
minUniformBufferOffsetAlignment
             DeviceSize
minStorageBufferOffsetAlignment
             Int32
minTexelOffset
             Word32
maxTexelOffset
             Int32
minTexelGatherOffset
             Word32
maxTexelGatherOffset
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
minInterpolationOffset)
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
maxInterpolationOffset)
             Word32
subPixelInterpolationOffsetBits
             Word32
maxFramebufferWidth
             Word32
maxFramebufferHeight
             Word32
maxFramebufferLayers
             SampleCountFlags
framebufferColorSampleCounts
             SampleCountFlags
framebufferDepthSampleCounts
             SampleCountFlags
framebufferStencilSampleCounts
             SampleCountFlags
framebufferNoAttachmentsSampleCounts
             Word32
maxColorAttachments
             SampleCountFlags
sampledImageColorSampleCounts
             SampleCountFlags
sampledImageIntegerSampleCounts
             SampleCountFlags
sampledImageDepthSampleCounts
             SampleCountFlags
sampledImageStencilSampleCounts
             SampleCountFlags
storageImageSampleCounts
             Word32
maxSampleMaskWords
             (Bool32 -> Bool
bool32ToBool Bool32
timestampComputeAndGraphics)
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
timestampPeriod)
             Word32
maxClipDistances
             Word32
maxCullDistances
             Word32
maxCombinedClipAndCullDistances
             Word32
discreteQueuePriorities
             (( (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
pointSizeRange0)
              , (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
pointSizeRange1) ))
             (( (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
lineWidthRange0)
              , (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
lineWidthRange1) ))
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
pointSizeGranularity)
             (coerce :: forall a b. Coercible a b => a -> b
coerce @CFloat @Float CFloat
lineWidthGranularity)
             (Bool32 -> Bool
bool32ToBool Bool32
strictLines)
             (Bool32 -> Bool
bool32ToBool Bool32
standardSampleLocations)
             DeviceSize
optimalBufferCopyOffsetAlignment
             DeviceSize
optimalBufferCopyRowPitchAlignment
             DeviceSize
nonCoherentAtomSize

instance Storable PhysicalDeviceLimits where
  sizeOf :: PhysicalDeviceLimits -> Int
sizeOf ~PhysicalDeviceLimits
_ = Int
504
  alignment :: PhysicalDeviceLimits -> Int
alignment ~PhysicalDeviceLimits
_ = Int
8
  peek :: Ptr PhysicalDeviceLimits -> IO PhysicalDeviceLimits
peek = forall a. FromCStruct a => Ptr a -> IO a
peekCStruct
  poke :: Ptr PhysicalDeviceLimits -> PhysicalDeviceLimits -> IO ()
poke Ptr PhysicalDeviceLimits
ptr PhysicalDeviceLimits
poked = forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceLimits
ptr PhysicalDeviceLimits
poked (forall (f :: * -> *) a. Applicative f => a -> f a
pure ())

instance Zero PhysicalDeviceLimits where
  zero :: PhysicalDeviceLimits
zero = Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> DeviceSize
-> DeviceSize
-> 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
-> (Word32, Word32, Word32)
-> Word32
-> (Word32, Word32, Word32)
-> Word32
-> Word32
-> Word32
-> Word32
-> Word32
-> Float
-> Float
-> Word32
-> (Word32, Word32)
-> (Float, Float)
-> Word32
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> Int32
-> Word32
-> Int32
-> Word32
-> Float
-> Float
-> Word32
-> Word32
-> Word32
-> Word32
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> Word32
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> SampleCountFlags
-> Word32
-> Bool
-> Float
-> Word32
-> Word32
-> Word32
-> Word32
-> (Float, Float)
-> (Float, Float)
-> Float
-> Float
-> Bool
-> Bool
-> DeviceSize
-> DeviceSize
-> DeviceSize
-> PhysicalDeviceLimits
PhysicalDeviceLimits
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           forall a. Zero a => a
zero
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           (forall a. Zero a => a
zero, forall a. Zero a => a
zero)
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero
           forall a. Zero a => a
zero