a/vk: Add function to print device features

This commit is contained in:
Jakob Bornecrantz 2022-04-23 23:47:35 +01:00
parent f65a8b1eda
commit 3aa4fdb096
3 changed files with 29 additions and 11 deletions

View file

@ -477,6 +477,13 @@ vk_print_device_info(struct vk_bundle *vk,
uint32_t gpu_index, uint32_t gpu_index,
const char *title); const char *title);
/*!
* Print device features to the logger at the given logging level, if the
* vk_bundle has that level enabled.
*/
void
vk_print_features_info(struct vk_bundle *vk, enum u_logging_level log_level);
/*! /*!
* Print external handle features to the logger at the given logging level, * Print external handle features to the logger at the given logging level,
* if the vk_bundle has that level enabled. * if the vk_bundle has that level enabled.

View file

@ -32,6 +32,15 @@ vk_print_device_info(struct vk_bundle *vk,
VK_VERSION_PATCH(pdp->driverVersion)); VK_VERSION_PATCH(pdp->driverVersion));
} }
void
vk_print_features_info(struct vk_bundle *vk, enum u_logging_level log_level)
{
U_LOG_IFL(log_level, vk->log_level, //
"Features:" //
"\n\ttimeline_semaphore: %s", //
vk->features.timeline_semaphore ? "true" : "false"); //
}
void void
vk_print_external_handles_info(struct vk_bundle *vk, enum u_logging_level log_level) vk_print_external_handles_info(struct vk_bundle *vk, enum u_logging_level log_level)
{ {
@ -45,8 +54,7 @@ vk_print_external_handles_info(struct vk_bundle *vk, enum u_logging_level log_le
vk->external.fence_opaque_fd ? "true" : "false"); // vk->external.fence_opaque_fd ? "true" : "false"); //
U_LOG_IFL(log_level, vk->log_level, // U_LOG_IFL(log_level, vk->log_level, //
"Supported semaphores:\n\t%s: %s\n\t%s: %s\n\t%s: %s\n\t%s: %s\n\t%s: %s", // "Supported semaphores:\n\t%s: %s\n\t%s: %s\n\t%s: %s\n\t%s: %s", //
"features.timeline_semaphore", vk->features.timeline_semaphore ? "true" : "false", //
"VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT(binary)", // "VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_SYNC_FD_BIT(binary)", //
vk->external.binary_semaphore_sync_fd ? "true" : "false", // vk->external.binary_semaphore_sync_fd ? "true" : "false", //
"VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT(binary)", // "VK_EXTERNAL_SEMAPHORE_HANDLE_TYPE_OPAQUE_FD_BIT(binary)", //

View file

@ -217,6 +217,9 @@ create_device(struct vk_bundle *vk, const struct comp_vulkan_arguments *vk_args)
return ret; return ret;
} }
// Print features enabled.
vk_print_features_info(vk, U_LOGGING_INFO);
// Now that we are done debug some used external handles. // Now that we are done debug some used external handles.
vk_print_external_handles_info(vk, U_LOGGING_INFO); vk_print_external_handles_info(vk, U_LOGGING_INFO);