summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/yuzu/configuration/config.cpp2
-rw-r--r--src/yuzu/configuration/configure_dialog.cpp3
-rw-r--r--src/yuzu/configuration/configure_dialog.h2
-rw-r--r--src/yuzu/configuration/configure_graphics.cpp23
-rw-r--r--src/yuzu/configuration/configure_graphics.h6
-rw-r--r--src/yuzu/configuration/configure_graphics_advanced.cpp17
-rw-r--r--src/yuzu/configuration/configure_graphics_advanced.h3
-rw-r--r--src/yuzu/configuration/configure_graphics_advanced.ui11
-rw-r--r--src/yuzu/configuration/configure_per_game.cpp3
-rw-r--r--src/yuzu/configuration/configure_per_game.h2
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
77ConfigureGraphics::ConfigureGraphics(const Core::System& system_, QWidget* parent) 79ConfigureGraphics::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
39public: 40public:
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
75void ConfigureGraphicsAdvanced::changeEvent(QEvent* event) { 83void 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
142void 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
31private: 33private:
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.
133Compute 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};