{-# language CPP #-}
-- | = Name
--
-- VK_KHR_shader_expect_assume - device extension
--
-- = VK_KHR_shader_expect_assume
--
-- [__Name String__]
--     @VK_KHR_shader_expect_assume@
--
-- [__Extension Type__]
--     Device extension
--
-- [__Registered Extension Number__]
--     545
--
-- [__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>
--
-- [__SPIR-V Dependencies__]
--
--     -   <https://htmlpreview.github.io/?https://github.com/KhronosGroup/SPIRV-Registry/blob/master/extensions/KHR/SPV_KHR_expect_assume.html SPV_KHR_expect_assume>
--
-- [__Contact__]
--
--     -   Kevin Petit
--         <https://github.com/KhronosGroup/Vulkan-Docs/issues/new?body=[VK_KHR_shader_expect_assume] @kpet%0A*Here describe the issue or question you have about the VK_KHR_shader_expect_assume extension* >
--
-- [__Extension Proposal__]
--     <https://github.com/KhronosGroup/Vulkan-Docs/tree/main/proposals/VK_KHR_shader_expect_assume.adoc VK_KHR_shader_expect_assume>
--
-- == Other Extension Metadata
--
-- [__Last Modified Date__]
--     2023-12-06
--
-- [__IP Status__]
--     No known IP claims.
--
-- [__Contributors__]
--
--     -   Kevin Petit, Arm
--
--     -   Tobias Hector, AMD
--
--     -   James Fitzpatrick, Imagination Technologies
--
-- == Description
--
-- This extension allows the use of the @SPV_KHR_expect_assume@ extension
-- in SPIR-V shader modules which enables SPIR-V producers to provide
-- optimization hints to the Vulkan implementation.
--
-- == New Structures
--
-- -   Extending
--     'Vulkan.Core11.Promoted_From_VK_KHR_get_physical_device_properties2.PhysicalDeviceFeatures2',
--     'Vulkan.Core10.Device.DeviceCreateInfo':
--
--     -   'PhysicalDeviceShaderExpectAssumeFeaturesKHR'
--
-- == New Enum Constants
--
-- -   'KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME'
--
-- -   'KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION'
--
-- -   Extending 'Vulkan.Core10.Enums.StructureType.StructureType':
--
--     -   'Vulkan.Core10.Enums.StructureType.STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_EXPECT_ASSUME_FEATURES_KHR'
--
-- == New SPIR-V Capabilities
--
-- -   <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#spirvenv-capabilities-table-ExpectAssumeKHR ExpectAssumeKHR>
--
-- == Version History
--
-- -   Revision 1, 2023-12-06 (Kevin Petit)
--
--     -   Initial revision
--
-- == See Also
--
-- No cross-references are available
--
-- == Document Notes
--
-- For more information, see the
-- <https://registry.khronos.org/vulkan/specs/1.3-extensions/html/vkspec.html#VK_KHR_shader_expect_assume Vulkan Specification>
--
-- This page is a generated document. Fixes and changes should be made to
-- the generator scripts, not directly.
module Vulkan.Extensions.VK_KHR_shader_expect_assume  ( PhysicalDeviceShaderExpectAssumeFeaturesKHR(..)
                                                      , KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION
                                                      , pattern KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION
                                                      , KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME
                                                      , pattern KHR_SHADER_EXPECT_ASSUME_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_SHADER_EXPECT_ASSUME_FEATURES_KHR))
-- | VkPhysicalDeviceShaderExpectAssumeFeaturesKHR - Structure describing
-- shader expect assume features that can be supported by an implementation
--
-- = Description
--
-- If the 'PhysicalDeviceShaderExpectAssumeFeaturesKHR' 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. 'PhysicalDeviceShaderExpectAssumeFeaturesKHR' /can/ also be
-- used in the @pNext@ chain of 'Vulkan.Core10.Device.DeviceCreateInfo' to
-- selectively enable these features.
--
-- == Valid Usage (Implicit)
--
-- = See Also
--
-- <https://www.khronos.org/registry/vulkan/specs/1.2-extensions/html/vkspec.html#VK_KHR_shader_expect_assume VK_KHR_shader_expect_assume>,
-- 'Vulkan.Core10.FundamentalTypes.Bool32',
-- 'Vulkan.Core10.Enums.StructureType.StructureType'
data PhysicalDeviceShaderExpectAssumeFeaturesKHR = PhysicalDeviceShaderExpectAssumeFeaturesKHR
  { -- | #features-shaderExpectAssume# @shaderExpectAssume@ specifies whether
    -- shader modules /can/ declare the @ExpectAssumeKHR@ capability.
    PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
shaderExpectAssume :: Bool }
  deriving (Typeable, PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
(PhysicalDeviceShaderExpectAssumeFeaturesKHR
 -> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool)
-> (PhysicalDeviceShaderExpectAssumeFeaturesKHR
    -> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool)
-> Eq PhysicalDeviceShaderExpectAssumeFeaturesKHR
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
== :: PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
$c/= :: PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
/= :: PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
Eq)
#if defined(GENERIC_INSTANCES)
deriving instance Generic (PhysicalDeviceShaderExpectAssumeFeaturesKHR)
#endif
deriving instance Show PhysicalDeviceShaderExpectAssumeFeaturesKHR

instance ToCStruct PhysicalDeviceShaderExpectAssumeFeaturesKHR where
  withCStruct :: forall b.
PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> (Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b)
-> IO b
withCStruct PhysicalDeviceShaderExpectAssumeFeaturesKHR
x Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b
f = Int
-> (Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b)
-> IO b
forall a b. Int -> (Ptr a -> IO b) -> IO b
allocaBytes Int
24 ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b) -> IO b)
-> (Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b)
-> IO b
forall a b. (a -> b) -> a -> b
$ \Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p -> Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b -> IO b
forall b.
Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b -> IO b
forall a b. ToCStruct a => Ptr a -> a -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p PhysicalDeviceShaderExpectAssumeFeaturesKHR
x (Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b
f Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p)
  pokeCStruct :: forall b.
Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b -> IO b
pokeCStruct Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p PhysicalDeviceShaderExpectAssumeFeaturesKHR{Bool
$sel:shaderExpectAssume:PhysicalDeviceShaderExpectAssumeFeaturesKHR :: PhysicalDeviceShaderExpectAssumeFeaturesKHR -> Bool
shaderExpectAssume :: Bool
..} IO b
f = do
    Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_EXPECT_ASSUME_FEATURES_KHR)
    Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> 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 PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32)) (Bool -> Bool32
boolToBool32 (Bool
shaderExpectAssume))
    IO b
f
  cStructSize :: Int
cStructSize = Int
24
  cStructAlignment :: Int
cStructAlignment = Int
8
  pokeZeroCStruct :: forall b.
Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR -> IO b -> IO b
pokeZeroCStruct Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p IO b
f = do
    Ptr StructureType -> StructureType -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> Int -> Ptr StructureType
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
0 :: Ptr StructureType)) (StructureType
STRUCTURE_TYPE_PHYSICAL_DEVICE_SHADER_EXPECT_ASSUME_FEATURES_KHR)
    Ptr (Ptr ()) -> Ptr () -> IO ()
forall a. Storable a => Ptr a -> a -> IO ()
poke ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> 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 PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> 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 PhysicalDeviceShaderExpectAssumeFeaturesKHR where
  peekCStruct :: Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> IO PhysicalDeviceShaderExpectAssumeFeaturesKHR
peekCStruct Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p = do
    Bool32
shaderExpectAssume <- forall a. Storable a => Ptr a -> IO a
peek @Bool32 ((Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
p Ptr PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> Int -> Ptr Bool32
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
16 :: Ptr Bool32))
    PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> IO PhysicalDeviceShaderExpectAssumeFeaturesKHR
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (PhysicalDeviceShaderExpectAssumeFeaturesKHR
 -> IO PhysicalDeviceShaderExpectAssumeFeaturesKHR)
-> PhysicalDeviceShaderExpectAssumeFeaturesKHR
-> IO PhysicalDeviceShaderExpectAssumeFeaturesKHR
forall a b. (a -> b) -> a -> b
$ Bool -> PhysicalDeviceShaderExpectAssumeFeaturesKHR
PhysicalDeviceShaderExpectAssumeFeaturesKHR
             (Bool32 -> Bool
bool32ToBool Bool32
shaderExpectAssume)

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

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


type KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION = 1

-- No documentation found for TopLevel "VK_KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION"
pattern KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION :: forall a . Integral a => a
pattern $mKHR_SHADER_EXPECT_ASSUME_SPEC_VERSION :: forall {r} {a}.
Integral a =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bKHR_SHADER_EXPECT_ASSUME_SPEC_VERSION :: forall a. Integral a => a
KHR_SHADER_EXPECT_ASSUME_SPEC_VERSION = 1


type KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME = "VK_KHR_shader_expect_assume"

-- No documentation found for TopLevel "VK_KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME"
pattern KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME :: forall a . (Eq a, IsString a) => a
pattern $mKHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME :: forall {r} {a}.
(Eq a, IsString a) =>
a -> ((# #) -> r) -> ((# #) -> r) -> r
$bKHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
KHR_SHADER_EXPECT_ASSUME_EXTENSION_NAME = "VK_KHR_shader_expect_assume"