|
|
|
@ -38,9 +38,8 @@ vk::SurfaceKHR CreateSurface( |
|
|
|
.flags = 0, |
|
|
|
.pLayer = static_cast<const CAMetalLayer*>(window_info.render_surface), |
|
|
|
}; |
|
|
|
const auto vkCreateMetalSurfaceEXT = reinterpret_cast<PFN_vkCreateMetalSurfaceEXT>(dld.vkGetInstanceProcAddr(*instance, "vkCreateMetalSurfaceEXT")); |
|
|
|
const auto vkCreateMetalSurfaceEXT = PFN_vkCreateMetalSurfaceEXT(dld.vkGetInstanceProcAddr(*instance, "vkCreateMetalSurfaceEXT")); |
|
|
|
if (!vkCreateMetalSurfaceEXT || vkCreateMetalSurfaceEXT(*instance, &metal_ci, nullptr, &unsafe_surface) != VK_SUCCESS) { |
|
|
|
#if 0
|
|
|
|
// TODO: Way to fallback? - where's my vulkan headers
|
|
|
|
// Attempt to make a macOS surface instead then...
|
|
|
|
// This is the deprecated VkMacOSSurfaceCreateInfoMVK(3) version; but should work if the above failed
|
|
|
|
@ -51,14 +50,12 @@ vk::SurfaceKHR CreateSurface( |
|
|
|
.flags = 0, |
|
|
|
.pView = static_cast<const void*>(window_info.render_surface), |
|
|
|
}; |
|
|
|
const auto vkCreateMacOSSurfaceMVK = reinterpret_cast<PFN_vkCreateMacOSSurfaceMVK>(dld.vkGetInstanceProcAddr(*instance, "vkCreateMacOSSurfaceMVK")); |
|
|
|
const auto vkCreateMacOSSurfaceMVK = PFN_vkCreateMacOSSurfaceMVK(dld.vkGetInstanceProcAddr(*instance, "vkCreateMacOSSurfaceMVK")); |
|
|
|
if (!vkCreateMacOSSurfaceMVK || vkCreateMacOSSurfaceMVK(*instance, &macos_legacy_ci, nullptr, &unsafe_surface) != VK_SUCCESS) { |
|
|
|
LOG_ERROR(Render_Vulkan, "Failed to initialize Metal/macOS surface"); |
|
|
|
throw vk::Exception(VK_ERROR_INITIALIZATION_FAILED); |
|
|
|
} |
|
|
|
#endif
|
|
|
|
LOG_ERROR(Render_Vulkan, "Failed to initialize Metal/macOS surface"); |
|
|
|
throw vk::Exception(VK_ERROR_INITIALIZATION_FAILED); |
|
|
|
} |
|
|
|
} |
|
|
|
#elif defined(__ANDROID__)
|
|
|
|
|