diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/yuzu/configuration/config.cpp | 2 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_dialog.cpp | 3 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_dialog.h | 2 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics.cpp | 23 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics.h | 6 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics_advanced.cpp | 17 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics_advanced.h | 3 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_graphics_advanced.ui | 11 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_per_game.cpp | 3 | ||||
| -rw-r--r-- | src/yuzu/configuration/configure_per_game.h | 2 |
10 files changed, 63 insertions, 9 deletions
diff --git a/src/yuzu/configuration/config.cpp b/src/yuzu/configuration/config.cpp index a85eb4687..b52203ff1 100644 --- a/src/yuzu/configuration/config.cpp +++ b/src/yuzu/configuration/config.cpp | |||
| @@ -714,6 +714,7 @@ void Config::ReadRendererValues() { | |||
| 714 | ReadGlobalSetting(Settings::values.use_asynchronous_shaders); | 714 | ReadGlobalSetting(Settings::values.use_asynchronous_shaders); |
| 715 | ReadGlobalSetting(Settings::values.use_fast_gpu_time); | 715 | ReadGlobalSetting(Settings::values.use_fast_gpu_time); |
| 716 | ReadGlobalSetting(Settings::values.use_vulkan_driver_pipeline_cache); | 716 | ReadGlobalSetting(Settings::values.use_vulkan_driver_pipeline_cache); |
| 717 | ReadGlobalSetting(Settings::values.enable_compute_pipelines); | ||
| 717 | ReadGlobalSetting(Settings::values.bg_red); | 718 | ReadGlobalSetting(Settings::values.bg_red); |
| 718 | ReadGlobalSetting(Settings::values.bg_green); | 719 | ReadGlobalSetting(Settings::values.bg_green); |
| 719 | ReadGlobalSetting(Settings::values.bg_blue); | 720 | ReadGlobalSetting(Settings::values.bg_blue); |
| @@ -1362,6 +1363,7 @@ void Config::SaveRendererValues() { | |||
| 1362 | WriteGlobalSetting(Settings::values.use_asynchronous_shaders); | 1363 | WriteGlobalSetting(Settings::values.use_asynchronous_shaders); |
| 1363 | WriteGlobalSetting(Settings::values.use_fast_gpu_time); | 1364 | WriteGlobalSetting(Settings::values.use_fast_gpu_time); |
| 1364 | WriteGlobalSetting(Settings::values.use_vulkan_driver_pipeline_cache); | 1365 | WriteGlobalSetting(Settings::values.use_vulkan_driver_pipeline_cache); |
| 1366 | WriteGlobalSetting(Settings::values.enable_compute_pipelines); | ||
| 1365 | WriteGlobalSetting(Settings::values.bg_red); | 1367 | WriteGlobalSetting(Settings::values.bg_red); |
| 1366 | WriteGlobalSetting(Settings::values.bg_green); | 1368 | WriteGlobalSetting(Settings::values.bg_green); |
| 1367 | WriteGlobalSetting(Settings::values.bg_blue); | 1369 | WriteGlobalSetting(Settings::values.bg_blue); |
diff --git a/src/yuzu/configuration/configure_dialog.cpp b/src/yuzu/configuration/configure_dialog.cpp index 2aaefcc05..8e76a819a 100644 --- a/src/yuzu/configuration/configure_dialog.cpp +++ b/src/yuzu/configuration/configure_dialog.cpp | |||
| @@ -36,8 +36,9 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry_, | |||
| 36 | debug_tab_tab{std::make_unique<ConfigureDebugTab>(system_, this)}, | 36 | debug_tab_tab{std::make_unique<ConfigureDebugTab>(system_, this)}, |
| 37 | filesystem_tab{std::make_unique<ConfigureFilesystem>(this)}, | 37 | filesystem_tab{std::make_unique<ConfigureFilesystem>(this)}, |
| 38 | general_tab{std::make_unique<ConfigureGeneral>(system_, this)}, | 38 | general_tab{std::make_unique<ConfigureGeneral>(system_, this)}, |
| 39 | graphics_tab{std::make_unique<ConfigureGraphics>(system_, this)}, | ||
| 40 | graphics_advanced_tab{std::make_unique<ConfigureGraphicsAdvanced>(system_, this)}, | 39 | graphics_advanced_tab{std::make_unique<ConfigureGraphicsAdvanced>(system_, this)}, |
| 40 | graphics_tab{std::make_unique<ConfigureGraphics>( | ||
| 41 | system_, [&]() { graphics_advanced_tab->ExposeComputeOption(); }, this)}, | ||
| 41 | hotkeys_tab{std::make_unique<ConfigureHotkeys>(system_.HIDCore(), this)}, | 42 | hotkeys_tab{std::make_unique<ConfigureHotkeys>(system_.HIDCore(), this)}, |
| 42 | input_tab{std::make_unique<ConfigureInput>(system_, this)}, | 43 | input_tab{std::make_unique<ConfigureInput>(system_, this)}, |
| 43 | network_tab{std::make_unique<ConfigureNetwork>(system_, this)}, | 44 | network_tab{std::make_unique<ConfigureNetwork>(system_, this)}, |
diff --git a/src/yuzu/configuration/configure_dialog.h b/src/yuzu/configuration/configure_dialog.h index 1f724834a..a086a07c4 100644 --- a/src/yuzu/configuration/configure_dialog.h +++ b/src/yuzu/configuration/configure_dialog.h | |||
| @@ -72,8 +72,8 @@ private: | |||
| 72 | std::unique_ptr<ConfigureDebugTab> debug_tab_tab; | 72 | std::unique_ptr<ConfigureDebugTab> debug_tab_tab; |
| 73 | std::unique_ptr<ConfigureFilesystem> filesystem_tab; | 73 | std::unique_ptr<ConfigureFilesystem> filesystem_tab; |
| 74 | std::unique_ptr<ConfigureGeneral> general_tab; | 74 | std::unique_ptr<ConfigureGeneral> general_tab; |
| 75 | std::unique_ptr<ConfigureGraphics> graphics_tab; | ||
| 76 | std::unique_ptr<ConfigureGraphicsAdvanced> graphics_advanced_tab; | 75 | std::unique_ptr<ConfigureGraphicsAdvanced> graphics_advanced_tab; |
| 76 | std::unique_ptr<ConfigureGraphics> graphics_tab; | ||
| 77 | std::unique_ptr<ConfigureHotkeys> hotkeys_tab; | 77 | std::unique_ptr<ConfigureHotkeys> hotkeys_tab; |
| 78 | std::unique_ptr<ConfigureInput> input_tab; | 78 | std::unique_ptr<ConfigureInput> input_tab; |
| 79 | std::unique_ptr<ConfigureNetwork> network_tab; | 79 | std::unique_ptr<ConfigureNetwork> network_tab; |
diff --git a/src/yuzu/configuration/configure_graphics.cpp b/src/yuzu/configuration/configure_graphics.cpp index 76e5b7499..f316b598c 100644 --- a/src/yuzu/configuration/configure_graphics.cpp +++ b/src/yuzu/configuration/configure_graphics.cpp | |||
| @@ -2,9 +2,11 @@ | |||
| 2 | // SPDX-License-Identifier: GPL-2.0-or-later | 2 | // SPDX-License-Identifier: GPL-2.0-or-later |
| 3 | 3 | ||
| 4 | // Include this early to include Vulkan headers how we want to | 4 | // Include this early to include Vulkan headers how we want to |
| 5 | #include "video_core/vulkan_common/vulkan_device.h" | ||
| 5 | #include "video_core/vulkan_common/vulkan_wrapper.h" | 6 | #include "video_core/vulkan_common/vulkan_wrapper.h" |
| 6 | 7 | ||
| 7 | #include <algorithm> | 8 | #include <algorithm> |
| 9 | #include <functional> | ||
| 8 | #include <iosfwd> | 10 | #include <iosfwd> |
| 9 | #include <iterator> | 11 | #include <iterator> |
| 10 | #include <string> | 12 | #include <string> |
| @@ -74,8 +76,11 @@ static constexpr Settings::VSyncMode PresentModeToSetting(VkPresentModeKHR mode) | |||
| 74 | } | 76 | } |
| 75 | } | 77 | } |
| 76 | 78 | ||
| 77 | ConfigureGraphics::ConfigureGraphics(const Core::System& system_, QWidget* parent) | 79 | ConfigureGraphics::ConfigureGraphics(const Core::System& system_, |
| 78 | : QWidget(parent), ui{std::make_unique<Ui::ConfigureGraphics>()}, system{system_} { | 80 | const std::function<void()>& expose_compute_option_, |
| 81 | QWidget* parent) | ||
| 82 | : QWidget(parent), ui{std::make_unique<Ui::ConfigureGraphics>()}, | ||
| 83 | expose_compute_option{expose_compute_option_}, system{system_} { | ||
| 79 | vulkan_device = Settings::values.vulkan_device.GetValue(); | 84 | vulkan_device = Settings::values.vulkan_device.GetValue(); |
| 80 | RetrieveVulkanDevices(); | 85 | RetrieveVulkanDevices(); |
| 81 | 86 | ||
| @@ -513,8 +518,7 @@ void ConfigureGraphics::RetrieveVulkanDevices() try { | |||
| 513 | const Common::DynamicLibrary library = OpenLibrary(); | 518 | const Common::DynamicLibrary library = OpenLibrary(); |
| 514 | const vk::Instance instance = CreateInstance(library, dld, VK_API_VERSION_1_1, wsi.type); | 519 | const vk::Instance instance = CreateInstance(library, dld, VK_API_VERSION_1_1, wsi.type); |
| 515 | const std::vector<VkPhysicalDevice> physical_devices = instance.EnumeratePhysicalDevices(); | 520 | const std::vector<VkPhysicalDevice> physical_devices = instance.EnumeratePhysicalDevices(); |
| 516 | vk::SurfaceKHR surface = //< needed to view present modes for a device | 521 | vk::SurfaceKHR surface = CreateSurface(instance, wsi); |
| 517 | CreateSurface(instance, wsi); | ||
| 518 | 522 | ||
| 519 | vulkan_devices.clear(); | 523 | vulkan_devices.clear(); |
| 520 | vulkan_devices.reserve(physical_devices.size()); | 524 | vulkan_devices.reserve(physical_devices.size()); |
| @@ -527,6 +531,17 @@ void ConfigureGraphics::RetrieveVulkanDevices() try { | |||
| 527 | physical_device.GetSurfacePresentModesKHR(*surface); | 531 | physical_device.GetSurfacePresentModesKHR(*surface); |
| 528 | vulkan_devices.push_back(QString::fromStdString(name)); | 532 | vulkan_devices.push_back(QString::fromStdString(name)); |
| 529 | device_present_modes.push_back(present_modes); | 533 | device_present_modes.push_back(present_modes); |
| 534 | |||
| 535 | VkPhysicalDeviceDriverProperties driver_properties{}; | ||
| 536 | driver_properties.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_DRIVER_PROPERTIES; | ||
| 537 | driver_properties.pNext = nullptr; | ||
| 538 | VkPhysicalDeviceProperties2 properties{}; | ||
| 539 | properties.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PROPERTIES_2_KHR; | ||
| 540 | properties.pNext = &driver_properties; | ||
| 541 | dld.vkGetPhysicalDeviceProperties2(physical_device, &properties); | ||
| 542 | if (driver_properties.driverID == VK_DRIVER_ID_INTEL_PROPRIETARY_WINDOWS) { | ||
| 543 | expose_compute_option(); | ||
| 544 | } | ||
| 530 | } | 545 | } |
| 531 | } catch (const Vulkan::vk::Exception& exception) { | 546 | } catch (const Vulkan::vk::Exception& exception) { |
| 532 | LOG_ERROR(Frontend, "Failed to enumerate devices with error: {}", exception.what()); | 547 | LOG_ERROR(Frontend, "Failed to enumerate devices with error: {}", exception.what()); |
diff --git a/src/yuzu/configuration/configure_graphics.h b/src/yuzu/configuration/configure_graphics.h index 901f604a5..364b1cac2 100644 --- a/src/yuzu/configuration/configure_graphics.h +++ b/src/yuzu/configuration/configure_graphics.h | |||
| @@ -3,6 +3,7 @@ | |||
| 3 | 3 | ||
| 4 | #pragma once | 4 | #pragma once |
| 5 | 5 | ||
| 6 | #include <functional> | ||
| 6 | #include <memory> | 7 | #include <memory> |
| 7 | #include <vector> | 8 | #include <vector> |
| 8 | #include <QColor> | 9 | #include <QColor> |
| @@ -37,7 +38,9 @@ class ConfigureGraphics : public QWidget { | |||
| 37 | Q_OBJECT | 38 | Q_OBJECT |
| 38 | 39 | ||
| 39 | public: | 40 | public: |
| 40 | explicit ConfigureGraphics(const Core::System& system_, QWidget* parent = nullptr); | 41 | explicit ConfigureGraphics(const Core::System& system_, |
| 42 | const std::function<void()>& expose_compute_option_, | ||
| 43 | QWidget* parent = nullptr); | ||
| 41 | ~ConfigureGraphics() override; | 44 | ~ConfigureGraphics() override; |
| 42 | 45 | ||
| 43 | void ApplyConfiguration(); | 46 | void ApplyConfiguration(); |
| @@ -81,6 +84,7 @@ private: | |||
| 81 | // selection in the combobox | 84 | // selection in the combobox |
| 82 | u32 vulkan_device{}; | 85 | u32 vulkan_device{}; |
| 83 | Settings::ShaderBackend shader_backend{}; | 86 | Settings::ShaderBackend shader_backend{}; |
| 87 | const std::function<void()>& expose_compute_option; | ||
| 84 | 88 | ||
| 85 | const Core::System& system; | 89 | const Core::System& system; |
| 86 | }; | 90 | }; |
diff --git a/src/yuzu/configuration/configure_graphics_advanced.cpp b/src/yuzu/configuration/configure_graphics_advanced.cpp index 005b022ca..7975285a7 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.cpp +++ b/src/yuzu/configuration/configure_graphics_advanced.cpp | |||
| @@ -12,6 +12,8 @@ ConfigureGraphicsAdvanced::ConfigureGraphicsAdvanced(const Core::System& system_ | |||
| 12 | 12 | ||
| 13 | ui->setupUi(this); | 13 | ui->setupUi(this); |
| 14 | 14 | ||
| 15 | ui->enable_compute_pipelines_checkbox->setVisible(false); | ||
| 16 | |||
| 15 | SetupPerGameUI(); | 17 | SetupPerGameUI(); |
| 16 | 18 | ||
| 17 | SetConfiguration(); | 19 | SetConfiguration(); |
| @@ -26,6 +28,7 @@ void ConfigureGraphicsAdvanced::SetConfiguration() { | |||
| 26 | ui->async_astc->setEnabled(runtime_lock); | 28 | ui->async_astc->setEnabled(runtime_lock); |
| 27 | ui->use_asynchronous_shaders->setEnabled(runtime_lock); | 29 | ui->use_asynchronous_shaders->setEnabled(runtime_lock); |
| 28 | ui->anisotropic_filtering_combobox->setEnabled(runtime_lock); | 30 | ui->anisotropic_filtering_combobox->setEnabled(runtime_lock); |
| 31 | ui->enable_compute_pipelines_checkbox->setEnabled(runtime_lock); | ||
| 29 | 32 | ||
| 30 | ui->async_present->setChecked(Settings::values.async_presentation.GetValue()); | 33 | ui->async_present->setChecked(Settings::values.async_presentation.GetValue()); |
| 31 | ui->renderer_force_max_clock->setChecked(Settings::values.renderer_force_max_clock.GetValue()); | 34 | ui->renderer_force_max_clock->setChecked(Settings::values.renderer_force_max_clock.GetValue()); |
| @@ -34,6 +37,8 @@ void ConfigureGraphicsAdvanced::SetConfiguration() { | |||
| 34 | ui->use_fast_gpu_time->setChecked(Settings::values.use_fast_gpu_time.GetValue()); | 37 | ui->use_fast_gpu_time->setChecked(Settings::values.use_fast_gpu_time.GetValue()); |
| 35 | ui->use_vulkan_driver_pipeline_cache->setChecked( | 38 | ui->use_vulkan_driver_pipeline_cache->setChecked( |
| 36 | Settings::values.use_vulkan_driver_pipeline_cache.GetValue()); | 39 | Settings::values.use_vulkan_driver_pipeline_cache.GetValue()); |
| 40 | ui->enable_compute_pipelines_checkbox->setChecked( | ||
| 41 | Settings::values.enable_compute_pipelines.GetValue()); | ||
| 37 | 42 | ||
| 38 | if (Settings::IsConfiguringGlobal()) { | 43 | if (Settings::IsConfiguringGlobal()) { |
| 39 | ui->gpu_accuracy->setCurrentIndex( | 44 | ui->gpu_accuracy->setCurrentIndex( |
| @@ -70,6 +75,9 @@ void ConfigureGraphicsAdvanced::ApplyConfiguration() { | |||
| 70 | ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_vulkan_driver_pipeline_cache, | 75 | ConfigurationShared::ApplyPerGameSetting(&Settings::values.use_vulkan_driver_pipeline_cache, |
| 71 | ui->use_vulkan_driver_pipeline_cache, | 76 | ui->use_vulkan_driver_pipeline_cache, |
| 72 | use_vulkan_driver_pipeline_cache); | 77 | use_vulkan_driver_pipeline_cache); |
| 78 | ConfigurationShared::ApplyPerGameSetting(&Settings::values.enable_compute_pipelines, | ||
| 79 | ui->enable_compute_pipelines_checkbox, | ||
| 80 | enable_compute_pipelines); | ||
| 73 | } | 81 | } |
| 74 | 82 | ||
| 75 | void ConfigureGraphicsAdvanced::changeEvent(QEvent* event) { | 83 | void ConfigureGraphicsAdvanced::changeEvent(QEvent* event) { |
| @@ -99,6 +107,8 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() { | |||
| 99 | Settings::values.use_vulkan_driver_pipeline_cache.UsingGlobal()); | 107 | Settings::values.use_vulkan_driver_pipeline_cache.UsingGlobal()); |
| 100 | ui->anisotropic_filtering_combobox->setEnabled( | 108 | ui->anisotropic_filtering_combobox->setEnabled( |
| 101 | Settings::values.max_anisotropy.UsingGlobal()); | 109 | Settings::values.max_anisotropy.UsingGlobal()); |
| 110 | ui->enable_compute_pipelines_checkbox->setEnabled( | ||
| 111 | Settings::values.enable_compute_pipelines.UsingGlobal()); | ||
| 102 | 112 | ||
| 103 | return; | 113 | return; |
| 104 | } | 114 | } |
| @@ -118,6 +128,9 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() { | |||
| 118 | ConfigurationShared::SetColoredTristate(ui->use_vulkan_driver_pipeline_cache, | 128 | ConfigurationShared::SetColoredTristate(ui->use_vulkan_driver_pipeline_cache, |
| 119 | Settings::values.use_vulkan_driver_pipeline_cache, | 129 | Settings::values.use_vulkan_driver_pipeline_cache, |
| 120 | use_vulkan_driver_pipeline_cache); | 130 | use_vulkan_driver_pipeline_cache); |
| 131 | ConfigurationShared::SetColoredTristate(ui->enable_compute_pipelines_checkbox, | ||
| 132 | Settings::values.enable_compute_pipelines, | ||
| 133 | enable_compute_pipelines); | ||
| 121 | ConfigurationShared::SetColoredComboBox( | 134 | ConfigurationShared::SetColoredComboBox( |
| 122 | ui->gpu_accuracy, ui->label_gpu_accuracy, | 135 | ui->gpu_accuracy, ui->label_gpu_accuracy, |
| 123 | static_cast<int>(Settings::values.gpu_accuracy.GetValue(true))); | 136 | static_cast<int>(Settings::values.gpu_accuracy.GetValue(true))); |
| @@ -125,3 +138,7 @@ void ConfigureGraphicsAdvanced::SetupPerGameUI() { | |||
| 125 | ui->anisotropic_filtering_combobox, ui->af_label, | 138 | ui->anisotropic_filtering_combobox, ui->af_label, |
| 126 | static_cast<int>(Settings::values.max_anisotropy.GetValue(true))); | 139 | static_cast<int>(Settings::values.max_anisotropy.GetValue(true))); |
| 127 | } | 140 | } |
| 141 | |||
| 142 | void ConfigureGraphicsAdvanced::ExposeComputeOption() { | ||
| 143 | ui->enable_compute_pipelines_checkbox->setVisible(true); | ||
| 144 | } | ||
diff --git a/src/yuzu/configuration/configure_graphics_advanced.h b/src/yuzu/configuration/configure_graphics_advanced.h index ff5060957..2d8c7fd2d 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.h +++ b/src/yuzu/configuration/configure_graphics_advanced.h | |||
| @@ -28,6 +28,8 @@ public: | |||
| 28 | void ApplyConfiguration(); | 28 | void ApplyConfiguration(); |
| 29 | void SetConfiguration(); | 29 | void SetConfiguration(); |
| 30 | 30 | ||
| 31 | void ExposeComputeOption(); | ||
| 32 | |||
| 31 | private: | 33 | private: |
| 32 | void changeEvent(QEvent* event) override; | 34 | void changeEvent(QEvent* event) override; |
| 33 | void RetranslateUI(); | 35 | void RetranslateUI(); |
| @@ -43,6 +45,7 @@ private: | |||
| 43 | ConfigurationShared::CheckState use_asynchronous_shaders; | 45 | ConfigurationShared::CheckState use_asynchronous_shaders; |
| 44 | ConfigurationShared::CheckState use_fast_gpu_time; | 46 | ConfigurationShared::CheckState use_fast_gpu_time; |
| 45 | ConfigurationShared::CheckState use_vulkan_driver_pipeline_cache; | 47 | ConfigurationShared::CheckState use_vulkan_driver_pipeline_cache; |
| 48 | ConfigurationShared::CheckState enable_compute_pipelines; | ||
| 46 | 49 | ||
| 47 | const Core::System& system; | 50 | const Core::System& system; |
| 48 | }; | 51 | }; |
diff --git a/src/yuzu/configuration/configure_graphics_advanced.ui b/src/yuzu/configuration/configure_graphics_advanced.ui index d073fe9b1..a222d294b 100644 --- a/src/yuzu/configuration/configure_graphics_advanced.ui +++ b/src/yuzu/configuration/configure_graphics_advanced.ui | |||
| @@ -127,6 +127,17 @@ | |||
| 127 | </widget> | 127 | </widget> |
| 128 | </item> | 128 | </item> |
| 129 | <item> | 129 | <item> |
| 130 | <widget class="QCheckBox" name="enable_compute_pipelines_checkbox"> | ||
| 131 | <property name="toolTip"> | ||
| 132 | <string>Enable compute pipelines, required by some games. This setting only exists for Intel proprietary drivers, and may crash if enabled. | ||
| 133 | Compute pipelines are always enabled on all other drivers.</string> | ||
| 134 | </property> | ||
| 135 | <property name="text"> | ||
| 136 | <string>Enable Compute Pipelines (Intel Vulkan only)</string> | ||
| 137 | </property> | ||
| 138 | </widget> | ||
| 139 | </item> | ||
| 140 | <item> | ||
| 130 | <widget class="QWidget" name="af_layout" native="true"> | 141 | <widget class="QWidget" name="af_layout" native="true"> |
| 131 | <layout class="QHBoxLayout" name="horizontalLayout_1"> | 142 | <layout class="QHBoxLayout" name="horizontalLayout_1"> |
| 132 | <property name="leftMargin"> | 143 | <property name="leftMargin"> |
diff --git a/src/yuzu/configuration/configure_per_game.cpp b/src/yuzu/configuration/configure_per_game.cpp index 7e757eafd..7ac162586 100644 --- a/src/yuzu/configuration/configure_per_game.cpp +++ b/src/yuzu/configuration/configure_per_game.cpp | |||
| @@ -48,8 +48,9 @@ ConfigurePerGame::ConfigurePerGame(QWidget* parent, u64 title_id_, const std::st | |||
| 48 | audio_tab = std::make_unique<ConfigureAudio>(system_, this); | 48 | audio_tab = std::make_unique<ConfigureAudio>(system_, this); |
| 49 | cpu_tab = std::make_unique<ConfigureCpu>(system_, this); | 49 | cpu_tab = std::make_unique<ConfigureCpu>(system_, this); |
| 50 | general_tab = std::make_unique<ConfigureGeneral>(system_, this); | 50 | general_tab = std::make_unique<ConfigureGeneral>(system_, this); |
| 51 | graphics_tab = std::make_unique<ConfigureGraphics>(system_, this); | ||
| 52 | graphics_advanced_tab = std::make_unique<ConfigureGraphicsAdvanced>(system_, this); | 51 | graphics_advanced_tab = std::make_unique<ConfigureGraphicsAdvanced>(system_, this); |
| 52 | graphics_tab = std::make_unique<ConfigureGraphics>( | ||
| 53 | system_, [&]() { graphics_advanced_tab->ExposeComputeOption(); }, this); | ||
| 53 | input_tab = std::make_unique<ConfigureInputPerGame>(system_, game_config.get(), this); | 54 | input_tab = std::make_unique<ConfigureInputPerGame>(system_, game_config.get(), this); |
| 54 | system_tab = std::make_unique<ConfigureSystem>(system_, this); | 55 | system_tab = std::make_unique<ConfigureSystem>(system_, this); |
| 55 | 56 | ||
diff --git a/src/yuzu/configuration/configure_per_game.h b/src/yuzu/configuration/configure_per_game.h index 4ecc43541..85752f1fa 100644 --- a/src/yuzu/configuration/configure_per_game.h +++ b/src/yuzu/configuration/configure_per_game.h | |||
| @@ -75,8 +75,8 @@ private: | |||
| 75 | std::unique_ptr<ConfigureAudio> audio_tab; | 75 | std::unique_ptr<ConfigureAudio> audio_tab; |
| 76 | std::unique_ptr<ConfigureCpu> cpu_tab; | 76 | std::unique_ptr<ConfigureCpu> cpu_tab; |
| 77 | std::unique_ptr<ConfigureGeneral> general_tab; | 77 | std::unique_ptr<ConfigureGeneral> general_tab; |
| 78 | std::unique_ptr<ConfigureGraphics> graphics_tab; | ||
| 79 | std::unique_ptr<ConfigureGraphicsAdvanced> graphics_advanced_tab; | 78 | std::unique_ptr<ConfigureGraphicsAdvanced> graphics_advanced_tab; |
| 79 | std::unique_ptr<ConfigureGraphics> graphics_tab; | ||
| 80 | std::unique_ptr<ConfigureInputPerGame> input_tab; | 80 | std::unique_ptr<ConfigureInputPerGame> input_tab; |
| 81 | std::unique_ptr<ConfigureSystem> system_tab; | 81 | std::unique_ptr<ConfigureSystem> system_tab; |
| 82 | }; | 82 | }; |