| Safe Haskell | Safe-Inferred | 
|---|---|
| Language | Haskell2010 | 
Vulkan.Extensions.VK_EXT_metal_objects
Description
Name
VK_EXT_metal_objects - device extension
VK_EXT_metal_objects
- Name String
- VK_EXT_metal_objects
- Extension Type
- Device extension
- Registered Extension Number
- 312
- Revision
- 1
- Ratification Status
- Not ratified
- Extension and Version Dependencies; Contact
- Extension Proposal
- VK_EXT_metal_objects
Other Extension Metadata
- Last Modified Date
- 2022-05-28
- IP Status
- No known IP claims.
- Contributors
- Bill Hollings, The Brenwill Workshop Ltd.
- Dzmitry Malyshau, Mozilla Corp.
 
Description
In a Vulkan implementation that is layered on top of Metal on Apple device platforms, this extension provides the ability to import and export the underlying Metal objects associated with specific Vulkan objects.
As detailed in the
 extension proposal document,
 this extension adds one new Vulkan command, exportMetalObjectsEXT, to
 export underlying Metal objects from Vulkan objects, and supports
 importing the appropriate existing Metal objects when creating Vulkan
 objects of types DeviceMemory,
 Image, Semaphore, and
 Event,
The intent is that this extension will be advertised and supported only on implementations that are layered on top of Metal on Apple device platforms.
New Base Types
New Commands
New Structures
- Extending - ExportMetalObjectsInfoEXT:
- Extending - ImageCreateInfo:
- Extending - InstanceCreateInfo,- MemoryAllocateInfo,- ImageCreateInfo,- ImageViewCreateInfo,- BufferViewCreateInfo,- SemaphoreCreateInfo,- EventCreateInfo:
- Extending - MemoryAllocateInfo:
- Extending - SemaphoreCreateInfo,- EventCreateInfo:
New Enums
New Bitmasks
New Enum Constants
- EXT_METAL_OBJECTS_SPEC_VERSION
- Extending - StructureType:- STRUCTURE_TYPE_EXPORT_METAL_BUFFER_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_COMMAND_QUEUE_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_DEVICE_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_IO_SURFACE_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_OBJECTS_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_OBJECT_CREATE_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_SHARED_EVENT_INFO_EXT
- STRUCTURE_TYPE_EXPORT_METAL_TEXTURE_INFO_EXT
- STRUCTURE_TYPE_IMPORT_METAL_BUFFER_INFO_EXT
- STRUCTURE_TYPE_IMPORT_METAL_IO_SURFACE_INFO_EXT
- STRUCTURE_TYPE_IMPORT_METAL_SHARED_EVENT_INFO_EXT
- STRUCTURE_TYPE_IMPORT_METAL_TEXTURE_INFO_EXT
 
Issues
None.
Version History
- Revision 1, 2022-05-28 (Bill Hollings) - Initial draft.
- Incorporated feedback from review by the Vulkan Working Group. Renamed many structures, moved import/export of MTLBuffer to VkDeviceMemory, added export of MTLSharedEvent, added import of MTLSharedEvent for VkSemaphore and VkEvent, and changed used bit mask fields to individual bit fields to simplify Valid Usage rules.
 
See Also
IOSurfaceRef, MTLBuffer_id, MTLCommandQueue_id, MTLDevice_id,
 MTLSharedEvent_id, MTLTexture_id, ExportMetalBufferInfoEXT,
 ExportMetalCommandQueueInfoEXT, ExportMetalDeviceInfoEXT,
 ExportMetalIOSurfaceInfoEXT, ExportMetalObjectCreateInfoEXT,
 ExportMetalObjectTypeFlagBitsEXT, ExportMetalObjectTypeFlagsEXT,
 ExportMetalObjectsInfoEXT, ExportMetalSharedEventInfoEXT,
 ExportMetalTextureInfoEXT, ImportMetalBufferInfoEXT,
 ImportMetalIOSurfaceInfoEXT, ImportMetalSharedEventInfoEXT,
 ImportMetalTextureInfoEXT, exportMetalObjectsEXT
Document Notes
For more information, see the Vulkan Specification
This page is a generated document. Fixes and changes should be made to the generator scripts, not directly.
Synopsis
- exportMetalObjectsEXT :: forall a io. (Extendss ExportMetalObjectsInfoEXT a, PokeChain a, PeekChain a, MonadIO io) => Device -> io (ExportMetalObjectsInfoEXT a)
- data ExportMetalObjectCreateInfoEXT = ExportMetalObjectCreateInfoEXT {}
- data ExportMetalObjectsInfoEXT (es :: [Type]) = ExportMetalObjectsInfoEXT {}
- data ExportMetalDeviceInfoEXT = ExportMetalDeviceInfoEXT {}
- data ExportMetalCommandQueueInfoEXT = ExportMetalCommandQueueInfoEXT {}
- data ExportMetalBufferInfoEXT = ExportMetalBufferInfoEXT {}
- data ImportMetalBufferInfoEXT = ImportMetalBufferInfoEXT {}
- data ExportMetalTextureInfoEXT = ExportMetalTextureInfoEXT {}
- data ImportMetalTextureInfoEXT = ImportMetalTextureInfoEXT {}
- data ExportMetalIOSurfaceInfoEXT = ExportMetalIOSurfaceInfoEXT {- image :: Image
- ioSurface :: IOSurfaceRef
 
- data ImportMetalIOSurfaceInfoEXT = ImportMetalIOSurfaceInfoEXT {}
- data ExportMetalSharedEventInfoEXT = ExportMetalSharedEventInfoEXT {}
- data ImportMetalSharedEventInfoEXT = ImportMetalSharedEventInfoEXT {}
- type ExportMetalObjectTypeFlagsEXT = ExportMetalObjectTypeFlagBitsEXT
- newtype ExportMetalObjectTypeFlagBitsEXT where- ExportMetalObjectTypeFlagBitsEXT Flags
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_DEVICE_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_COMMAND_QUEUE_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_BUFFER_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_TEXTURE_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_IOSURFACE_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
- pattern EXPORT_METAL_OBJECT_TYPE_METAL_SHARED_EVENT_BIT_EXT :: ExportMetalObjectTypeFlagBitsEXT
 
- type EXT_METAL_OBJECTS_SPEC_VERSION = 1
- pattern EXT_METAL_OBJECTS_SPEC_VERSION :: forall a. Integral a => a
- type EXT_METAL_OBJECTS_EXTENSION_NAME = "VK_EXT_metal_objects"
- pattern EXT_METAL_OBJECTS_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a
- type MTLDevice_id = Ptr ()
- type MTLCommandQueue_id = Ptr ()
- type MTLBuffer_id = Ptr ()
- type MTLTexture_id = Ptr ()
- type IOSurfaceRef = Ptr ()
- type MTLSharedEvent_id = Ptr ()
Documentation
exportMetalObjectsEXT Source #
Arguments
| :: forall a io. (Extendss ExportMetalObjectsInfoEXT a, PokeChain a, PeekChain a, MonadIO io) | |
| => Device | 
   | 
| -> io (ExportMetalObjectsInfoEXT a) | 
vkExportMetalObjectsEXT - Export Metal objects from the corresponding Vulkan objects
Valid Usage (Implicit)
See Also
data ExportMetalObjectCreateInfoEXT Source #
VkExportMetalObjectCreateInfoEXT - Structure that identifies the Metal objects that can be exported from Vulkan objects
Valid Usage (Implicit)
-  sTypemust beSTRUCTURE_TYPE_EXPORT_METAL_OBJECT_CREATE_INFO_EXT
- 
     If exportObjectTypeis not0,exportObjectTypemust be a validExportMetalObjectTypeFlagBitsEXTvalue
See Also
VK_EXT_metal_objects,
 ExportMetalObjectTypeFlagBitsEXT,
 StructureType
Constructors
| ExportMetalObjectCreateInfoEXT | |
| Fields 
 | |
Instances
data ExportMetalObjectsInfoEXT (es :: [Type]) Source #
VkExportMetalObjectsInfoEXT - Structure whose pNext chain identifies Vulkan objects and corresponding Metal objects
Valid Usage
-  If the pNextchain includes aExportMetalDeviceInfoEXTstructure, theInstancemust have been created withEXPORT_METAL_OBJECT_TYPE_METAL_DEVICE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theInstanceCreateInfostructure in thecreateInstancecommand
-  If the pNextchain includes aExportMetalCommandQueueInfoEXTstructure, theInstancemust have been created withEXPORT_METAL_OBJECT_TYPE_METAL_COMMAND_QUEUE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theInstanceCreateInfostructure in thecreateInstancecommand
-  If the pNextchain includes aExportMetalBufferInfoEXTstructure, theDeviceMemoryin itsmemorymember must have been allocated withEXPORT_METAL_OBJECT_TYPE_METAL_BUFFER_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theMemoryAllocateInfostructure in theallocateMemorycommand
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, exactly one of itsimage,imageView, orbufferViewmembers must not beNULL_HANDLE
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and itsimagemember is notNULL_HANDLE, theImagein itsimagemember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_TEXTURE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theImageCreateInfostructure in thecreateImagecommand
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and itsimageViewmember is notNULL_HANDLE, theImageViewin itsimageViewmember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_TEXTURE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theImageViewCreateInfostructure in thecreateImageViewcommand
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and itsbufferViewmember is notNULL_HANDLE, theBufferViewin itsbufferViewmember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_TEXTURE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theBufferViewCreateInfostructure in thecreateBufferViewcommand
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and if either itsimageorimageViewmember is notNULL_HANDLE, thenplanemust beIMAGE_ASPECT_PLANE_0_BIT,IMAGE_ASPECT_PLANE_1_BIT, orIMAGE_ASPECT_PLANE_2_BIT
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and if theImagein itsimagemember does not have a multi-planar format, then itsplanemember must beIMAGE_ASPECT_PLANE_0_BIT
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and if theImagein itsimagemember has a multi-planar format with only two planes, then itsplanemember must not beIMAGE_ASPECT_PLANE_2_BIT
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and if theImageViewin itsimageViewmember does not have a multi-planar format, then itsplanemember must beIMAGE_ASPECT_PLANE_0_BIT
-  If the pNextchain includes aExportMetalTextureInfoEXTstructure, and if theImageViewin itsimageViewmember has a multi-planar format with only two planes, then itsplanemember must not beIMAGE_ASPECT_PLANE_2_BIT
-  If the pNextchain includes aExportMetalIOSurfaceInfoEXTstructure, theImagein itsimagemember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_IOSURFACE_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theImageCreateInfostructure in thecreateImagecommand
-  If the pNextchain includes aExportMetalSharedEventInfoEXTstructure, exactly one of itssemaphoreoreventmembers must not beNULL_HANDLE
-  If the pNextchain includes aExportMetalSharedEventInfoEXTstructure, and itssemaphoremember is notNULL_HANDLE, theSemaphorein itssemaphoremember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_SHARED_EVENT_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theSemaphoreCreateInfostructure in thecreateSemaphorecommand
-  If the pNextchain includes aExportMetalSharedEventInfoEXTstructure, and itseventmember is notNULL_HANDLE, theEventin itseventmember must have been created withEXPORT_METAL_OBJECT_TYPE_METAL_SHARED_EVENT_BIT_EXTin theexportObjectTypemember of aExportMetalObjectCreateInfoEXTstructure in thepNextchain of theEventCreateInfostructure in thecreateEventcommand
Valid Usage (Implicit)
-  sTypemust beSTRUCTURE_TYPE_EXPORT_METAL_OBJECTS_INFO_EXT
-  Each pNextmember of any structure (including this one) in thepNextchain must be eitherNULLor a pointer to a valid instance ofExportMetalBufferInfoEXT,ExportMetalCommandQueueInfoEXT,ExportMetalDeviceInfoEXT,ExportMetalIOSurfaceInfoEXT,ExportMetalSharedEventInfoEXT, orExportMetalTextureInfoEXT
-  The sTypevalue of each struct in thepNextchain must be unique, with the exception of structures of typeExportMetalBufferInfoEXT,ExportMetalCommandQueueInfoEXT,ExportMetalIOSurfaceInfoEXT,ExportMetalSharedEventInfoEXT, orExportMetalTextureInfoEXT
See Also
Constructors
| ExportMetalObjectsInfoEXT | |
Instances
data ExportMetalDeviceInfoEXT Source #
VkExportMetalDeviceInfoEXT - Structure that identifies a VkDevice object and corresponding Metal MTLDevice object
Valid Usage (Implicit)
See Also
Constructors
| ExportMetalDeviceInfoEXT | |
| Fields 
 | |
Instances
data ExportMetalCommandQueueInfoEXT Source #
VkExportMetalCommandQueueInfoEXT - Structure that identifies a VkQueue object and corresponding Metal MTLCommandQueue object
Valid Usage (Implicit)
See Also
Constructors
| ExportMetalCommandQueueInfoEXT | |
| Fields | |
Instances
data ExportMetalBufferInfoEXT Source #
VkExportMetalBufferInfoEXT - Structure that identifies a VkDeviceMemory object and corresponding Metal MTLBuffer object
Valid Usage (Implicit)
See Also
Constructors
| ExportMetalBufferInfoEXT | |
| Fields 
 | |
Instances
data ImportMetalBufferInfoEXT Source #
VkImportMetalBufferInfoEXT - Structure that identifies a Metal MTLBuffer object to use when creating a VkDeviceMemory object.
Description
The app must ensure that the configuration of the id<MTLBuffer>
 object is compatible with the configuration of the
 DeviceMemory. Failure to do so results in
 undefined behavior.
Valid Usage (Implicit)
See Also
Constructors
| ImportMetalBufferInfoEXT | |
| Fields 
 | |
Instances
data ExportMetalTextureInfoEXT Source #
VkExportMetalTextureInfoEXT - Structure that identifies a VkImage, VkImageView, or VkBufferView object and corresponding Metal MTLTexture object
Valid Usage (Implicit)
-  sTypemust beSTRUCTURE_TYPE_EXPORT_METAL_TEXTURE_INFO_EXT
-  If imageis notNULL_HANDLE,imagemust be a validImagehandle
-  If
     imageViewis notNULL_HANDLE,imageViewmust be a validImageViewhandle
-  If
     bufferViewis notNULL_HANDLE,bufferViewmust be a validBufferViewhandle
-  planemust be a validImageAspectFlagBitsvalue
-  Each of
     bufferView,image, andimageViewthat are valid handles of non-ignored parameters must have been created, allocated, or retrieved from the sameDevice
See Also
VK_EXT_metal_objects,
 BufferView, Image,
 ImageAspectFlagBits,
 ImageView,
 StructureType
Constructors
| ExportMetalTextureInfoEXT | |
| Fields 
 | |
Instances
data ImportMetalTextureInfoEXT Source #
VkImportMetalTextureInfoEXT - Structure that identifies Metal MTLTexture objects to use when creating a VkImage.
Description
The pNext chain must include one ImportMetalTextureInfoEXT
 structure for each plane in the Image. The app
 must ensure that the configuration of the Metal id<MTLTexture>
 objects are compatible with the configuration of the
 Image. Failure to do so results in undefined
 behavior.
Valid Usage (Implicit)
See Also
Constructors
| ImportMetalTextureInfoEXT | |
| Fields 
 | |
Instances
data ExportMetalIOSurfaceInfoEXT Source #
VkExportMetalIOSurfaceInfoEXT - Structure that identifies a VkImage object and corresponding Metal IOSurfaceRef object
Valid Usage (Implicit)
See Also
Constructors
| ExportMetalIOSurfaceInfoEXT | |
| Fields 
 | |
Instances
data ImportMetalIOSurfaceInfoEXT Source #
VkImportMetalIOSurfaceInfoEXT - Structure that identifies a VkImage object and corresponding Metal IOSurfaceRef object to use.
Description
If ioSurface is not NULL_HANDLE, it will
 be used to underlie the Image. If ioSurface is
 NULL_HANDLE, the implementation will create
 a new IOSurface to underlie the Image.
If provided, the app must ensure that the configuration of the
 IOSurfaceRef object is compatible with the configuration of the
 Image. Failure to do so results in undefined
 behavior.
Valid Usage (Implicit)
See Also
Constructors
| ImportMetalIOSurfaceInfoEXT | |
| Fields 
 | |
Instances
data ExportMetalSharedEventInfoEXT Source #
VkExportMetalSharedEventInfoEXT - Structure that identifies a VkSemaphore or VkEvent object and corresponding Metal MTLSharedEvent object
Valid Usage (Implicit)
-  sTypemust beSTRUCTURE_TYPE_EXPORT_METAL_SHARED_EVENT_INFO_EXT
-  If
     semaphoreis notNULL_HANDLE,semaphoremust be a validSemaphorehandle
-  If eventis notNULL_HANDLE,eventmust be a validEventhandle
-  Both of event, andsemaphorethat are valid handles of non-ignored parameters must have been created, allocated, or retrieved from the sameDevice
See Also
Constructors
| ExportMetalSharedEventInfoEXT | |
| Fields 
 | |
Instances
data ImportMetalSharedEventInfoEXT Source #
VkImportMetalSharedEventInfoEXT - Structure that identifies a VkSemaphore or VkEvent object and corresponding Metal Shared Event object to use.
Description
If the pNext chain of the
 SemaphoreCreateInfo structure includes
 both ImportMetalSharedEventInfoEXT and
 SemaphoreTypeCreateInfo,
 the signaledValue property of the imported id<MTLSharedEvent>
 object will be set to initialValue of
 SemaphoreTypeCreateInfo.
Valid Usage (Implicit)
See Also
Constructors
| ImportMetalSharedEventInfoEXT | |
| Fields | |
Instances
newtype ExportMetalObjectTypeFlagBitsEXT Source #
VkExportMetalObjectTypeFlagBitsEXT - Bitmask specifying Metal object types that can be exported from a Vulkan object
See Also
VK_EXT_metal_objects,
 ExportMetalObjectCreateInfoEXT, ExportMetalObjectTypeFlagsEXT
Constructors
| ExportMetalObjectTypeFlagBitsEXT Flags | 
Bundled Patterns
Instances
type EXT_METAL_OBJECTS_SPEC_VERSION = 1 Source #
pattern EXT_METAL_OBJECTS_SPEC_VERSION :: forall a. Integral a => a Source #
type EXT_METAL_OBJECTS_EXTENSION_NAME = "VK_EXT_metal_objects" Source #
pattern EXT_METAL_OBJECTS_EXTENSION_NAME :: forall a. (Eq a, IsString a) => a Source #
type MTLDevice_id = Ptr () Source #
type MTLCommandQueue_id = Ptr () Source #
type MTLBuffer_id = Ptr () Source #
type MTLTexture_id = Ptr () Source #
type IOSurfaceRef = Ptr () Source #
type MTLSharedEvent_id = Ptr () Source #