| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
Vulkan.Extensions.VK_EXT_external_memory_host
Synopsis
- getMemoryHostPointerPropertiesEXT :: forall io. MonadIO io => Device -> ExternalMemoryHandleTypeFlagBits -> ("hostPointer" ::: Ptr ()) -> io MemoryHostPointerPropertiesEXT
- data ImportMemoryHostPointerInfoEXT = ImportMemoryHostPointerInfoEXT {}
- data MemoryHostPointerPropertiesEXT = MemoryHostPointerPropertiesEXT {}
- data PhysicalDeviceExternalMemoryHostPropertiesEXT = PhysicalDeviceExternalMemoryHostPropertiesEXT {}
- type EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION = 1
- pattern EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION :: forall a. Integral a => a
- type EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME = "VK_EXT_external_memory_host"
- pattern EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
Documentation
getMemoryHostPointerPropertiesEXT Source #
Arguments
| :: forall io. MonadIO io | |
| => Device | 
 | 
| -> ExternalMemoryHandleTypeFlagBits | 
 | 
| -> ("hostPointer" ::: Ptr ()) | 
 | 
| -> io MemoryHostPointerPropertiesEXT | 
vkGetMemoryHostPointerPropertiesEXT - Get properties of external memory host pointer
Valid Usage
- handleTypemust be- EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXTor- EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
- pHostPointermust be a pointer aligned to an integer multiple of- PhysicalDeviceExternalMemoryHostPropertiesEXT::- minImportedHostPointerAlignment
- If handleTypeisEXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT,pHostPointermust be a pointer to host memory
- If handleTypeisEXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT,pHostPointermust be a pointer to host mapped foreign memory
Valid Usage (Implicit)
- devicemust be a valid- Devicehandle
- handleTypemust be a valid- ExternalMemoryHandleTypeFlagBitsvalue
- pMemoryHostPointerPropertiesmust be a valid pointer to a- MemoryHostPointerPropertiesEXTstructure
Return Codes
See Also
Device,
 ExternalMemoryHandleTypeFlagBits,
 MemoryHostPointerPropertiesEXT
data ImportMemoryHostPointerInfoEXT Source #
VkImportMemoryHostPointerInfoEXT - import memory from a host pointer
Description
Importing memory from a host pointer shares ownership of the memory between the host and the Vulkan implementation. The application can continue to access the memory through the host pointer but it is the application’s responsibility to synchronize device and non-device access to the payload as defined in Host Access to Device Memory Objects.
Applications can import the same payload into multiple instances of Vulkan and multiple times into a given Vulkan instance. However, implementations may fail to import the same payload multiple times into a given physical device due to platform constraints.
Importing memory from a particular host pointer may not be possible
 due to additional platform-specific restrictions beyond the scope of
 this specification in which case the implementation must fail the
 memory import operation with the error code
 ERROR_INVALID_EXTERNAL_HANDLE_KHR.
Whether device memory objects imported from a host pointer hold a reference to their payload is undefined. As such, the application must ensure that the imported memory range remains valid and accessible for the lifetime of the imported memory object.
Valid Usage
- If handleTypeis not0, it must be supported for import, as reported inExternalMemoryProperties
- If handleTypeis not0, it must beEXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXTorEXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
- pHostPointermust be a pointer aligned to an integer multiple of- PhysicalDeviceExternalMemoryHostPropertiesEXT::- minImportedHostPointerAlignment
- If handleTypeisEXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT,pHostPointermust be a pointer toallocationSizenumber of bytes of host memory, whereallocationSizeis the member of theMemoryAllocateInfostructure this structure is chained to
- If handleTypeisEXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT,pHostPointermust be a pointer toallocationSizenumber of bytes of host mapped foreign memory, whereallocationSizeis the member of theMemoryAllocateInfostructure this structure is chained to
Valid Usage (Implicit)
- sTypemust be- STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT
- handleTypemust be a valid- ExternalMemoryHandleTypeFlagBitsvalue
See Also
Constructors
| ImportMemoryHostPointerInfoEXT | |
| Fields 
 | |
Instances
data MemoryHostPointerPropertiesEXT Source #
VkMemoryHostPointerPropertiesEXT - Properties of external memory host pointer
Description
The value returned by memoryTypeBits must only include bits that
 identify memory types which are host visible.
Valid Usage (Implicit)
See Also
Constructors
| MemoryHostPointerPropertiesEXT | |
| Fields 
 | |
Instances
data PhysicalDeviceExternalMemoryHostPropertiesEXT Source #
VkPhysicalDeviceExternalMemoryHostPropertiesEXT - Structure describing external memory host pointer limits that can be supported by an implementation
Members
The members of the PhysicalDeviceExternalMemoryHostPropertiesEXT
 structure describe the following implementation-dependent limits:
Description
If the PhysicalDeviceExternalMemoryHostPropertiesEXT structure is
 included in the pNext chain of
 PhysicalDeviceProperties2,
 it is filled with the implementation-dependent limits.
Valid Usage (Implicit)
See Also
Constructors
| PhysicalDeviceExternalMemoryHostPropertiesEXT | |
| Fields 
 | |
Instances
type EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION = 1 Source #
pattern EXT_EXTERNAL_MEMORY_HOST_SPEC_VERSION :: forall a. Integral a => a Source #
type EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME = "VK_EXT_external_memory_host" Source #
pattern EXT_EXTERNAL_MEMORY_HOST_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a Source #