forked from eden-emu/eden
		
	Merge pull request #6573 from lat9nq/cpu-settings-cleanup-2
core,common,yuzu qt: Add CPU accuracy option 'Auto'
This commit is contained in:
		
						commit
						7d416865fd
					
				
					 18 changed files with 291 additions and 148 deletions
				
			
		|  | @ -93,7 +93,7 @@ bool IsGPULevelHigh() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool IsFastmemEnabled() { | bool IsFastmemEnabled() { | ||||||
|     if (values.cpu_accuracy.GetValue() == CPUAccuracy::DebugMode) { |     if (values.cpu_debug_mode) { | ||||||
|         return static_cast<bool>(values.cpuopt_fastmem); |         return static_cast<bool>(values.cpuopt_fastmem); | ||||||
|     } |     } | ||||||
|     return true; |     return true; | ||||||
|  |  | ||||||
|  | @ -31,9 +31,9 @@ enum class GPUAccuracy : u32 { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum class CPUAccuracy : u32 { | enum class CPUAccuracy : u32 { | ||||||
|     Accurate = 0, |     Auto = 0, | ||||||
|     Unsafe = 1, |     Accurate = 1, | ||||||
|     DebugMode = 2, |     Unsafe = 2, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| /** The BasicSetting class is a simple resource manager. It defines a label and default value
 | /** The BasicSetting class is a simple resource manager. It defines a label and default value
 | ||||||
|  | @ -284,7 +284,10 @@ struct Values { | ||||||
|     Setting<bool> use_multi_core{true, "use_multi_core"}; |     Setting<bool> use_multi_core{true, "use_multi_core"}; | ||||||
| 
 | 
 | ||||||
|     // Cpu
 |     // Cpu
 | ||||||
|     Setting<CPUAccuracy> cpu_accuracy{CPUAccuracy::Accurate, "cpu_accuracy"}; |     Setting<CPUAccuracy> cpu_accuracy{CPUAccuracy::Auto, "cpu_accuracy"}; | ||||||
|  |     // TODO: remove cpu_accuracy_first_time, migration setting added 8 July 2021
 | ||||||
|  |     BasicSetting<bool> cpu_accuracy_first_time{true, "cpu_accuracy_first_time"}; | ||||||
|  |     BasicSetting<bool> cpu_debug_mode{false, "cpu_debug_mode"}; | ||||||
| 
 | 
 | ||||||
|     BasicSetting<bool> cpuopt_page_tables{true, "cpuopt_page_tables"}; |     BasicSetting<bool> cpuopt_page_tables{true, "cpuopt_page_tables"}; | ||||||
|     BasicSetting<bool> cpuopt_block_linking{true, "cpuopt_block_linking"}; |     BasicSetting<bool> cpuopt_block_linking{true, "cpuopt_block_linking"}; | ||||||
|  |  | ||||||
|  | @ -150,7 +150,7 @@ std::shared_ptr<Dynarmic::A32::Jit> ARM_Dynarmic_32::MakeJit(Common::PageTable* | ||||||
|     config.far_code_offset = 400_MiB; |     config.far_code_offset = 400_MiB; | ||||||
| 
 | 
 | ||||||
|     // Safe optimizations
 |     // Safe optimizations
 | ||||||
|     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::DebugMode) { |     if (Settings::values.cpu_debug_mode) { | ||||||
|         if (!Settings::values.cpuopt_page_tables) { |         if (!Settings::values.cpuopt_page_tables) { | ||||||
|             config.page_table = nullptr; |             config.page_table = nullptr; | ||||||
|         } |         } | ||||||
|  | @ -183,20 +183,28 @@ std::shared_ptr<Dynarmic::A32::Jit> ARM_Dynarmic_32::MakeJit(Common::PageTable* | ||||||
|     // Unsafe optimizations
 |     // Unsafe optimizations
 | ||||||
|     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Unsafe) { |     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Unsafe) { | ||||||
|         config.unsafe_optimizations = true; |         config.unsafe_optimizations = true; | ||||||
|         if (Settings::values.cpuopt_unsafe_unfuse_fma.GetValue()) { |         if (Settings::values.cpuopt_unsafe_unfuse_fma) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_reduce_fp_error.GetValue()) { |         if (Settings::values.cpuopt_unsafe_reduce_fp_error) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_ReducedErrorFP; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_ReducedErrorFP; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_ignore_standard_fpcr.GetValue()) { |         if (Settings::values.cpuopt_unsafe_ignore_standard_fpcr) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_IgnoreStandardFPCRValue; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_IgnoreStandardFPCRValue; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_inaccurate_nan.GetValue()) { |         if (Settings::values.cpuopt_unsafe_inaccurate_nan) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // Curated optimizations
 | ||||||
|  |     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Auto) { | ||||||
|  |         config.unsafe_optimizations = true; | ||||||
|  |         config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; | ||||||
|  |         config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_IgnoreStandardFPCRValue; | ||||||
|  |         config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return std::make_unique<Dynarmic::A32::Jit>(config); |     return std::make_unique<Dynarmic::A32::Jit>(config); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -190,7 +190,7 @@ std::shared_ptr<Dynarmic::A64::Jit> ARM_Dynarmic_64::MakeJit(Common::PageTable* | ||||||
|     config.far_code_offset = 400_MiB; |     config.far_code_offset = 400_MiB; | ||||||
| 
 | 
 | ||||||
|     // Safe optimizations
 |     // Safe optimizations
 | ||||||
|     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::DebugMode) { |     if (Settings::values.cpu_debug_mode) { | ||||||
|         if (!Settings::values.cpuopt_page_tables) { |         if (!Settings::values.cpuopt_page_tables) { | ||||||
|             config.page_table = nullptr; |             config.page_table = nullptr; | ||||||
|         } |         } | ||||||
|  | @ -223,20 +223,28 @@ std::shared_ptr<Dynarmic::A64::Jit> ARM_Dynarmic_64::MakeJit(Common::PageTable* | ||||||
|     // Unsafe optimizations
 |     // Unsafe optimizations
 | ||||||
|     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Unsafe) { |     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Unsafe) { | ||||||
|         config.unsafe_optimizations = true; |         config.unsafe_optimizations = true; | ||||||
|         if (Settings::values.cpuopt_unsafe_unfuse_fma.GetValue()) { |         if (Settings::values.cpuopt_unsafe_unfuse_fma) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_reduce_fp_error.GetValue()) { |         if (Settings::values.cpuopt_unsafe_reduce_fp_error) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_ReducedErrorFP; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_ReducedErrorFP; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_inaccurate_nan.GetValue()) { |         if (Settings::values.cpuopt_unsafe_inaccurate_nan) { | ||||||
|             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; |             config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; | ||||||
|         } |         } | ||||||
|         if (Settings::values.cpuopt_unsafe_fastmem_check.GetValue()) { |         if (Settings::values.cpuopt_unsafe_fastmem_check) { | ||||||
|             config.fastmem_address_space_bits = 64; |             config.fastmem_address_space_bits = 64; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // Curated optimizations
 | ||||||
|  |     if (Settings::values.cpu_accuracy.GetValue() == Settings::CPUAccuracy::Auto) { | ||||||
|  |         config.unsafe_optimizations = true; | ||||||
|  |         config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_UnfuseFMA; | ||||||
|  |         config.optimizations |= Dynarmic::OptimizationFlag::Unsafe_InaccurateNaN; | ||||||
|  |         config.fastmem_address_space_bits = 64; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return std::make_shared<Dynarmic::A64::Jit>(config); |     return std::make_shared<Dynarmic::A64::Jit>(config); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -52,6 +52,9 @@ add_executable(yuzu | ||||||
|     configuration/configure_debug_controller.cpp |     configuration/configure_debug_controller.cpp | ||||||
|     configuration/configure_debug_controller.h |     configuration/configure_debug_controller.h | ||||||
|     configuration/configure_debug_controller.ui |     configuration/configure_debug_controller.ui | ||||||
|  |     configuration/configure_debug_tab.cpp | ||||||
|  |     configuration/configure_debug_tab.h | ||||||
|  |     configuration/configure_debug_tab.ui | ||||||
|     configuration/configure_dialog.cpp |     configuration/configure_dialog.cpp | ||||||
|     configuration/configure_dialog.h |     configuration/configure_dialog.h | ||||||
|     configuration/configure_filesystem.cpp |     configuration/configure_filesystem.cpp | ||||||
|  |  | ||||||
|  | @ -793,7 +793,13 @@ void Config::ReadPathValues() { | ||||||
| void Config::ReadCpuValues() { | void Config::ReadCpuValues() { | ||||||
|     qt_config->beginGroup(QStringLiteral("Cpu")); |     qt_config->beginGroup(QStringLiteral("Cpu")); | ||||||
| 
 | 
 | ||||||
|     ReadGlobalSetting(Settings::values.cpu_accuracy); |     ReadBasicSetting(Settings::values.cpu_accuracy_first_time); | ||||||
|  |     if (Settings::values.cpu_accuracy_first_time) { | ||||||
|  |         Settings::values.cpu_accuracy.SetValue(Settings::values.cpu_accuracy.GetDefault()); | ||||||
|  |         Settings::values.cpu_accuracy_first_time.SetValue(false); | ||||||
|  |     } else { | ||||||
|  |         ReadGlobalSetting(Settings::values.cpu_accuracy); | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     ReadGlobalSetting(Settings::values.cpuopt_unsafe_unfuse_fma); |     ReadGlobalSetting(Settings::values.cpuopt_unsafe_unfuse_fma); | ||||||
|     ReadGlobalSetting(Settings::values.cpuopt_unsafe_reduce_fp_error); |     ReadGlobalSetting(Settings::values.cpuopt_unsafe_reduce_fp_error); | ||||||
|  | @ -802,6 +808,7 @@ void Config::ReadCpuValues() { | ||||||
|     ReadGlobalSetting(Settings::values.cpuopt_unsafe_fastmem_check); |     ReadGlobalSetting(Settings::values.cpuopt_unsafe_fastmem_check); | ||||||
| 
 | 
 | ||||||
|     if (global) { |     if (global) { | ||||||
|  |         ReadBasicSetting(Settings::values.cpu_debug_mode); | ||||||
|         ReadBasicSetting(Settings::values.cpuopt_page_tables); |         ReadBasicSetting(Settings::values.cpuopt_page_tables); | ||||||
|         ReadBasicSetting(Settings::values.cpuopt_block_linking); |         ReadBasicSetting(Settings::values.cpuopt_block_linking); | ||||||
|         ReadBasicSetting(Settings::values.cpuopt_return_stack_buffer); |         ReadBasicSetting(Settings::values.cpuopt_return_stack_buffer); | ||||||
|  | @ -1312,6 +1319,7 @@ void Config::SavePathValues() { | ||||||
| void Config::SaveCpuValues() { | void Config::SaveCpuValues() { | ||||||
|     qt_config->beginGroup(QStringLiteral("Cpu")); |     qt_config->beginGroup(QStringLiteral("Cpu")); | ||||||
| 
 | 
 | ||||||
|  |     WriteBasicSetting(Settings::values.cpu_accuracy_first_time); | ||||||
|     WriteSetting(QStringLiteral("cpu_accuracy"), |     WriteSetting(QStringLiteral("cpu_accuracy"), | ||||||
|                  static_cast<u32>(Settings::values.cpu_accuracy.GetValue(global)), |                  static_cast<u32>(Settings::values.cpu_accuracy.GetValue(global)), | ||||||
|                  static_cast<u32>(Settings::values.cpu_accuracy.GetDefault()), |                  static_cast<u32>(Settings::values.cpu_accuracy.GetDefault()), | ||||||
|  | @ -1324,6 +1332,7 @@ void Config::SaveCpuValues() { | ||||||
|     WriteGlobalSetting(Settings::values.cpuopt_unsafe_fastmem_check); |     WriteGlobalSetting(Settings::values.cpuopt_unsafe_fastmem_check); | ||||||
| 
 | 
 | ||||||
|     if (global) { |     if (global) { | ||||||
|  |         WriteBasicSetting(Settings::values.cpu_debug_mode); | ||||||
|         WriteBasicSetting(Settings::values.cpuopt_page_tables); |         WriteBasicSetting(Settings::values.cpuopt_page_tables); | ||||||
|         WriteBasicSetting(Settings::values.cpuopt_block_linking); |         WriteBasicSetting(Settings::values.cpuopt_block_linking); | ||||||
|         WriteBasicSetting(Settings::values.cpuopt_return_stack_buffer); |         WriteBasicSetting(Settings::values.cpuopt_return_stack_buffer); | ||||||
|  |  | ||||||
|  | @ -41,7 +41,7 @@ | ||||||
|      <item> |      <item> | ||||||
|       <widget class="QTabWidget" name="tabWidget"> |       <widget class="QTabWidget" name="tabWidget"> | ||||||
|        <property name="currentIndex"> |        <property name="currentIndex"> | ||||||
|         <number>0</number> |         <number>11</number> | ||||||
|        </property> |        </property> | ||||||
|        <widget class="ConfigureGeneral" name="generalTab"> |        <widget class="ConfigureGeneral" name="generalTab"> | ||||||
|         <property name="accessibleName"> |         <property name="accessibleName"> | ||||||
|  | @ -107,14 +107,6 @@ | ||||||
|          <string>CPU</string> |          <string>CPU</string> | ||||||
|         </attribute> |         </attribute> | ||||||
|        </widget> |        </widget> | ||||||
|        <widget class="ConfigureCpuDebug" name="cpuDebugTab"> |  | ||||||
|         <property name="accessibleName"> |  | ||||||
|          <string>Debug</string> |  | ||||||
|         </property> |  | ||||||
|         <attribute name="title"> |  | ||||||
|          <string>Debug</string> |  | ||||||
|         </attribute> |  | ||||||
|        </widget> |  | ||||||
|        <widget class="ConfigureGraphics" name="graphicsTab"> |        <widget class="ConfigureGraphics" name="graphicsTab"> | ||||||
|         <property name="accessibleName"> |         <property name="accessibleName"> | ||||||
|          <string>Graphics</string> |          <string>Graphics</string> | ||||||
|  | @ -139,7 +131,7 @@ | ||||||
|          <string>Audio</string> |          <string>Audio</string> | ||||||
|         </attribute> |         </attribute> | ||||||
|        </widget> |        </widget> | ||||||
|        <widget class="ConfigureDebug" name="debugTab"> |        <widget class="ConfigureDebugTab" name="debugTab"> | ||||||
|         <property name="accessibleName"> |         <property name="accessibleName"> | ||||||
|          <string>Debug</string> |          <string>Debug</string> | ||||||
|         </property> |         </property> | ||||||
|  | @ -207,24 +199,12 @@ | ||||||
|    <header>configuration/configure_audio.h</header> |    <header>configuration/configure_audio.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|   <customwidget> |  | ||||||
|    <class>ConfigureDebug</class> |  | ||||||
|    <extends>QWidget</extends> |  | ||||||
|    <header>configuration/configure_debug.h</header> |  | ||||||
|    <container>1</container> |  | ||||||
|   </customwidget> |  | ||||||
|   <customwidget> |   <customwidget> | ||||||
|    <class>ConfigureCpu</class> |    <class>ConfigureCpu</class> | ||||||
|    <extends>QWidget</extends> |    <extends>QWidget</extends> | ||||||
|    <header>configuration/configure_cpu.h</header> |    <header>configuration/configure_cpu.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|   <customwidget> |  | ||||||
|    <class>ConfigureCpuDebug</class> |  | ||||||
|    <extends>QWidget</extends> |  | ||||||
|    <header>configuration/configure_cpu_debug.h</header> |  | ||||||
|    <container>1</container> |  | ||||||
|   </customwidget> |  | ||||||
|   <customwidget> |   <customwidget> | ||||||
|    <class>ConfigureGraphics</class> |    <class>ConfigureGraphics</class> | ||||||
|    <extends>QWidget</extends> |    <extends>QWidget</extends> | ||||||
|  | @ -267,6 +247,12 @@ | ||||||
|    <header>configuration/configure_service.h</header> |    <header>configuration/configure_service.h</header> | ||||||
|    <container>1</container> |    <container>1</container> | ||||||
|   </customwidget> |   </customwidget> | ||||||
|  |   <customwidget> | ||||||
|  |    <class>ConfigureDebugTab</class> | ||||||
|  |    <extends>QWidget</extends> | ||||||
|  |    <header>configuration/configure_debug_tab.h</header> | ||||||
|  |    <container>1</container> | ||||||
|  |   </customwidget> | ||||||
|  </customwidgets> |  </customwidgets> | ||||||
|  <resources/> |  <resources/> | ||||||
|  <connections> |  <connections> | ||||||
|  | @ -275,12 +261,32 @@ | ||||||
|    <signal>accepted()</signal> |    <signal>accepted()</signal> | ||||||
|    <receiver>ConfigureDialog</receiver> |    <receiver>ConfigureDialog</receiver> | ||||||
|    <slot>accept()</slot> |    <slot>accept()</slot> | ||||||
|  |    <hints> | ||||||
|  |     <hint type="sourcelabel"> | ||||||
|  |      <x>20</x> | ||||||
|  |      <y>20</y> | ||||||
|  |     </hint> | ||||||
|  |     <hint type="destinationlabel"> | ||||||
|  |      <x>20</x> | ||||||
|  |      <y>20</y> | ||||||
|  |     </hint> | ||||||
|  |    </hints> | ||||||
|   </connection> |   </connection> | ||||||
|   <connection> |   <connection> | ||||||
|    <sender>buttonBox</sender> |    <sender>buttonBox</sender> | ||||||
|    <signal>rejected()</signal> |    <signal>rejected()</signal> | ||||||
|    <receiver>ConfigureDialog</receiver> |    <receiver>ConfigureDialog</receiver> | ||||||
|    <slot>reject()</slot> |    <slot>reject()</slot> | ||||||
|  |    <hints> | ||||||
|  |     <hint type="sourcelabel"> | ||||||
|  |      <x>20</x> | ||||||
|  |      <y>20</y> | ||||||
|  |     </hint> | ||||||
|  |     <hint type="destinationlabel"> | ||||||
|  |      <x>20</x> | ||||||
|  |      <y>20</y> | ||||||
|  |     </hint> | ||||||
|  |    </hints> | ||||||
|   </connection> |   </connection> | ||||||
|  </connections> |  </connections> | ||||||
| </ui> | </ui> | ||||||
|  |  | ||||||
|  | @ -20,8 +20,6 @@ ConfigureCpu::ConfigureCpu(QWidget* parent) : QWidget(parent), ui(new Ui::Config | ||||||
| 
 | 
 | ||||||
|     SetConfiguration(); |     SetConfiguration(); | ||||||
| 
 | 
 | ||||||
|     connect(ui->accuracy, qOverload<int>(&QComboBox::activated), this, |  | ||||||
|             &ConfigureCpu::AccuracyUpdated); |  | ||||||
|     connect(ui->accuracy, qOverload<int>(&QComboBox::currentIndexChanged), this, |     connect(ui->accuracy, qOverload<int>(&QComboBox::currentIndexChanged), this, | ||||||
|             &ConfigureCpu::UpdateGroup); |             &ConfigureCpu::UpdateGroup); | ||||||
| } | } | ||||||
|  | @ -58,20 +56,6 @@ void ConfigureCpu::SetConfiguration() { | ||||||
|     UpdateGroup(ui->accuracy->currentIndex()); |     UpdateGroup(ui->accuracy->currentIndex()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ConfigureCpu::AccuracyUpdated(int index) { |  | ||||||
|     if (Settings::IsConfiguringGlobal() && |  | ||||||
|         static_cast<Settings::CPUAccuracy>(index) == Settings::CPUAccuracy::DebugMode) { |  | ||||||
|         const auto result = QMessageBox::warning(this, tr("Setting CPU to Debug Mode"), |  | ||||||
|                                                  tr("CPU Debug Mode is only intended for developer " |  | ||||||
|                                                     "use. Are you sure you want to enable this?"), |  | ||||||
|                                                  QMessageBox::Yes | QMessageBox::No); |  | ||||||
|         if (result == QMessageBox::No) { |  | ||||||
|             ui->accuracy->setCurrentIndex(static_cast<int>(Settings::CPUAccuracy::Accurate)); |  | ||||||
|             UpdateGroup(static_cast<int>(Settings::CPUAccuracy::Accurate)); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void ConfigureCpu::UpdateGroup(int index) { | void ConfigureCpu::UpdateGroup(int index) { | ||||||
|     if (!Settings::IsConfiguringGlobal()) { |     if (!Settings::IsConfiguringGlobal()) { | ||||||
|         index -= ConfigurationShared::USE_GLOBAL_OFFSET; |         index -= ConfigurationShared::USE_GLOBAL_OFFSET; | ||||||
|  | @ -134,8 +118,6 @@ void ConfigureCpu::SetupPerGameUI() { | ||||||
|     ConfigurationShared::SetColoredComboBox( |     ConfigurationShared::SetColoredComboBox( | ||||||
|         ui->accuracy, ui->widget_accuracy, |         ui->accuracy, ui->widget_accuracy, | ||||||
|         static_cast<u32>(Settings::values.cpu_accuracy.GetValue(true))); |         static_cast<u32>(Settings::values.cpu_accuracy.GetValue(true))); | ||||||
|     ui->accuracy->removeItem(static_cast<u32>(Settings::CPUAccuracy::DebugMode) + |  | ||||||
|                              ConfigurationShared::USE_GLOBAL_OFFSET); |  | ||||||
| 
 | 
 | ||||||
|     ConfigurationShared::SetColoredTristate(ui->cpuopt_unsafe_unfuse_fma, |     ConfigurationShared::SetColoredTristate(ui->cpuopt_unsafe_unfuse_fma, | ||||||
|                                             Settings::values.cpuopt_unsafe_unfuse_fma, |                                             Settings::values.cpuopt_unsafe_unfuse_fma, | ||||||
|  |  | ||||||
|  | @ -29,7 +29,6 @@ private: | ||||||
|     void changeEvent(QEvent* event) override; |     void changeEvent(QEvent* event) override; | ||||||
|     void RetranslateUI(); |     void RetranslateUI(); | ||||||
| 
 | 
 | ||||||
|     void AccuracyUpdated(int index); |  | ||||||
|     void UpdateGroup(int index); |     void UpdateGroup(int index); | ||||||
| 
 | 
 | ||||||
|     void SetConfiguration(); |     void SetConfiguration(); | ||||||
|  |  | ||||||
|  | @ -6,8 +6,8 @@ | ||||||
|    <rect> |    <rect> | ||||||
|     <x>0</x> |     <x>0</x> | ||||||
|     <y>0</y> |     <y>0</y> | ||||||
|     <width>400</width> |     <width>448</width> | ||||||
|     <height>321</height> |     <height>433</height> | ||||||
|    </rect> |    </rect> | ||||||
|   </property> |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|  | @ -17,7 +17,7 @@ | ||||||
|    <item> |    <item> | ||||||
|     <layout class="QVBoxLayout"> |     <layout class="QVBoxLayout"> | ||||||
|      <item> |      <item> | ||||||
|       <widget class="QGroupBox"> |       <widget class="QGroupBox" name="groupBox"> | ||||||
|        <property name="title"> |        <property name="title"> | ||||||
|         <string>General</string> |         <string>General</string> | ||||||
|        </property> |        </property> | ||||||
|  | @ -34,6 +34,11 @@ | ||||||
|            </item> |            </item> | ||||||
|            <item> |            <item> | ||||||
|             <widget class="QComboBox" name="accuracy"> |             <widget class="QComboBox" name="accuracy"> | ||||||
|  |              <item> | ||||||
|  |               <property name="text"> | ||||||
|  |                <string>Auto</string> | ||||||
|  |               </property> | ||||||
|  |              </item> | ||||||
|              <item> |              <item> | ||||||
|               <property name="text"> |               <property name="text"> | ||||||
|                <string>Accurate</string> |                <string>Accurate</string> | ||||||
|  | @ -44,11 +49,6 @@ | ||||||
|                <string>Unsafe</string> |                <string>Unsafe</string> | ||||||
|               </property> |               </property> | ||||||
|              </item> |              </item> | ||||||
|              <item> |  | ||||||
|               <property name="text"> |  | ||||||
|                <string>Enable Debug Mode</string> |  | ||||||
|               </property> |  | ||||||
|              </item> |  | ||||||
|             </widget> |             </widget> | ||||||
|            </item> |            </item> | ||||||
|           </layout> |           </layout> | ||||||
|  | @ -57,7 +57,7 @@ | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QLabel" name="label_recommended_accuracy"> |          <widget class="QLabel" name="label_recommended_accuracy"> | ||||||
|           <property name="text"> |           <property name="text"> | ||||||
|            <string>We recommend setting accuracy to "Accurate".</string> |            <string>We recommend setting accuracy to "Auto".</string> | ||||||
|           </property> |           </property> | ||||||
|           <property name="wordWrap"> |           <property name="wordWrap"> | ||||||
|            <bool>false</bool> |            <bool>false</bool> | ||||||
|  |  | ||||||
|  | @ -6,7 +6,6 @@ | ||||||
| 
 | 
 | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <QWidget> | #include <QWidget> | ||||||
| #include "common/settings.h" |  | ||||||
| 
 | 
 | ||||||
| namespace Ui { | namespace Ui { | ||||||
| class ConfigureCpuDebug; | class ConfigureCpuDebug; | ||||||
|  |  | ||||||
|  | @ -6,8 +6,8 @@ | ||||||
|    <rect> |    <rect> | ||||||
|     <x>0</x> |     <x>0</x> | ||||||
|     <y>0</y> |     <y>0</y> | ||||||
|     <width>400</width> |     <width>592</width> | ||||||
|     <height>321</height> |     <height>503</height> | ||||||
|    </rect> |    </rect> | ||||||
|   </property> |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|  | @ -17,140 +17,132 @@ | ||||||
|    <item> |    <item> | ||||||
|     <layout class="QVBoxLayout"> |     <layout class="QVBoxLayout"> | ||||||
|      <item> |      <item> | ||||||
|       <widget class="QGroupBox"> |       <widget class="QGroupBox" name="groupBox"> | ||||||
|        <property name="title"> |        <property name="title"> | ||||||
|         <string>Toggle CPU Optimizations</string> |         <string>Toggle CPU Optimizations</string> | ||||||
|        </property> |        </property> | ||||||
|        <layout class="QVBoxLayout"> |        <layout class="QVBoxLayout"> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QLabel"> |          <widget class="QLabel" name="label"> | ||||||
|           <property name="wordWrap"> |  | ||||||
|             <bool>1</bool> |  | ||||||
|           </property> |  | ||||||
|           <property name="text"> |           <property name="text"> | ||||||
|            <string> |            <string><html><head/><body><p><span style=" font-weight:600;">For debugging only.</span><br/>If you're not sure what these do, keep all of these enabled. <br/>These settings, when disabled, only take effect when CPU Debugging is enabled. </p></body></html></string> | ||||||
|             <div> |           </property> | ||||||
|             <b>For debugging only.</b> |           <property name="wordWrap"> | ||||||
|             <br> |            <bool>false</bool> | ||||||
|             If you're not sure what these do, keep all of these enabled. |  | ||||||
|             <br> |  | ||||||
|             These settings, when disabled, only take effect when CPU Accuracy is "Debug Mode". |  | ||||||
|             </div> |  | ||||||
|            </string> |  | ||||||
|           </property> |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_page_tables"> |          <widget class="QCheckBox" name="cpuopt_page_tables"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable inline page tables</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div style="white-space: nowrap">This optimization speeds up memory accesses by the guest program.</div> |             <div style="white-space: nowrap">This optimization speeds up memory accesses by the guest program.</div> | ||||||
|             <div style="white-space: nowrap">Enabling it inlines accesses to PageTable::pointers into emitted code.</div> |             <div style="white-space: nowrap">Enabling it inlines accesses to PageTable::pointers into emitted code.</div> | ||||||
|             <div style="white-space: nowrap">Disabling this forces all memory accesses to go through the Memory::Read/Memory::Write functions.</div> |             <div style="white-space: nowrap">Disabling this forces all memory accesses to go through the Memory::Read/Memory::Write functions.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable inline page tables</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_block_linking"> |          <widget class="QCheckBox" name="cpuopt_block_linking"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable block linking</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>This optimization avoids dispatcher lookups by allowing emitted basic blocks to jump directly to other basic blocks if the destination PC is static.</div> |             <div>This optimization avoids dispatcher lookups by allowing emitted basic blocks to jump directly to other basic blocks if the destination PC is static.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable block linking</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_return_stack_buffer"> |          <widget class="QCheckBox" name="cpuopt_return_stack_buffer"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable return stack buffer</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>This optimization avoids dispatcher lookups by keeping track potential return addresses of BL instructions. This approximates what happens with a return stack buffer on a real CPU.</div> |             <div>This optimization avoids dispatcher lookups by keeping track potential return addresses of BL instructions. This approximates what happens with a return stack buffer on a real CPU.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable return stack buffer</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_fast_dispatcher"> |          <widget class="QCheckBox" name="cpuopt_fast_dispatcher"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable fast dispatcher</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>Enable a two-tiered dispatch system. A faster dispatcher written in assembly has a small MRU cache of jump destinations is used first. If that fails, dispatch falls back to the slower C++ dispatcher.</div> |             <div>Enable a two-tiered dispatch system. A faster dispatcher written in assembly has a small MRU cache of jump destinations is used first. If that fails, dispatch falls back to the slower C++ dispatcher.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable fast dispatcher</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_context_elimination"> |          <widget class="QCheckBox" name="cpuopt_context_elimination"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable context elimination</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>Enables an IR optimization that reduces unnecessary accesses to the CPU context structure.</div> |             <div>Enables an IR optimization that reduces unnecessary accesses to the CPU context structure.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable context elimination</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_const_prop"> |          <widget class="QCheckBox" name="cpuopt_const_prop"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable constant propagation</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>Enables IR optimizations that involve constant propagation.</div> |             <div>Enables IR optimizations that involve constant propagation.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable constant propagation</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_misc_ir"> |          <widget class="QCheckBox" name="cpuopt_misc_ir"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable miscellaneous optimizations</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div>Enables miscellaneous IR optimizations.</div> |             <div>Enables miscellaneous IR optimizations.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable miscellaneous optimizations</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_reduce_misalign_checks"> |          <widget class="QCheckBox" name="cpuopt_reduce_misalign_checks"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable misalignment check reduction</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div style="white-space: nowrap">When enabled, a misalignment is only triggered when an access crosses a page boundary.</div> |             <div style="white-space: nowrap">When enabled, a misalignment is only triggered when an access crosses a page boundary.</div> | ||||||
|             <div style="white-space: nowrap">When disabled, a misalignment is triggered on all misaligned accesses.</div> |             <div style="white-space: nowrap">When disabled, a misalignment is triggered on all misaligned accesses.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable misalignment check reduction</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|         <item> |         <item> | ||||||
|          <widget class="QCheckBox" name="cpuopt_fastmem"> |          <widget class="QCheckBox" name="cpuopt_fastmem"> | ||||||
|           <property name="text"> |  | ||||||
|            <string>Enable Host MMU Emulation</string> |  | ||||||
|           </property> |  | ||||||
|           <property name="toolTip"> |           <property name="toolTip"> | ||||||
|            <string> |            <string> | ||||||
|             <div style="white-space: nowrap">This optimization speeds up memory accesses by the guest program.</div> |             <div style="white-space: nowrap">This optimization speeds up memory accesses by the guest program.</div> | ||||||
|             <div style="white-space: nowrap">Enabling it causes guest memory reads/writes to be done directly into memory and make use of Host's MMU.</div> |             <div style="white-space: nowrap">Enabling it causes guest memory reads/writes to be done directly into memory and make use of Host's MMU.</div> | ||||||
|             <div style="white-space: nowrap">Disabling this forces all memory accesses to use Software MMU Emulation.</div> |             <div style="white-space: nowrap">Disabling this forces all memory accesses to use Software MMU Emulation.</div> | ||||||
|            </string> |            </string> | ||||||
|           </property> |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Enable Host MMU Emulation</string> | ||||||
|  |           </property> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|        </layout> |        </layout> | ||||||
|  |  | ||||||
|  | @ -43,6 +43,8 @@ void ConfigureDebug::SetConfiguration() { | ||||||
|     ui->use_auto_stub->setChecked(Settings::values.use_auto_stub.GetValue()); |     ui->use_auto_stub->setChecked(Settings::values.use_auto_stub.GetValue()); | ||||||
|     ui->enable_graphics_debugging->setEnabled(runtime_lock); |     ui->enable_graphics_debugging->setEnabled(runtime_lock); | ||||||
|     ui->enable_graphics_debugging->setChecked(Settings::values.renderer_debug.GetValue()); |     ui->enable_graphics_debugging->setChecked(Settings::values.renderer_debug.GetValue()); | ||||||
|  |     ui->enable_cpu_debugging->setEnabled(runtime_lock); | ||||||
|  |     ui->enable_cpu_debugging->setChecked(Settings::values.cpu_debug_mode.GetValue()); | ||||||
|     ui->disable_macro_jit->setEnabled(runtime_lock); |     ui->disable_macro_jit->setEnabled(runtime_lock); | ||||||
|     ui->disable_macro_jit->setChecked(Settings::values.disable_macro_jit.GetValue()); |     ui->disable_macro_jit->setChecked(Settings::values.disable_macro_jit.GetValue()); | ||||||
|     ui->extended_logging->setChecked(Settings::values.extended_logging.GetValue()); |     ui->extended_logging->setChecked(Settings::values.extended_logging.GetValue()); | ||||||
|  | @ -58,6 +60,7 @@ void ConfigureDebug::ApplyConfiguration() { | ||||||
|     Settings::values.use_debug_asserts = ui->use_debug_asserts->isChecked(); |     Settings::values.use_debug_asserts = ui->use_debug_asserts->isChecked(); | ||||||
|     Settings::values.use_auto_stub = ui->use_auto_stub->isChecked(); |     Settings::values.use_auto_stub = ui->use_auto_stub->isChecked(); | ||||||
|     Settings::values.renderer_debug = ui->enable_graphics_debugging->isChecked(); |     Settings::values.renderer_debug = ui->enable_graphics_debugging->isChecked(); | ||||||
|  |     Settings::values.cpu_debug_mode = ui->enable_cpu_debugging->isChecked(); | ||||||
|     Settings::values.disable_macro_jit = ui->disable_macro_jit->isChecked(); |     Settings::values.disable_macro_jit = ui->disable_macro_jit->isChecked(); | ||||||
|     Settings::values.extended_logging = ui->extended_logging->isChecked(); |     Settings::values.extended_logging = ui->extended_logging->isChecked(); | ||||||
|     Debugger::ToggleConsole(); |     Debugger::ToggleConsole(); | ||||||
|  |  | ||||||
|  | @ -7,7 +7,7 @@ | ||||||
|     <x>0</x> |     <x>0</x> | ||||||
|     <y>0</y> |     <y>0</y> | ||||||
|     <width>400</width> |     <width>400</width> | ||||||
|     <height>486</height> |     <height>777</height> | ||||||
|    </rect> |    </rect> | ||||||
|   </property> |   </property> | ||||||
|   <property name="windowTitle"> |   <property name="windowTitle"> | ||||||
|  | @ -192,34 +192,41 @@ | ||||||
|         </property> |         </property> | ||||||
|        </widget> |        </widget> | ||||||
|       </item> |       </item> | ||||||
|        <item> |  | ||||||
|          <widget class="QCheckBox" name="use_debug_asserts"> |  | ||||||
|            <property name="text"> |  | ||||||
|              <string>Enable Debug Asserts</string> |  | ||||||
|            </property> |  | ||||||
|          </widget> |  | ||||||
|        </item> |  | ||||||
|        <item> |  | ||||||
|          <widget class="QCheckBox" name="use_auto_stub"> |  | ||||||
|            <property name="text"> |  | ||||||
|              <string>Enable Auto-Stub</string> |  | ||||||
|            </property> |  | ||||||
|          </widget> |  | ||||||
|        </item> |  | ||||||
|       <item> |       <item> | ||||||
|         <widget class="QLabel" name="label_5"> |        <widget class="QCheckBox" name="enable_cpu_debugging"> | ||||||
|           <property name="font"> |         <property name="text"> | ||||||
|             <font> |          <string>Enable CPU Debugging</string> | ||||||
|               <italic>true</italic> |         </property> | ||||||
|             </font> |        </widget> | ||||||
|           </property> |       </item> | ||||||
|           <property name="text"> |       <item> | ||||||
|             <string>This will be reset automatically when yuzu closes.</string> |        <widget class="QCheckBox" name="use_debug_asserts"> | ||||||
|           </property> |         <property name="text"> | ||||||
|           <property name="indent"> |          <string>Enable Debug Asserts</string> | ||||||
|             <number>20</number> |         </property> | ||||||
|           </property> |        </widget> | ||||||
|         </widget> |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QCheckBox" name="use_auto_stub"> | ||||||
|  |         <property name="text"> | ||||||
|  |          <string>Enable Auto-Stub</string> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|  |       </item> | ||||||
|  |       <item> | ||||||
|  |        <widget class="QLabel" name="label_5"> | ||||||
|  |         <property name="font"> | ||||||
|  |          <font> | ||||||
|  |           <italic>true</italic> | ||||||
|  |          </font> | ||||||
|  |         </property> | ||||||
|  |         <property name="text"> | ||||||
|  |          <string>This will be reset automatically when yuzu closes.</string> | ||||||
|  |         </property> | ||||||
|  |         <property name="indent"> | ||||||
|  |          <number>20</number> | ||||||
|  |         </property> | ||||||
|  |        </widget> | ||||||
|       </item> |       </item> | ||||||
|      </layout> |      </layout> | ||||||
|     </widget> |     </widget> | ||||||
|  |  | ||||||
							
								
								
									
										38
									
								
								src/yuzu/configuration/configure_debug_tab.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/yuzu/configuration/configure_debug_tab.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | ||||||
|  | // Copyright 2021 yuzu Emulator Project
 | ||||||
|  | // Licensed under GPLv2 or any later version
 | ||||||
|  | // Refer to the license.txt file included.
 | ||||||
|  | 
 | ||||||
|  | #include "ui_configure_debug_tab.h" | ||||||
|  | #include "yuzu/configuration/configure_debug_tab.h" | ||||||
|  | 
 | ||||||
|  | ConfigureDebugTab::ConfigureDebugTab(QWidget* parent) | ||||||
|  |     : QWidget(parent), ui(new Ui::ConfigureDebugTab) { | ||||||
|  |     ui->setupUi(this); | ||||||
|  | 
 | ||||||
|  |     SetConfiguration(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | ConfigureDebugTab::~ConfigureDebugTab() = default; | ||||||
|  | 
 | ||||||
|  | void ConfigureDebugTab::ApplyConfiguration() { | ||||||
|  |     ui->debugTab->ApplyConfiguration(); | ||||||
|  |     ui->cpuDebugTab->ApplyConfiguration(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDebugTab::SetCurrentIndex(int index) { | ||||||
|  |     ui->tabWidget->setCurrentIndex(index); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDebugTab::changeEvent(QEvent* event) { | ||||||
|  |     if (event->type() == QEvent::LanguageChange) { | ||||||
|  |         RetranslateUI(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     QWidget::changeEvent(event); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDebugTab::RetranslateUI() { | ||||||
|  |     ui->retranslateUi(this); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void ConfigureDebugTab::SetConfiguration() {} | ||||||
							
								
								
									
										32
									
								
								src/yuzu/configuration/configure_debug_tab.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/yuzu/configuration/configure_debug_tab.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | ||||||
|  | // Copyright 2021 yuzu Emulator Project
 | ||||||
|  | // Licensed under GPLv2 or any later version
 | ||||||
|  | // Refer to the license.txt file included.
 | ||||||
|  | 
 | ||||||
|  | #pragma once | ||||||
|  | 
 | ||||||
|  | #include <memory> | ||||||
|  | #include <QWidget> | ||||||
|  | 
 | ||||||
|  | namespace Ui { | ||||||
|  | class ConfigureDebugTab; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | class ConfigureDebugTab : public QWidget { | ||||||
|  |     Q_OBJECT | ||||||
|  | 
 | ||||||
|  | public: | ||||||
|  |     explicit ConfigureDebugTab(QWidget* parent = nullptr); | ||||||
|  |     ~ConfigureDebugTab() override; | ||||||
|  | 
 | ||||||
|  |     void ApplyConfiguration(); | ||||||
|  | 
 | ||||||
|  |     void SetCurrentIndex(int index); | ||||||
|  | 
 | ||||||
|  | private: | ||||||
|  |     void changeEvent(QEvent* event) override; | ||||||
|  |     void RetranslateUI(); | ||||||
|  | 
 | ||||||
|  |     void SetConfiguration(); | ||||||
|  | 
 | ||||||
|  |     std::unique_ptr<Ui::ConfigureDebugTab> ui; | ||||||
|  | }; | ||||||
							
								
								
									
										52
									
								
								src/yuzu/configuration/configure_debug_tab.ui
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								src/yuzu/configuration/configure_debug_tab.ui
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,52 @@ | ||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <ui version="4.0"> | ||||||
|  |  <class>ConfigureDebugTab</class> | ||||||
|  |  <widget class="QWidget" name="ConfigureDebugTab"> | ||||||
|  |   <property name="geometry"> | ||||||
|  |    <rect> | ||||||
|  |     <x>0</x> | ||||||
|  |     <y>0</y> | ||||||
|  |     <width>320</width> | ||||||
|  |     <height>240</height> | ||||||
|  |    </rect> | ||||||
|  |   </property> | ||||||
|  |   <property name="windowTitle"> | ||||||
|  |    <string>Form</string> | ||||||
|  |   </property> | ||||||
|  |   <layout class="QVBoxLayout" name="verticalLayout"> | ||||||
|  |    <item> | ||||||
|  |     <widget class="QTabWidget" name="tabWidget"> | ||||||
|  |      <property name="currentIndex"> | ||||||
|  |       <number>1</number> | ||||||
|  |      </property> | ||||||
|  |      <widget class="ConfigureDebug" name="debugTab"> | ||||||
|  |       <attribute name="title"> | ||||||
|  |        <string>General</string> | ||||||
|  |       </attribute> | ||||||
|  |      </widget> | ||||||
|  |      <widget class="ConfigureCpuDebug" name="cpuDebugTab"> | ||||||
|  |       <attribute name="title"> | ||||||
|  |        <string>CPU</string> | ||||||
|  |       </attribute> | ||||||
|  |      </widget> | ||||||
|  |     </widget> | ||||||
|  |    </item> | ||||||
|  |   </layout> | ||||||
|  |  </widget> | ||||||
|  |  <customwidgets> | ||||||
|  |   <customwidget> | ||||||
|  |    <class>ConfigureDebug</class> | ||||||
|  |    <extends>QWidget</extends> | ||||||
|  |    <header>configuration/configure_debug.h</header> | ||||||
|  |    <container>1</container> | ||||||
|  |   </customwidget> | ||||||
|  |   <customwidget> | ||||||
|  |    <class>ConfigureCpuDebug</class> | ||||||
|  |    <extends>QWidget</extends> | ||||||
|  |    <header>configuration/configure_cpu_debug.h</header> | ||||||
|  |    <container>1</container> | ||||||
|  |   </customwidget> | ||||||
|  |  </customwidgets> | ||||||
|  |  <resources/> | ||||||
|  |  <connections/> | ||||||
|  | </ui> | ||||||
|  | @ -8,6 +8,7 @@ | ||||||
| #include <QListWidgetItem> | #include <QListWidgetItem> | ||||||
| #include <QPushButton> | #include <QPushButton> | ||||||
| #include <QSignalBlocker> | #include <QSignalBlocker> | ||||||
|  | #include <QTabWidget> | ||||||
| #include "common/settings.h" | #include "common/settings.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
| #include "ui_configure.h" | #include "ui_configure.h" | ||||||
|  | @ -32,6 +33,8 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, HotkeyRegistry& registry, | ||||||
|     SetConfiguration(); |     SetConfiguration(); | ||||||
|     PopulateSelectionList(); |     PopulateSelectionList(); | ||||||
| 
 | 
 | ||||||
|  |     connect(ui->tabWidget, &QTabWidget::currentChanged, this, | ||||||
|  |             [this]() { ui->debugTab->SetCurrentIndex(0); }); | ||||||
|     connect(ui->uiTab, &ConfigureUi::LanguageChanged, this, &ConfigureDialog::OnLanguageChanged); |     connect(ui->uiTab, &ConfigureUi::LanguageChanged, this, &ConfigureDialog::OnLanguageChanged); | ||||||
|     connect(ui->selectorList, &QListWidget::itemSelectionChanged, this, |     connect(ui->selectorList, &QListWidget::itemSelectionChanged, this, | ||||||
|             &ConfigureDialog::UpdateVisibleTabs); |             &ConfigureDialog::UpdateVisibleTabs); | ||||||
|  | @ -59,7 +62,6 @@ void ConfigureDialog::ApplyConfiguration() { | ||||||
|     ui->inputTab->ApplyConfiguration(); |     ui->inputTab->ApplyConfiguration(); | ||||||
|     ui->hotkeysTab->ApplyConfiguration(registry); |     ui->hotkeysTab->ApplyConfiguration(registry); | ||||||
|     ui->cpuTab->ApplyConfiguration(); |     ui->cpuTab->ApplyConfiguration(); | ||||||
|     ui->cpuDebugTab->ApplyConfiguration(); |  | ||||||
|     ui->graphicsTab->ApplyConfiguration(); |     ui->graphicsTab->ApplyConfiguration(); | ||||||
|     ui->graphicsAdvancedTab->ApplyConfiguration(); |     ui->graphicsAdvancedTab->ApplyConfiguration(); | ||||||
|     ui->audioTab->ApplyConfiguration(); |     ui->audioTab->ApplyConfiguration(); | ||||||
|  | @ -102,7 +104,7 @@ void ConfigureDialog::PopulateSelectionList() { | ||||||
|     const std::array<std::pair<QString, QList<QWidget*>>, 6> items{ |     const std::array<std::pair<QString, QList<QWidget*>>, 6> items{ | ||||||
|         {{tr("General"), {ui->generalTab, ui->hotkeysTab, ui->uiTab, ui->webTab, ui->debugTab}}, |         {{tr("General"), {ui->generalTab, ui->hotkeysTab, ui->uiTab, ui->webTab, ui->debugTab}}, | ||||||
|          {tr("System"), {ui->systemTab, ui->profileManagerTab, ui->serviceTab, ui->filesystemTab}}, |          {tr("System"), {ui->systemTab, ui->profileManagerTab, ui->serviceTab, ui->filesystemTab}}, | ||||||
|          {tr("CPU"), {ui->cpuTab, ui->cpuDebugTab}}, |          {tr("CPU"), {ui->cpuTab}}, | ||||||
|          {tr("Graphics"), {ui->graphicsTab, ui->graphicsAdvancedTab}}, |          {tr("Graphics"), {ui->graphicsTab, ui->graphicsAdvancedTab}}, | ||||||
|          {tr("Audio"), {ui->audioTab}}, |          {tr("Audio"), {ui->audioTab}}, | ||||||
|          {tr("Controls"), ui->inputTab->GetSubTabs()}}, |          {tr("Controls"), ui->inputTab->GetSubTabs()}}, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando S
						Fernando S