yuzu: Remove setting for using Unicorn
The JIT is mature enough that this setting can be removed, falling back to Unicorn only on unsupported architectures. Any missing features from Unicorn (of which there are extremely few), are mostly developer-oriented, which most users don't care about. Features should be coordinated with the JIT, not the interpreter, anyhow.
This commit is contained in:
		
							parent
							
								
									6b4fd5ccad
								
							
						
					
					
						commit
						66cfba50ed
					
				
					 9 changed files with 6 additions and 29 deletions
				
			
		|  | @ -53,16 +53,12 @@ bool CpuBarrier::Rendezvous() { | ||||||
| Cpu::Cpu(System& system, ExclusiveMonitor& exclusive_monitor, CpuBarrier& cpu_barrier, | Cpu::Cpu(System& system, ExclusiveMonitor& exclusive_monitor, CpuBarrier& cpu_barrier, | ||||||
|          std::size_t core_index) |          std::size_t core_index) | ||||||
|     : cpu_barrier{cpu_barrier}, core_timing{system.CoreTiming()}, core_index{core_index} { |     : cpu_barrier{cpu_barrier}, core_timing{system.CoreTiming()}, core_index{core_index} { | ||||||
|     if (Settings::values.cpu_jit_enabled) { |  | ||||||
| #ifdef ARCHITECTURE_x86_64 | #ifdef ARCHITECTURE_x86_64 | ||||||
|         arm_interface = std::make_unique<ARM_Dynarmic>(system, exclusive_monitor, core_index); |     arm_interface = std::make_unique<ARM_Dynarmic>(system, exclusive_monitor, core_index); | ||||||
| #else | #else | ||||||
|         arm_interface = std::make_unique<ARM_Unicorn>(system); |     arm_interface = std::make_unique<ARM_Unicorn>(system); | ||||||
|         LOG_WARNING(Core, "CPU JIT requested, but Dynarmic not available"); |     LOG_WARNING(Core, "CPU JIT requested, but Dynarmic not available"); | ||||||
| #endif | #endif | ||||||
|     } else { |  | ||||||
|         arm_interface = std::make_unique<ARM_Unicorn>(system); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     scheduler = std::make_unique<Kernel::Scheduler>(system, *arm_interface); |     scheduler = std::make_unique<Kernel::Scheduler>(system, *arm_interface); | ||||||
| } | } | ||||||
|  | @ -70,15 +66,12 @@ Cpu::Cpu(System& system, ExclusiveMonitor& exclusive_monitor, CpuBarrier& cpu_ba | ||||||
| Cpu::~Cpu() = default; | Cpu::~Cpu() = default; | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<ExclusiveMonitor> Cpu::MakeExclusiveMonitor(std::size_t num_cores) { | std::unique_ptr<ExclusiveMonitor> Cpu::MakeExclusiveMonitor(std::size_t num_cores) { | ||||||
|     if (Settings::values.cpu_jit_enabled) { |  | ||||||
| #ifdef ARCHITECTURE_x86_64 | #ifdef ARCHITECTURE_x86_64 | ||||||
|         return std::make_unique<DynarmicExclusiveMonitor>(num_cores); |     return std::make_unique<DynarmicExclusiveMonitor>(num_cores); | ||||||
| #else | #else | ||||||
|         return nullptr; // TODO(merry): Passthrough exclusive monitor
 |     // TODO(merry): Passthrough exclusive monitor
 | ||||||
|  |     return nullptr; | ||||||
| #endif | #endif | ||||||
|     } else { |  | ||||||
|         return nullptr; // TODO(merry): Passthrough exclusive monitor
 |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Cpu::RunLoop(bool tight_loop) { | void Cpu::RunLoop(bool tight_loop) { | ||||||
|  |  | ||||||
|  | @ -85,7 +85,6 @@ void LogSettings() { | ||||||
|     LogSetting("System_RngSeed", Settings::values.rng_seed.value_or(0)); |     LogSetting("System_RngSeed", Settings::values.rng_seed.value_or(0)); | ||||||
|     LogSetting("System_CurrentUser", Settings::values.current_user); |     LogSetting("System_CurrentUser", Settings::values.current_user); | ||||||
|     LogSetting("System_LanguageIndex", Settings::values.language_index); |     LogSetting("System_LanguageIndex", Settings::values.language_index); | ||||||
|     LogSetting("Core_CpuJitEnabled", Settings::values.cpu_jit_enabled); |  | ||||||
|     LogSetting("Core_UseMultiCore", Settings::values.use_multi_core); |     LogSetting("Core_UseMultiCore", Settings::values.use_multi_core); | ||||||
|     LogSetting("Renderer_UseResolutionFactor", Settings::values.resolution_factor); |     LogSetting("Renderer_UseResolutionFactor", Settings::values.resolution_factor); | ||||||
|     LogSetting("Renderer_UseFrameLimit", Settings::values.use_frame_limit); |     LogSetting("Renderer_UseFrameLimit", Settings::values.use_frame_limit); | ||||||
|  |  | ||||||
|  | @ -378,7 +378,6 @@ struct Values { | ||||||
|     std::atomic_bool is_device_reload_pending{true}; |     std::atomic_bool is_device_reload_pending{true}; | ||||||
| 
 | 
 | ||||||
|     // Core
 |     // Core
 | ||||||
|     bool cpu_jit_enabled; |  | ||||||
|     bool use_multi_core; |     bool use_multi_core; | ||||||
| 
 | 
 | ||||||
|     // Data Storage
 |     // Data Storage
 | ||||||
|  |  | ||||||
|  | @ -168,7 +168,6 @@ void TelemetrySession::AddInitialInfo(Loader::AppLoader& app_loader) { | ||||||
|     AddField(Telemetry::FieldType::UserConfig, "Audio_SinkId", Settings::values.sink_id); |     AddField(Telemetry::FieldType::UserConfig, "Audio_SinkId", Settings::values.sink_id); | ||||||
|     AddField(Telemetry::FieldType::UserConfig, "Audio_EnableAudioStretching", |     AddField(Telemetry::FieldType::UserConfig, "Audio_EnableAudioStretching", | ||||||
|              Settings::values.enable_audio_stretching); |              Settings::values.enable_audio_stretching); | ||||||
|     AddField(Telemetry::FieldType::UserConfig, "Core_UseCpuJit", Settings::values.cpu_jit_enabled); |  | ||||||
|     AddField(Telemetry::FieldType::UserConfig, "Core_UseMultiCore", |     AddField(Telemetry::FieldType::UserConfig, "Core_UseMultiCore", | ||||||
|              Settings::values.use_multi_core); |              Settings::values.use_multi_core); | ||||||
|     AddField(Telemetry::FieldType::UserConfig, "Renderer_ResolutionFactor", |     AddField(Telemetry::FieldType::UserConfig, "Renderer_ResolutionFactor", | ||||||
|  |  | ||||||
|  | @ -436,8 +436,6 @@ void Config::ReadControlValues() { | ||||||
| void Config::ReadCoreValues() { | void Config::ReadCoreValues() { | ||||||
|     qt_config->beginGroup(QStringLiteral("Core")); |     qt_config->beginGroup(QStringLiteral("Core")); | ||||||
| 
 | 
 | ||||||
|     Settings::values.cpu_jit_enabled = |  | ||||||
|         ReadSetting(QStringLiteral("cpu_jit_enabled"), true).toBool(); |  | ||||||
|     Settings::values.use_multi_core = ReadSetting(QStringLiteral("use_multi_core"), false).toBool(); |     Settings::values.use_multi_core = ReadSetting(QStringLiteral("use_multi_core"), false).toBool(); | ||||||
| 
 | 
 | ||||||
|     qt_config->endGroup(); |     qt_config->endGroup(); | ||||||
|  | @ -831,7 +829,6 @@ void Config::SaveControlValues() { | ||||||
| void Config::SaveCoreValues() { | void Config::SaveCoreValues() { | ||||||
|     qt_config->beginGroup(QStringLiteral("Core")); |     qt_config->beginGroup(QStringLiteral("Core")); | ||||||
| 
 | 
 | ||||||
|     WriteSetting(QStringLiteral("cpu_jit_enabled"), Settings::values.cpu_jit_enabled, true); |  | ||||||
|     WriteSetting(QStringLiteral("use_multi_core"), Settings::values.use_multi_core, false); |     WriteSetting(QStringLiteral("use_multi_core"), Settings::values.use_multi_core, false); | ||||||
| 
 | 
 | ||||||
|     qt_config->endGroup(); |     qt_config->endGroup(); | ||||||
|  |  | ||||||
|  | @ -340,7 +340,6 @@ void Config::ReadValues() { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Core
 |     // Core
 | ||||||
|     Settings::values.cpu_jit_enabled = sdl2_config->GetBoolean("Core", "cpu_jit_enabled", true); |  | ||||||
|     Settings::values.use_multi_core = sdl2_config->GetBoolean("Core", "use_multi_core", false); |     Settings::values.use_multi_core = sdl2_config->GetBoolean("Core", "use_multi_core", false); | ||||||
| 
 | 
 | ||||||
|     // Renderer
 |     // Renderer
 | ||||||
|  |  | ||||||
|  | @ -76,10 +76,6 @@ motion_device= | ||||||
| touch_device= | touch_device= | ||||||
| 
 | 
 | ||||||
| [Core] | [Core] | ||||||
| # Whether to use the Just-In-Time (JIT) compiler for CPU emulation |  | ||||||
| # 0: Interpreter (slow), 1 (default): JIT (fast) |  | ||||||
| cpu_jit_enabled = |  | ||||||
| 
 |  | ||||||
| # Whether to use multi-core for CPU emulation | # Whether to use multi-core for CPU emulation | ||||||
| # 0 (default): Disabled, 1: Enabled | # 0 (default): Disabled, 1: Enabled | ||||||
| use_multi_core= | use_multi_core= | ||||||
|  |  | ||||||
|  | @ -114,7 +114,6 @@ void Config::ReadValues() { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Core
 |     // Core
 | ||||||
|     Settings::values.cpu_jit_enabled = sdl2_config->GetBoolean("Core", "cpu_jit_enabled", true); |  | ||||||
|     Settings::values.use_multi_core = sdl2_config->GetBoolean("Core", "use_multi_core", false); |     Settings::values.use_multi_core = sdl2_config->GetBoolean("Core", "use_multi_core", false); | ||||||
| 
 | 
 | ||||||
|     // Renderer
 |     // Renderer
 | ||||||
|  |  | ||||||
|  | @ -8,10 +8,6 @@ namespace DefaultINI { | ||||||
| 
 | 
 | ||||||
| const char* sdl2_config_file = R"( | const char* sdl2_config_file = R"( | ||||||
| [Core] | [Core] | ||||||
| # Whether to use the Just-In-Time (JIT) compiler for CPU emulation |  | ||||||
| # 0: Interpreter (slow), 1 (default): JIT (fast) |  | ||||||
| cpu_jit_enabled = |  | ||||||
| 
 |  | ||||||
| # Whether to use multi-core for CPU emulation | # Whether to use multi-core for CPU emulation | ||||||
| # 0 (default): Disabled, 1: Enabled | # 0 (default): Disabled, 1: Enabled | ||||||
| use_multi_core= | use_multi_core= | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash