{-# language CPP #-}
-- | = Name
--
-- VK_EXT_zero_initialize_device_memory - device extension
--
-- = VK_EXT_zero_initialize_device_memory
--
-- [__Name String__]
--     @VK_EXT_zero_initialize_device_memory@
--
-- [__Extension Type__]
--     Device extension
--
-- [__Registered Extension Number__]
--     621
--
-- [__Revision__]
--     1
--
-- [__Ratification Status__]
--     Ratified
--
-- [__Extension and Version Dependencies__]
--     <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_KHR_get_physical_device_properties2 VK_KHR_get_physical_device_properties2>
--     or
--     <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#versions-1.1 Vulkan Version 1.1>
--
-- [__Contact__]
--
--     -   Mike Blumenkrantz
--         <https://github.com/KhronosGroup/Vulkan-Docs/issues/new?body=[VK_EXT_zero_initialize_device_memory] @zmike%0A*Here describe the issue or question you have about the VK_EXT_zero_initialize_device_memory extension* >
--
-- [__Extension Proposal__]
--     <https://github.com/KhronosGroup/Vulkan-Docs/tree/main/proposals/VK_EXT_zero_initialize_device_memory.adoc VK_EXT_zero_initialize_device_memory>
--
-- == Other Extension Metadata
--
-- [__Last Modified Date__]
--     2025-04-09
--
-- [__Interactions and External Dependencies__]
--
--     -   Interacts with Vulkan 1.1.
--
--     -   Interacts with @VK_KHR_get_physical_device_properties2@.
--
-- [__IP Status__]
--     No known IP claims.
--
-- [__Contributors__]
--
--     -   Hans-Kristian Arntzen, VALVE
--
--     -   Mike Blumenkrantz, VALVE
--
--     -   Tobias Hector, AMD
--
--     -   Faith Ekstrand, Collabora
--
--     -   Ricardo Garcia, Igalia
--
--     -   Jan-Harald Fredriksen, ARM
--
--     -   Spencer Fricke, LunarG
--
-- == Description
--
-- By default, Vulkan provides no guarantees that device memory allocated
-- through vkAllocateMemory is cleared to zero. This means that
-- applications wanting resources to be zero-initialized must execute a
-- command such as vkCmdFillBuffer or vkCmdClearColorImage on the device to
-- ensure a deterministic result. This can be wasteful if the underlying
-- platform either:
--
-- -   Already performs that zero clear anyway, due to e.g. security
--     concerns.
--
-- -   Can be performed more efficiently in implementation, by e.g.
--     clearing pages to zero in the background after device memory is
--     freed.
--
-- This extension also has uses in API layering and porting efforts, where
-- zero memory behavior may be more strict than Vulkan. Different OS
-- platforms also have wildly different behaviors here, which leads to
-- implementations needing to apply workarounds to paper over these issues
-- in the wild. If an extension exists to make allocation behavior
-- explicit, we hopefully achieve a more robust ecosystem for Vulkan.
--
-- == New Structures
--
-- -   Extending
--     'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceFeatures2',
--     'Vulkan.Core10.Device.DeviceCreateInfo':
--
--     -   'PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT'
--
-- == New Enum Constants
--
-- -   'EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME'
--
-- -   'EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION'
--
-- -   Extending 'Vulkan.Core10.Enums.ImageLayout.ImageLayout':
--
--     -   'Vulkan.Core10.Enums.ImageLayout.IMAGE_LAYOUT_ZERO_INITIALIZED_EXT'
--
-- -   Extending
--     'Vulkan.Core11.Enums.MemoryAllocateFlagBits.MemoryAllocateFlagBits':
--
--     -   'Vulkan.Core11.Enums.MemoryAllocateFlagBits.MEMORY_ALLOCATE_ZERO_INITIALIZE_BIT_EXT'
--
-- -   Extending 'Vulkan.Core10.Enums.StructureType.StructureType':
--
--     -   'Vulkan.Core10.Enums.StructureType.STRUCTURE_TYPE_PHYSICAL_DEVICE_ZERO_INITIALIZE_DEVICE_MEMORY_FEATURES_EXT'
--
-- == Version History
--
-- -   Revision 1, 2025-03-10 (Mike Blumenkrantz)
--
--     -   Initial version
--
-- == See Also
--
-- No cross-references are available
--
-- == Document Notes
--
-- For more information, see the
-- <https://registry.khronos.org/vulkan/specs/latest/html/vkspec.html#VK_EXT_zero_initialize_device_memory Vulkan Specification>.
--
-- This page is a generated document. Fixes and changes should be made to
-- the generator scripts, not directly.
module Vulkan.Extensions.VK_EXT_zero_initialize_device_memory  ( PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT(..)
                                                               , EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION
                                                               , pattern EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION
                                                               , EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME
                                                               , pattern EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME
                                                               ) where

import Foreign.Marshal.Alloc (allocaBytes)
import Foreign.Ptr (nullPtr)
import Foreign.Ptr (plusPtr)
import Vulkan.CStruct (FromCStruct)
import Vulkan.CStruct (FromCStruct(..))
import Vulkan.CStruct (ToCStruct)
import Vulkan.CStruct (ToCStruct(..))
import Vulkan.Zero (Zero(..))
import Data.String (IsString)
import Data.Typeable (Typeable)
import Foreign.Storable (Storable)
import Foreign.Storable (Storable(peek))
import Foreign.Storable (Storable(poke))
import qualified Foreign.Storable (Storable(..))
import GHC.Generics (Generic)
import Foreign.Ptr (Ptr)
import Data.Kind (Type)
import Vulkan.Core10.FundamentalTypes (bool32ToBool)
import Vulkan.Core10.FundamentalTypes (boolToBool32)
import Vulkan.Core10.FundamentalTypes (Bool32)
import Vulkan.Core10.Enums.StructureType (StructureType)
import Vulkan.Core10.Enums.StructureType (StructureType(STRUCTURE_TYPE_PHYSICAL_DEVICE_ZERO_INITIALIZE_DEVICE_MEMORY_FEATURES_EXT))
-- | VkPhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT - Structure
-- describing whether the implementation supports cleared allocation
-- functionality
--
-- = Members
--
-- This structure describes the following features:
--
-- = Description
--
-- If the 'PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT' structure
-- is included in the @pNext@ chain of the
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceFeatures2'
-- structure passed to
-- 'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.getPhysicalDeviceFeatures2',
-- it is filled in to indicate whether each corresponding feature is
-- supported. If the application wishes to use a
-- 'Vulkan.Core10.Handles.Device' with any features described by
-- 'PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT', it /must/ add an
-- instance of the structure, with the desired feature members set to
-- 'Vulkan.Core10.FundamentalTypes.TRUE', to the @pNext@ chain of
-- 'Vulkan.Core10.Device.DeviceCreateInfo' when creating the
-- 'Vulkan.Core10.Handles.Device'.
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_EXT_zero_initialize_device_memory VK_EXT_zero_initialize_device_memory>,
-- 'Vulkan.Core10.FundamentalTypes.Bool32',
-- 'Vulkan.Core10.Enums.StructureType.StructureType'
data PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT = PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
  { -- | #features-zeroInitializeDeviceMemory# @zeroInitializeDeviceMemory@
    -- indicates that the implementation supports zeroing memory allocations
    -- using a user-specified flag.
    PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
zeroInitializeDeviceMemory :: Bool }
  deriving (Typeable, PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
(PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
 -> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool)
-> (PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
    -> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool)
-> Eq PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
== :: PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
$c/= :: PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
/= :: PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT)
#endif
deriving instance Show PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT

instance ToCStruct PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT where
  withCStruct :: forall b.
PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> (Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
    -> IO b)
-> IO b
withCStruct PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
x Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> IO b
f = Int
-> (Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
    -> IO b)
-> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> IO b)
 -> IO b)
-> (Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
    -> IO b)
-> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p -> Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> IO b
-> IO b
forall b.
Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> IO b
-> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
x (Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> IO b
f Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p)
  pokeCStruct :: forall b.
Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> IO b
-> IO b
pokeCStruct Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT{Bool
zeroInitializeDeviceMemory :: PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT -> Bool
zeroInitializeDeviceMemory :: Bool
..} IO b
f = do
    Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_ZERO_INITIALIZE_DEVICE_MEMORY_FEATURES_EXT)
    Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
    Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
zeroInitializeDeviceMemory))
    IO b
f
  cStructSize :: Int
cStructSize = Int
24
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b.
Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p IO b
f = do
    Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_ZERO_INITIALIZE_DEVICE_MEMORY_FEATURES_EXT)
    Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr (Ptr ())
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
8 :: Ptr (Ptr ()))) (Ptr ()
forall a. Ptr a
nullPtr)
    Ptr Bool32 -> Bool32 -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
forall a. Zero a => a
zero))
    IO b
f

instance FromCStruct PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT where
  peekCStruct :: Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> IO PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
peekCStruct Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p = do
    zeroInitializeDeviceMemory <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
p Ptr PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
    pure $ PhysicalDeviceZeroInitializeDeviceMemoryFeaturesEXT
             (bool32ToBool zeroInitializeDeviceMemory)

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

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


type EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION = 1

-- No documentation found for TopLevel "VK_EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION"
pattern EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION :: forall a . Integral a => a
pattern $mEXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION :: forall {r} {a}.
Integral a =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bEXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION :: forall a. Integral a => a
EXT_ZERO_INITIALIZE_DEVICE_MEMORY_SPEC_VERSION = 1


type EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME = "VK_EXT_zero_initialize_device_memory"

-- No documentation found for TopLevel "VK_EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME"
pattern EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $mEXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME :: forall {r} {a}.
(Eq a, IsString a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bEXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
EXT_ZERO_INITIALIZE_DEVICE_MEMORY_EXTENSION_NAME = "VK_EXT_zero_initialize_device_memory"