Copyright (c) 2021-2023 LunarG, Inc.
The Vulkan Profiles Toolset is a collection of components for Vulkan application developers to build portable Vulkan applications using Vulkan Profiles.
Vulkan Profiles have multiple use cases, including:
- Roadmap profiles: To express guidance on the future direction of Vulkan devices.
- Platform profiles: To express the Vulkan support available on different platforms.
- Device profiles: To express the Vulkan support of a single Vulkan driver for a Vulkan device.
- Engine profiles: To express some rendering code paths requirements of an engine.
- Etc.
Conceptually, Vulkan Profiles can be understood as the explicit expression and formalization of Vulkan requirements and provides clear communication of these requirements within the Vulkan Community.
The Vulkan Profiles Toolset delivered in the Vulkan SDK.
The Vulkan Profiles Toolset includes the following components:
- The Vulkan Profiles JSON Schema
- A data format to exchange Vulkan capabilities: extensions, features, properties, formats and queue properties.
- Each revision of Vulkan API is represented by a schema that supersedes older versions of Vulkan API.
- The schema covers Vulkan 1.3 and all extensions.
- The Vulkan Profiles JSON file generation
- A
Python
script to generate profiles file by combining multiple exist profiles files. - It supports both
union
andintersection
of Vulkan capabilities.
- A
- The Vulkan Profiles API library
- A header-only C++ library to use Vulkan Profiles in Vulkan applications.
- The library allows checking Profiles support on a device and creating a
VkDevice
instance with the profile features and extensions enabled. - The library requires a Vulkan 1.0 driver that supports
VK_KHR_get_physical_device_properties2
extension.
- The Vulkan Profiles Layer
- A layer used during application development to ensure adherence to the requirements of a chosen Vulkan Profile.
- It simulates but doesn't emulate Vulkan capabilities. Hence, it is used with the Validation layer to clamp available capabilities on the Vulkan developer system.
- The layer requires a Vulkan 1.1 driver.
- The Vulkan Profiles Comparison Table
- Human-readable format of Vulkan Profiles in a table to enable comparison.
Furthermore, the Vulkan SDK includes implementations of some Vulkan Profiles using the Vulkan Profiles JSON Schema:
- VP_KHR_roadmap_2024 (Vulkan 1.3)
- VP_KHR_roadmap_2022 (Vulkan 1.3)
- VP_ANDROID_baseline_2022 (Vulkan 1.1)
- VP_ANDROID_baseline_2021 (Vulkan 1.0)
- VP_LUNARG_desktop_baseline_2024 (Vulkan 1.2)
- VP_LUNARG_desktop_baseline_2023 (Vulkan 1.2)
- VP_LUNARG_desktop_baseline_2022 (Vulkan 1.1)
The VP_LUNARG_desktop_baseline
profiles are created as examples of Platform profiles. Vulkan application developers should create Platform profiles dedicated to their Vulkan applications that match the ecosystem of devices they want the Vulkan applications to run on.
Within the Vulkan SDK, the Vulkan Profiles files are located at $(VULKAN_SDK)/Config/VK_LAYER_KHRONOS_profiles
.
Considering the complexity of the Vulkan ecosystem, there isn't a single Vulkan Profile that can fit all needs. As a result, on top of the predefined Vulkan Profiles, the Vulkan Profiles Toolset solution is designed around the idea of code generation.
The Vulkan Profiles Toolset is generated against vk.xml
(the canonical representation of the Vulkan specification) and Vulkan Profiles.
This design guarantees that any Vulkan developer can regenerate the entire Vulkan Profiles Toolset solution with any new Vulkan Header update or any set of Vulkan Profiles.
The following diagram shows the Vulkan Profiles Toolset generation pipeline with every produced components:
Note: The Profiles layer is not yet code-generated but it will be in the future.
The Profiles layer builds its internal data tables by querying the capabilities of the underlying actual device, then applying the selected Vulkan Profile "on top of" of those tables. Therefore we only need to specify the features we wish to modify from the actual device; tweaking a single feature is easy. Here's an example of a valid Vulkan Profiles file for changing only the maximum permitted viewport size:
{
"$schema": "https://schema.khronos.org/vulkan/profiles-0.8.2-280.json#",
"capabilities": {
"baseline": {
"extensions": {},
"features": {},
"properties": {
"VkPhysicalDeviceProperties": {
"limits": {
"maxViewportDimensions": [ 4096, 2048 ],
}
}
},
"formats": {},
"queueFamiliesProperties": []
}
},
"profiles": {
"VP_LUNARG_example": {
"version": 1,
"api-version": "1.2.198",
"status": "STABLE",
"label": "LunarG Example Profile",
"description": "An example profile used for the overview documentation",
"capabilities": [
"baseline"
]
}
},
"contributors": {
"A Person": {
"company": "LunarG",
"email": "[email protected]",
"github": "lunarg",
"contact": true
}
},
"history": [
{
"revision": 1,
"date": "2021-12-08",
"author": "A Person",
"comment": "Initial revision"
}
]
}
The top-level sections of such profiles files are processed as follows:
$schema
- Required. Must be theURI
string referencing the JSON schema.capabilities
- Required. Specifies the list of capabilities sets.profiles
- Required. Specifies the list of profile definitions.contributors
- Optional. The list of contributors of the profile file.history
- Optional. The version history of the profile file.
Each entry in capabilities
includes a reference name and a dictionary containing the following sections:
extensions
- Optional. List of all required extensions.features
- Optional. List of all required features.properties
- Optional. List of all required properties.formats
- Optional. List of all required formats.queueFamiliesProperties
- Optional. List of all queue families properties.videoProfiles
- Optional. List of all required video profilies.
Each entry in profiles
includes a reference name and a dictionary containing the following sections:
version
- Required. The revision of the profile.api-version
- Required. The Vulkan API version against which the profile is written.status
- Optional. The development stage of the profile. It can be eitherALPHA
,BETA
,STABLE
orDEPRECATED
.label
- Required. The label used to present the profile to the Vulkan developer.description
- Required. The description of the profile.contributors
- Optional. The list of contributors of the profile.history
- Optional. The version history of the profile.profiles
- Optional. The list of profiles required by the profile.capabilities
- Required. The list of capability sets that can be referenced by a profile.fallback
- Optional. The list of profiles recommended if the checked profile is not supported by the platform.
profiles
may reference multiple capabilities
which may define the same capability differently. In this case, the rule is that the last reference of that capability overrides any previously set values.
The Vulkan Profiles Toolset includes a Python
script to generate a profiles file by combining multiple profiles files using two modes :
- Intersection of Vulkan Capabilities
- Union of Vulkan Capabilities
GPUInfo.org allows us downloading device
profiles in the form of JSON files. We can use these files to create platform profiles.
This is the approach used to create the VP_LUNARG_desktop_baseline_2024
profiles part of this repository.
Example:
python gen_profiles_file.py --registry vk.xml --input ./VP_LUNARG_desktop_baseline_2024
For more information about the command line arguments, please use the --help
argument :
python ./script/gen_profiles_file.py --help
The JSON schema allows validating that the profiles JSON file is correctly defined. This can be done by many tools including the following web-based validators: