aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/yuzu/vk_device_info.cpp
diff options
context:
space:
mode:
authorlat9nq <[email protected]>2023-05-28 21:46:02 +0000
committerlat9nq <[email protected]>2023-06-06 01:54:44 -0400
commitfc0c4db20d4161984a960a689afa0a08a5a4b401 (patch)
tree9271e436b5bbb08ea4d642a44aa50f788b6789e8 /src/yuzu/vk_device_info.cpp
parent069d7e6be4faa6d10f7e2dd3765d93f925aa2f25 (diff)
downloadyuzu-mainline-fc0c4db20d4161984a960a689afa0a08a5a4b401.tar.gz
yuzu-mainline-fc0c4db20d4161984a960a689afa0a08a5a4b401.zip
yuzu-qt: Load Vulkan device info at startup
Loading it when the configuration opens now incurs a noticeable delay. We also don't need to rediscover the same data repeatedly each time the configuration opens. Moves vulkan device info discovery to yuzu's startup as opposed to the configure_graphics constructor.
Diffstat (limited to 'src/yuzu/vk_device_info.cpp')
-rw-r--r--src/yuzu/vk_device_info.cpp53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/yuzu/vk_device_info.cpp b/src/yuzu/vk_device_info.cpp
new file mode 100644
index 000000000..2b967e4b8
--- /dev/null
+++ b/src/yuzu/vk_device_info.cpp
@@ -0,0 +1,53 @@
+#include "video_core/vulkan_common/vulkan_device.h"
+
+#include <vector>
+#include "common/dynamic_library.h"
+#include "video_core/vulkan_common/vulkan_instance.h"
+#include "video_core/vulkan_common/vulkan_library.h"
+#include "video_core/vulkan_common/vulkan_surface.h"
+#include "video_core/vulkan_common/vulkan_wrapper.h"
+#include "yuzu/qt_common.h"
+#include "yuzu/vk_device_info.h"
+
+namespace VkDeviceInfo {
+Record::Record(std::string_view name_, const std::vector<VkPresentModeKHR>& vsync_modes_,
+ bool is_intel_proprietary_)
+ : name{name_}, vsync_support{vsync_modes_}, is_intel_proprietary{is_intel_proprietary_} {}
+
+Record::~Record() = default;
+
+void PopulateRecords(std::vector<Record>& records, QWindow* window) try {
+ using namespace Vulkan;
+
+ auto wsi = QtCommon::GetWindowSystemInfo(window);
+
+ vk::InstanceDispatch dld;
+ const auto library = OpenLibrary();
+ const vk::Instance instance = CreateInstance(*library, dld, VK_API_VERSION_1_1, wsi.type);
+ const std::vector<VkPhysicalDevice> physical_devices = instance.EnumeratePhysicalDevices();
+ vk::SurfaceKHR surface = CreateSurface(instance, wsi);
+
+ records.clear();
+ records.reserve(physical_devices.size());
+ for (const VkPhysicalDevice device : physical_devices) {
+ const auto physical_device = vk::PhysicalDevice(device, dld);
+ const std::string name = physical_device.GetProperties().deviceName;
+ const std::vector<VkPresentModeKHR> present_modes =
+ physical_device.GetSurfacePresentModesKHR(*surface);
+
+ VkPhysicalDeviceDriverProperties driver_properties{};
+ driver_properties.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DRIVER_PROPERTIES;
+ driver_properties.pNext = nullptr;
+ VkPhysicalDeviceProperties2 properties{};
+ properties.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR;
+ properties.pNext = &driver_properties;
+ dld.vkGetPhysicalDeviceProperties2(physical_device, &properties);
+
+ records.push_back(VkDeviceInfo::Record(name, present_modes,
+ driver_properties.driverID ==
+ VK_DRIVER_ID_INTEL_PROPRIETARY_WINDOWS));
+ }
+} catch (const Vulkan::vk::Exception& exception) {
+ LOG_ERROR(Frontend, "Failed to enumerate devices with error: {}", exception.what());
+}
+} // namespace VkDeviceInfo