C Specification
An acquire operation may have a performance penalty when acquiring
ownership of a subresource range from one of the special queue families
reserved for external memory ownership transfers described above.
The application can reduce the performance penalty in some cases by adding
a VkExternalMemoryAcquireUnmodifiedEXT structure to the pNext
chain of the acquire operation's memory barrier structure.
The VkExternalMemoryAcquireUnmodifiedEXT
structure is defined as:
// Provided by VK_EXT_external_memory_acquire_unmodified
typedef struct VkExternalMemoryAcquireUnmodifiedEXT {
VkStructureType sType;
const void* pNext;
VkBool32 acquireUnmodifiedMemory;
} VkExternalMemoryAcquireUnmodifiedEXT;
Members
-
sType
is a VkStructureType value identifying this structure. -
pNext
isNULL
or a pointer to a structure extending this structure. -
acquireUnmodifiedMemory
specifies, ifVK_TRUE
, that no range of VkDeviceMemory bound to the resource of the memory barrier’s subresource range was modified at any time since the resource’s most recent release of ownership to the queue family specified by the memory barrier’ssrcQueueFamilyIndex
. IfVK_FALSE
, it specifies nothing.
Description
If the application releases ownership of the subresource range to one of the
special queue families reserved for external memory ownership transfers with
a memory barrier structure, and later re-acquires ownership from the same
queue family with a memory barrier structure, and if no range of
VkDeviceMemory bound to the resource was modified at any time between
the release operation and the acquire operation, then the application
should add a VkExternalMemoryAcquireUnmodifiedEXT structure to the
pNext
chain of the acquire operation's memory barrier structure
because this may reduce the performance penalty.
This struct is ignored if acquireUnmodifiedMemory
is VK_FALSE
.
In particular, VK_FALSE
does not specify that memory was modified.
This struct is ignored if the memory barrier’s srcQueueFamilyIndex
is
not a special queue family reserved for external memory ownership transfers.
Note
The method by which the application determines whether memory was modified between the release operation and acquire operation is outside the scope of Vulkan. For any Vulkan operation that accesses a resource, the application must not assume the implementation accesses the resource’s memory as read-only, even for apparently read-only operations such as transfer commands and shader reads. The validity of
VkExternalMemoryAcquireUnmodifiedEXT:: |
Document Notes
For more information, see the Vulkan Specification
This page is extracted from the Vulkan Specification. Fixes and changes should be made to the Specification, not directly.