st/oxr: Make VK_KHR_external_[fence|semaphore]_fd optional

Only for XR_KHR_vulkan_enable2, harder to do for XR_KHR_vulkan_enable.
This commit is contained in:
Jakob Bornecrantz 2022-05-08 13:48:56 +01:00 committed by Christoph Haag
parent 8945153bc9
commit e93b1c61ff
3 changed files with 63 additions and 6 deletions

View file

@ -1198,6 +1198,8 @@ struct oxr_system
struct struct
{ {
// No better place to keep this state. // No better place to keep this state.
bool external_fence_fd_enabled;
bool external_semaphore_fd_enabled;
bool timeline_semaphore_enabled; bool timeline_semaphore_enabled;
} vk; } vk;

View file

@ -13,6 +13,7 @@
#endif #endif
#include "xrt/xrt_instance.h" #include "xrt/xrt_instance.h"
#include "xrt/xrt_handles.h"
#include "xrt/xrt_gfx_vk.h" #include "xrt/xrt_gfx_vk.h"
#include "util/u_misc.h" #include "util/u_misc.h"
@ -78,6 +79,24 @@ oxr_session_populate_vk(struct oxr_logger *log,
struct oxr_session *sess) struct oxr_session *sess)
{ {
bool timeline_semaphore_enabled = sess->sys->vk.timeline_semaphore_enabled; bool timeline_semaphore_enabled = sess->sys->vk.timeline_semaphore_enabled;
bool external_fence_fd_enabled = sess->sys->vk.external_fence_fd_enabled;
bool external_semaphore_fd_enabled = sess->sys->vk.external_semaphore_fd_enabled;
#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
if (sys->inst->extensions.KHR_vulkan_enable && sys->inst->extensions.KHR_vulkan_enable2 &&
!external_fence_fd_enabled && !external_semaphore_fd_enabled) {
oxr_warn(log,
"Both KHR_vulkan_enable and KHR_vulkan_enable2 are enabled can not safely determine if "
"external fence|semaphore FD has been enabled assuming yes.");
external_fence_fd_enabled = true;
external_semaphore_fd_enabled = true;
} else if (sys->inst->extensions.KHR_vulkan_enable) {
// We always return these extensions as required for version 1.
external_fence_fd_enabled = true;
external_semaphore_fd_enabled = true;
}
#endif
if (!timeline_semaphore_enabled && if (!timeline_semaphore_enabled &&
check_for_layer_mnd_enable_timeline_semaphore(log, next->instance, next->physicalDevice)) { check_for_layer_mnd_enable_timeline_semaphore(log, next->instance, next->physicalDevice)) {
@ -97,8 +116,8 @@ oxr_session_populate_vk(struct oxr_logger *log,
vkGetInstanceProcAddr, // vkGetInstanceProcAddr, //
next->physicalDevice, // next->physicalDevice, //
next->device, // next->device, //
true, // external_fence_fd_enabled external_fence_fd_enabled, //
true, // external_semaphore_fd_enabled external_semaphore_fd_enabled, //
timeline_semaphore_enabled, // timeline_semaphore_enabled, //
next->queueFamilyIndex, // next->queueFamilyIndex, //
next->queueIndex); // next->queueIndex); //

View file

@ -134,8 +134,7 @@ static const char *required_vk_device_extensions[] = {
#endif #endif
// Platform version of "external_fence" and "external_semaphore" // Platform version of "external_fence" and "external_semaphore"
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD) #if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD) // Optional
VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME, VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME,
#elif defined(XRT_GRAPHICS_SYNC_HANDLE_IS_WIN32_HANDLE) #elif defined(XRT_GRAPHICS_SYNC_HANDLE_IS_WIN32_HANDLE)
VK_KHR_EXTERNAL_SEMAPHORE_WIN32_EXTENSION_NAME, VK_KHR_EXTERNAL_SEMAPHORE_WIN32_EXTENSION_NAME,
@ -147,6 +146,16 @@ static const char *required_vk_device_extensions[] = {
}; };
static const char *optional_device_extensions[] = { static const char *optional_device_extensions[] = {
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME,
VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME,
#elif defined(XRT_GRAPHICS_SYNC_HANDLE_IS_WIN32_HANDLE) // Not optional
#else
#error "Need port!"
#endif
#ifdef VK_KHR_timeline_semaphore #ifdef VK_KHR_timeline_semaphore
VK_KHR_TIMELINE_SEMAPHORE_EXTENSION_NAME, VK_KHR_TIMELINE_SEMAPHORE_EXTENSION_NAME,
#else #else
@ -317,11 +326,27 @@ oxr_vk_create_vulkan_device(struct oxr_logger *log,
return res; return res;
} }
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
bool external_fence_fd_enabled = false;
bool external_semaphore_fd_enabled = false;
#endif
for (uint32_t i = 0; i < ARRAY_SIZE(optional_device_extensions); i++) { for (uint32_t i = 0; i < ARRAY_SIZE(optional_device_extensions); i++) {
if (optional_device_extensions[i] && if (optional_device_extensions[i] &&
vk_check_extension(props, prop_count, optional_device_extensions[i])) { !vk_check_extension(props, prop_count, optional_device_extensions[i])) {
u_string_list_append_unique(device_extension_list, optional_device_extensions[i]); continue;
} }
u_string_list_append_unique(device_extension_list, optional_device_extensions[i]);
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
if (strcmp(optional_device_extensions[i], VK_KHR_EXTERNAL_FENCE_FD_EXTENSION_NAME) == 0) {
external_fence_fd_enabled = true;
}
if (strcmp(optional_device_extensions[i], VK_KHR_EXTERNAL_SEMAPHORE_FD_EXTENSION_NAME) == 0) {
external_semaphore_fd_enabled = true;
}
#endif
} }
free(props); free(props);
@ -384,6 +409,10 @@ oxr_vk_create_vulkan_device(struct oxr_logger *log,
oxr_slog(&slog, "\n\tresult: %s", vk_result_string(*vulkanResult)); oxr_slog(&slog, "\n\tresult: %s", vk_result_string(*vulkanResult));
oxr_slog(&slog, "\n\tvulkanDevice: 0x%" PRIx64, (uint64_t)(intptr_t)*vulkanDevice); oxr_slog(&slog, "\n\tvulkanDevice: 0x%" PRIx64, (uint64_t)(intptr_t)*vulkanDevice);
oxr_slog(&slog, "\n\tvulkanInstance: 0x%" PRIx64, (uint64_t)(intptr_t)sys->vulkan_enable2_instance); oxr_slog(&slog, "\n\tvulkanInstance: 0x%" PRIx64, (uint64_t)(intptr_t)sys->vulkan_enable2_instance);
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
oxr_slog(&slog, "\n\texternal_fence_fd: %s", external_fence_fd_enabled ? "true" : "false");
oxr_slog(&slog, "\n\texternal_semaphore_fd: %s", external_semaphore_fd_enabled ? "true" : "false");
#endif
#ifdef VK_KHR_timeline_semaphore #ifdef VK_KHR_timeline_semaphore
oxr_slog(&slog, "\n\ttimelineSemaphore: %s", oxr_slog(&slog, "\n\ttimelineSemaphore: %s",
timeline_semaphore_info.timelineSemaphore ? "true" : "false"); timeline_semaphore_info.timelineSemaphore ? "true" : "false");
@ -396,6 +425,13 @@ oxr_vk_create_vulkan_device(struct oxr_logger *log,
oxr_log_slog(log, &slog); oxr_log_slog(log, &slog);
} }
#if defined(XRT_GRAPHICS_SYNC_HANDLE_IS_FD)
if (*vulkanResult == VK_SUCCESS) {
sys->vk.external_fence_fd_enabled = external_fence_fd_enabled;
sys->vk.external_semaphore_fd_enabled = external_semaphore_fd_enabled;
}
#endif
#ifdef VK_KHR_timeline_semaphore #ifdef VK_KHR_timeline_semaphore
// Have timeline semaphores added and as such enabled. // Have timeline semaphores added and as such enabled.
if (*vulkanResult == VK_SUCCESS) { if (*vulkanResult == VK_SUCCESS) {