Skip to content

Commit

Permalink
Add VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX
Browse files Browse the repository at this point in the history
to the VK_QNX_external_memory_screen_buffer extension spec additions
  • Loading branch information
aruby-blackberry committed Jun 12, 2023
1 parent 92c045a commit c36e0b3
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 0 deletions.
45 changes: 45 additions & 0 deletions chapters/features.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -3473,6 +3473,51 @@ include::{generated}/validity/structs/VkPhysicalDeviceExternalMemorySciBufFeatur
--
endif::VK_NV_external_memory_sci_buf[]

ifdef::VK_QNX_external_memory_screen_buffer[]
[open,refpage='VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX',desc='Structure describing QNX Screen Buffer features that can be supported by an implementation',type='structs']
--
The sname:VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX structure is
defined as:

include::{generated}/api/structs/VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX.adoc[]

The members of the sname:VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX
structure describe the following features:

* [[features-screenBufferImport]] pname:screenBufferImport indicates whether
QNX Screen buffer import functionality is supported.
If pname:screenBufferImport is set to ename:VK_TRUE, slink:VkDeviceMemory
supports importing code:_screen_buffer from applications.
In this case, the application is responsible for the resource management
of the code:_screen_buffer.

[[features-externalscreenbuffer-table]]
.Functionality supported for QNX Screen Buffer features
|=====
| Features | Functionality
| pname:screenBufferImport | slink:VkImportScreenBufferInfoQNX
| Always supported^1^ | flink:vkGetScreenBufferPropertiesQNX, slink:VkScreenBufferPropertiesQNX, slink:VkScreenBufferFormatPropertiesQNX,
slink:VkExternalFormatQNX
|=====

1::
Functionality in this row is always available.

The <<features-externalscreenbuffer-table, Functionality supported for QNX Screen buffer
features>> table summarizes the functionality enabled by the
sname:VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX structure.
Each entry in the body of the table summarizes the functionality that can:
be used when the given features are supported and enabled.
This summarizes Valid Usage statements that are added elsewhere in this
specification.

:refpage: VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX
include::{chapters}/features.adoc[tag=features]

include::{generated}/validity/structs/VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX.adoc[]
--
endif::VK_QNX_external_memory_screen_buffer[]

ifdef::VK_EXT_index_type_uint8[]
[open,refpage='VkPhysicalDeviceIndexTypeUint8FeaturesEXT',desc='Structure describing whether uint8 index type can be used',type='structs']
--
Expand Down
5 changes: 5 additions & 0 deletions chapters/memory.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -1613,6 +1613,11 @@ ifdef::VK_ANDROID_external_memory_android_hardware_buffer[]
Android hardware buffer's code:AHardwareBuffer_Desc::code:usage
endif::VK_ANDROID_external_memory_android_hardware_buffer[]
ifdef::VK_QNX_external_memory_screen_buffer[]
* If the parameters define an import operation and the external handle
type is
ename:VK_EXTERNAL_MEMORY_HANDLE_TYPE_SCREEN_BUFFER_BIT_QNX,
slink:VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX::pname:screenBufferImport
must: be enabled
* If the parameters define an import operation and the external handle
type is
ename:VK_EXTERNAL_MEMORY_HANDLE_TYPE_SCREEN_BUFFER_BIT_QNX,
Expand Down
7 changes: 7 additions & 0 deletions xml/vk.xml
Original file line number Diff line number Diff line change
Expand Up @@ -8225,6 +8225,11 @@ typedef void* <name>MTLSharedEvent_id</name>;
<member optional="true"><type>void</type>* <name>pNext</name></member>
<member><type>uint64_t</type> <name>externalFormat</name></member>
</type>
<type category="struct" name="VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX" structextends="VkPhysicalDeviceFeatures2,VkDeviceCreateInfo">
<member values="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_SCREEN_BUFFER_FEATURES_QNX"><type>VkStructureType</type> <name>sType</name></member>
<member optional="true"><type>void</type>* <name>pNext</name></member>
<member><type>VkBool32</type> <name>screenBufferImport</name></member>
</type>
</types>


Expand Down Expand Up @@ -22234,10 +22239,12 @@ typedef void* <name>MTLSharedEvent_id</name>;
<enum offset="1" extends="VkStructureType" name="VK_STRUCTURE_TYPE_SCREEN_BUFFER_FORMAT_PROPERTIES_QNX"/>
<enum offset="2" extends="VkStructureType" name="VK_STRUCTURE_TYPE_IMPORT_SCREEN_BUFFER_INFO_QNX"/>
<enum offset="3" extends="VkStructureType" name="VK_STRUCTURE_TYPE_EXTERNAL_FORMAT_QNX"/>
<enum offset="4" extends="VkStructureType" name="VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_EXTERNAL_MEMORY_SCREEN_BUFFER_FEATURES_QNX"/>
<type name="VkScreenBufferPropertiesQNX"/>
<type name="VkScreenBufferFormatPropertiesQNX"/>
<type name="VkImportScreenBufferInfoQNX"/>
<type name="VkExternalFormatQNX"/>
<type name="VkPhysicalDeviceExternalMemoryScreenBufferFeaturesQNX"/>
<command name="vkGetScreenBufferPropertiesQNX"/>
</require>
</extension>
Expand Down

0 comments on commit c36e0b3

Please sign in to comment.