forked from eden-emu/eden
		
	Merge pull request #10974 from Steveice10/macos_vk
vulkan: Improvements to macOS surface creation
This commit is contained in:
		
						commit
						ae7e9b5469
					
				
					 5 changed files with 23 additions and 16 deletions
				
			
		|  | @ -19,11 +19,9 @@ | |||
| #include <windows.h> | ||||
| // ensure include order
 | ||||
| #include <vulkan/vulkan_win32.h> | ||||
| #elif defined(__APPLE__) | ||||
| #include <vulkan/vulkan_macos.h> | ||||
| #elif defined(__ANDROID__) | ||||
| #include <vulkan/vulkan_android.h> | ||||
| #else | ||||
| #elif !defined(__APPLE__) | ||||
| #include <X11/Xlib.h> | ||||
| #include <vulkan/vulkan_wayland.h> | ||||
| #include <vulkan/vulkan_xlib.h> | ||||
|  | @ -68,7 +66,7 @@ namespace { | |||
|         break; | ||||
| #elif defined(__APPLE__) | ||||
|     case Core::Frontend::WindowSystemType::Cocoa: | ||||
|         extensions.push_back(VK_MVK_MACOS_SURFACE_EXTENSION_NAME); | ||||
|         extensions.push_back(VK_EXT_METAL_SURFACE_EXTENSION_NAME); | ||||
|         break; | ||||
| #elif defined(__ANDROID__) | ||||
|     case Core::Frontend::WindowSystemType::Android: | ||||
|  |  | |||
|  | @ -11,11 +11,9 @@ | |||
| #include <windows.h> | ||||
| // ensure include order
 | ||||
| #include <vulkan/vulkan_win32.h> | ||||
| #elif defined(__APPLE__) | ||||
| #include <vulkan/vulkan_macos.h> | ||||
| #elif defined(__ANDROID__) | ||||
| #include <vulkan/vulkan_android.h> | ||||
| #else | ||||
| #elif !defined(__APPLE__) | ||||
| #include <X11/Xlib.h> | ||||
| #include <vulkan/vulkan_wayland.h> | ||||
| #include <vulkan/vulkan_xlib.h> | ||||
|  | @ -44,12 +42,13 @@ vk::SurfaceKHR CreateSurface( | |||
|     } | ||||
| #elif defined(__APPLE__) | ||||
|     if (window_info.type == Core::Frontend::WindowSystemType::Cocoa) { | ||||
|         const VkMacOSSurfaceCreateInfoMVK mvk_ci{VK_STRUCTURE_TYPE_MACOS_SURFACE_CREATE_INFO_MVK, | ||||
|                                                  nullptr, 0, window_info.render_surface}; | ||||
|         const auto vkCreateMacOSSurfaceMVK = reinterpret_cast<PFN_vkCreateMacOSSurfaceMVK>( | ||||
|             dld.vkGetInstanceProcAddr(*instance, "vkCreateMacOSSurfaceMVK")); | ||||
|         if (!vkCreateMacOSSurfaceMVK || | ||||
|             vkCreateMacOSSurfaceMVK(*instance, &mvk_ci, nullptr, &unsafe_surface) != VK_SUCCESS) { | ||||
|         const VkMetalSurfaceCreateInfoEXT macos_ci = { | ||||
|             .pLayer = static_cast<const CAMetalLayer*>(window_info.render_surface), | ||||
|         }; | ||||
|         const auto vkCreateMetalSurfaceEXT = reinterpret_cast<PFN_vkCreateMetalSurfaceEXT>( | ||||
|             dld.vkGetInstanceProcAddr(*instance, "vkCreateMetalSurfaceEXT")); | ||||
|         if (!vkCreateMetalSurfaceEXT || | ||||
|             vkCreateMetalSurfaceEXT(*instance, &macos_ci, nullptr, &unsafe_surface) != VK_SUCCESS) { | ||||
|             LOG_ERROR(Render_Vulkan, "Failed to initialize Metal surface"); | ||||
|             throw vk::Exception(VK_ERROR_INITIALIZATION_FAILED); | ||||
|         } | ||||
|  |  | |||
|  | @ -15,6 +15,8 @@ | |||
| #define VK_NO_PROTOTYPES | ||||
| #ifdef _WIN32 | ||||
| #define VK_USE_PLATFORM_WIN32_KHR | ||||
| #elif defined(__APPLE__) | ||||
| #define VK_USE_PLATFORM_METAL_EXT | ||||
| #endif | ||||
| #include <vulkan/vulkan.h> | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,6 +10,8 @@ | |||
| 
 | ||||
| #if !defined(WIN32) && !defined(__APPLE__) | ||||
| #include <qpa/qplatformnativeinterface.h> | ||||
| #elif defined(__APPLE__) | ||||
| #include <objc/message.h> | ||||
| #endif | ||||
| 
 | ||||
| namespace QtCommon { | ||||
|  | @ -37,9 +39,12 @@ Core::Frontend::EmuWindow::WindowSystemInfo GetWindowSystemInfo(QWindow* window) | |||
|     Core::Frontend::EmuWindow::WindowSystemInfo wsi; | ||||
|     wsi.type = GetWindowSystemType(); | ||||
| 
 | ||||
| #if defined(WIN32) | ||||
|     // Our Win32 Qt external doesn't have the private API.
 | ||||
| #if defined(WIN32) || defined(__APPLE__) | ||||
|     wsi.render_surface = window ? reinterpret_cast<void*>(window->winId()) : nullptr; | ||||
|     wsi.render_surface = reinterpret_cast<void*>(window->winId()); | ||||
| #elif defined(__APPLE__) | ||||
|     wsi.render_surface = reinterpret_cast<void* (*)(id, SEL)>(objc_msgSend)( | ||||
|         reinterpret_cast<id>(window->winId()), sel_registerName("layer")); | ||||
| #else | ||||
|     QPlatformNativeInterface* pni = QGuiApplication::platformNativeInterface(); | ||||
|     wsi.display_connection = pni->nativeResourceForWindow("display", window); | ||||
|  |  | |||
|  | @ -26,7 +26,10 @@ Record::~Record() = default; | |||
| void PopulateRecords(std::vector<Record>& records, QWindow* window) try { | ||||
|     using namespace Vulkan; | ||||
| 
 | ||||
|     auto wsi = QtCommon::GetWindowSystemInfo(window); | ||||
|     // Create a test window with a Vulkan surface type for checking present modes.
 | ||||
|     QWindow test_window(window); | ||||
|     test_window.setSurfaceType(QWindow::VulkanSurface); | ||||
|     auto wsi = QtCommon::GetWindowSystemInfo(&test_window); | ||||
| 
 | ||||
|     vk::InstanceDispatch dld; | ||||
|     const auto library = OpenLibrary(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 liamwhite
						liamwhite