2017-11-27 09:07:06 +00:00
|
|
|
include::meta/VK_EXT_external_memory_host.txt[]
|
|
|
|
|
|
|
|
*Last Modified Date*::
|
|
|
|
2017-11-10
|
|
|
|
*IP Status*::
|
|
|
|
No known IP claims.
|
|
|
|
*Contributors*::
|
|
|
|
- Jaakko Konttinen, AMD
|
|
|
|
- David Mao, AMD
|
|
|
|
- Daniel Rakos, AMD
|
|
|
|
- Tobias Hector, Imagination Technologies
|
|
|
|
- Jason Ekstrand, Intel
|
|
|
|
- James Jones, NVIDIA
|
|
|
|
|
|
|
|
This extension enables an application to import host allocations and host
|
|
|
|
mapped foreign device memory to Vulkan memory objects.
|
|
|
|
|
|
|
|
=== New Object Types
|
|
|
|
|
|
|
|
None.
|
|
|
|
|
|
|
|
=== New Enum Constants
|
|
|
|
|
|
|
|
* Extending elink:VkStructureType:
|
|
|
|
** ename:VK_STRUCTURE_TYPE_IMPORT_MEMORY_HOST_POINTER_INFO_EXT
|
|
|
|
** ename:VK_STRUCTURE_TYPE_MEMORY_HOST_POINTER_PROPERTIES_EXT
|
|
|
|
** ename:VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_HOST_PROPERTIES_EXT
|
|
|
|
|
|
|
|
* Extending elink:VkExternalMemoryHandleTypeFlagBitsKHR:
|
|
|
|
** ename:VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_ALLOCATION_BIT_EXT
|
|
|
|
** ename:VK_EXTERNAL_MEMORY_HANDLE_TYPE_HOST_MAPPED_FOREIGN_MEMORY_BIT_EXT
|
|
|
|
|
|
|
|
=== New Enums
|
|
|
|
|
|
|
|
None.
|
|
|
|
|
|
|
|
=== New Structs
|
|
|
|
|
|
|
|
* slink:VkImportMemoryHostPointerInfoEXT
|
|
|
|
* slink:VkMemoryHostPointerPropertiesEXT
|
|
|
|
* slink:VkPhysicalDeviceExternalMemoryHostPropertiesEXT
|
|
|
|
|
|
|
|
=== New Functions
|
|
|
|
|
|
|
|
* flink:vkGetMemoryHostPointerPropertiesEXT
|
|
|
|
|
|
|
|
=== Issues
|
|
|
|
|
|
|
|
1) What memory type has to be used to import host pointers?
|
|
|
|
|
|
|
|
RESOLVED: Depends on the implementation.
|
|
|
|
Applications have to use the new flink:vkGetMemoryHostPointerPropertiesEXT
|
|
|
|
command to query the supported memory types for a particular host pointer.
|
|
|
|
The reported memory types may include memory types that come from a memory
|
|
|
|
heap that is otherwise not usable for regular memory object allocation and
|
|
|
|
thus such a heap's size may be zero.
|
|
|
|
|
|
|
|
2) Can the application still access the contents of the host allocation
|
|
|
|
after importing?
|
|
|
|
|
|
|
|
RESOLVED: Yes.
|
|
|
|
However, usual synchronization requirements apply.
|
|
|
|
|
|
|
|
3) Can the application free the host allocation?
|
|
|
|
|
|
|
|
RESOLVED: No, it violates valid usage conditions.
|
|
|
|
Using the memory object imported from a host allocation that's already freed
|
Change log for October 7, 2018 Vulkan 1.1.87 spec update:
* Update release number to 87.
Public Issues:
* Merge flink:vkCmdPipelineBarrier self-dependency barrier VUs referring
to the same subpass dependency (public pull request 756).
* Describe default value of `"optional"` attribute in the registry schema
document (public issue 769)
* Fix links in <<VK_NVX_raytracing>> extension (public pull request 805).
* Mark the <<VK_KHR_mir_surface>> extension obsolete (see public issue 814
- does not close this, however).
* Fix missing endif in Image Creation block (public issue 817).
Internal Issues:
* Clarify that the compressed texture formats corresponding to
<<features-features-textureCompressionETC2>>,
<<features-features-textureCompressionASTC_LDR>>, and
<<features-features-textureCompressionBC>> is not contingent on the
feature bits, and may be supported even if the features are not enabled
(internal issue 663).
* Clarify that code:FragStencilRefEXT is output only in the
<<interfaces-builtin-variables, Built-In Variables>> section (internal
issue 1173).
* Identify and correct many overly-aggressive uses of "`undefined`", and
narrow them down, where straightforward to do so. Mark such resolved
uses of "`undefined`" with the custom undefined: macro. Add a new
<<writing-undefined, Describing Undefined Behavior>> section (internal
issue 1267).
* Don't require code:inline_uniform_block descriptors to be populated
before use in the flink:vkAllocateDescriptorSets section (internal issue
1380).
* Allow suppressing inline SVG images by controlling this with an
attribute set in the Makefile, rather than the explicit [%inline]
directive (internal issue 1391).
* Mark 'Khronos' as a registered trademark in several places, now that it
is one.
* Fix typo in the <<VK_KHR_shader_atomic_int64>> appendix using the GLSL
naming of the compare exchange op when referring to the SPIR-V op.
* Specify in the flink:vkGetPhysicalDeviceQueueFamilyProperties section
that all implementations must support at least one queue family, and
that every queue family must contain at least one queue.
* Make slink:VkPipelineDynamicStateCreateInfo::pname:dynamicStateCount,
slink:VkSampleLocationsInfoEXT::pname:sampleLocationsPerPixel, and
slink:VkSampleLocationsInfoEXT::pname:sampleLocationsCount optional, to
fix bogus implicit valid usage checks that were causing failures in the
conformance tests.
* Fix vendor tag in reserved extension 237 constants. Does not affect
anything since it's just a placeholder, but this should avoid further
comments.
* Minor markup fixes in some extension appendices.
New Extensions:
* `<<VK_FUCHSIA_imagepipe_surface>>`
2018-10-07 13:10:21 +00:00
|
|
|
thus results in undefined: behavior.
|
2017-11-27 09:07:06 +00:00
|
|
|
|
|
|
|
4) Is flink:vkMapMemory expected to return the same host address which was
|
|
|
|
specified when importing it to the memory object?
|
|
|
|
|
|
|
|
RESOLVED: No.
|
|
|
|
Implementations are allowed to return the same address but it's not
|
|
|
|
required.
|
|
|
|
Some implementations might return a different virtual mapping of the
|
|
|
|
allocation, although the same physical pages will be used.
|
|
|
|
|
|
|
|
5) Is there any limitation on the alignment of the host pointer and/or size?
|
|
|
|
|
|
|
|
RESOLVED: Yes.
|
|
|
|
Both the address and the size have to be an integer multiple of
|
|
|
|
pname:minImportedHostPointerAlignment.
|
|
|
|
In addition, some platforms and foreign devices may have additional
|
|
|
|
restrictions.
|
|
|
|
|
|
|
|
6) Can the same host allocation be imported multiple times into a given
|
|
|
|
physical device?
|
|
|
|
|
|
|
|
RESOLVED: No, at least not guaranteed by this extension.
|
|
|
|
Some platforms do not allow locking the same physical pages for device
|
Change log for October 7, 2018 Vulkan 1.1.87 spec update:
* Update release number to 87.
Public Issues:
* Merge flink:vkCmdPipelineBarrier self-dependency barrier VUs referring
to the same subpass dependency (public pull request 756).
* Describe default value of `"optional"` attribute in the registry schema
document (public issue 769)
* Fix links in <<VK_NVX_raytracing>> extension (public pull request 805).
* Mark the <<VK_KHR_mir_surface>> extension obsolete (see public issue 814
- does not close this, however).
* Fix missing endif in Image Creation block (public issue 817).
Internal Issues:
* Clarify that the compressed texture formats corresponding to
<<features-features-textureCompressionETC2>>,
<<features-features-textureCompressionASTC_LDR>>, and
<<features-features-textureCompressionBC>> is not contingent on the
feature bits, and may be supported even if the features are not enabled
(internal issue 663).
* Clarify that code:FragStencilRefEXT is output only in the
<<interfaces-builtin-variables, Built-In Variables>> section (internal
issue 1173).
* Identify and correct many overly-aggressive uses of "`undefined`", and
narrow them down, where straightforward to do so. Mark such resolved
uses of "`undefined`" with the custom undefined: macro. Add a new
<<writing-undefined, Describing Undefined Behavior>> section (internal
issue 1267).
* Don't require code:inline_uniform_block descriptors to be populated
before use in the flink:vkAllocateDescriptorSets section (internal issue
1380).
* Allow suppressing inline SVG images by controlling this with an
attribute set in the Makefile, rather than the explicit [%inline]
directive (internal issue 1391).
* Mark 'Khronos' as a registered trademark in several places, now that it
is one.
* Fix typo in the <<VK_KHR_shader_atomic_int64>> appendix using the GLSL
naming of the compare exchange op when referring to the SPIR-V op.
* Specify in the flink:vkGetPhysicalDeviceQueueFamilyProperties section
that all implementations must support at least one queue family, and
that every queue family must contain at least one queue.
* Make slink:VkPipelineDynamicStateCreateInfo::pname:dynamicStateCount,
slink:VkSampleLocationsInfoEXT::pname:sampleLocationsPerPixel, and
slink:VkSampleLocationsInfoEXT::pname:sampleLocationsCount optional, to
fix bogus implicit valid usage checks that were causing failures in the
conformance tests.
* Fix vendor tag in reserved extension 237 constants. Does not affect
anything since it's just a placeholder, but this should avoid further
comments.
* Minor markup fixes in some extension appendices.
New Extensions:
* `<<VK_FUCHSIA_imagepipe_surface>>`
2018-10-07 13:10:21 +00:00
|
|
|
access multiple times, so attempting to do it may result in undefined:
|
2017-11-27 09:07:06 +00:00
|
|
|
behavior.
|
|
|
|
|
|
|
|
7) Does this extension support exporting the new handle type?
|
|
|
|
|
|
|
|
RESOLVED: No.
|
|
|
|
|
|
|
|
8) Should we include the possibility to import host mapped foreign device
|
|
|
|
memory using this API?
|
|
|
|
|
|
|
|
RESOLVED: Yes, through a separate handle type.
|
|
|
|
Implementations are still allowed to support only one of the handle types
|
|
|
|
introduced by this extension by not returning import support for a
|
|
|
|
particular handle type as returned in slink:VkExternalMemoryPropertiesKHR.
|
|
|
|
|
|
|
|
=== Version History
|
|
|
|
|
|
|
|
* Revision 1, 2017-11-10 (Daniel Rakos)
|
|
|
|
- Internal revisions
|