Merge "[vulkan] Merge in tag sdk-1.2.148.1"
diff --git a/fuchsia/loader_extensions.c b/fuchsia/loader_extensions.c
index f82ffa2..bc9c6fb 100644
--- a/fuchsia/loader_extensions.c
+++ b/fuchsia/loader_extensions.c
@@ -35,10 +35,33 @@
}
}
+typedef VkResult(VKAPI_PTR *PFN_vkOpenInNamespaceAddr)(const char *pName, uint32_t handle);
+typedef PFN_vkVoidFunction(VKAPI_PTR *PFN_vkInitializeOpenInNamespaceCallbackAddr)(PFN_vkOpenInNamespaceAddr);
+
+VKAPI_ATTR static VkResult VKAPI_CALL loader_fdio_open_in_namespace(const char *pName, uint32_t handle) {
+ // fdio_service_connect specifies READ+WRITE, which fails for read-only files
+ zx_status_t status = fdio_open(pName, ZX_FS_RIGHT_READABLE, handle);
+ if (status == ZX_OK) {
+ return VK_SUCCESS;
+ } else {
+ loader_log(NULL, VK_DEBUG_REPORT_WARNING_BIT_EXT, 0, "Failed to open in namespace %s - error %d", pName, status);
+ return VK_ERROR_INITIALIZATION_FAILED;
+ }
+}
+
void loader_initialize_icd_services(loader_platform_dl_handle handle) {
+ PFN_vkInitializeOpenInNamespaceCallbackAddr fp_initialize_open_in_namespace_callback_addr;
+
+ fp_initialize_open_in_namespace_callback_addr =
+ loader_platform_get_proc_address(handle, "vk_icdInitializeOpenInNamespaceCallback");
+ if (fp_initialize_open_in_namespace_callback_addr) {
+ fp_initialize_open_in_namespace_callback_addr(&loader_fdio_open_in_namespace);
+ return;
+ }
+
PFN_vkInitializeConnectToServiceCallbackAddr fp_initialize_connect_to_service_callback_addr;
- // TODO(fxb/60206) - rename since this can be used for opening files
+ // TODO(fxb/60206) - remove
fp_initialize_connect_to_service_callback_addr =
loader_platform_get_proc_address(handle, "vk_icdInitializeConnectToServiceCallback");
if (!fp_initialize_connect_to_service_callback_addr) {