| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | #include <cstddef>
 | 
					
						
							| 
									
										
										
										
											2020-11-24 15:16:24 -08:00
										 |  |  | #include <functional>
 | 
					
						
							| 
									
										
										
										
											2015-12-29 18:03:08 -05:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:30:09 -02:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-28 14:00:44 -05:00
										 |  |  | #include "core/file_sys/vfs_types.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-22 04:30:09 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-11 20:20:19 -04:00
										 |  |  | namespace Core::Frontend { | 
					
						
							|  |  |  | class EmuWindow; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | } // namespace Core::Frontend
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							| 
									
										
										
										
											2018-12-28 00:03:01 -05:00
										 |  |  | class ContentProvider; | 
					
						
							|  |  |  | class ContentProviderUnion; | 
					
						
							|  |  |  | enum class ContentProviderUnionSlot; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | class VfsFilesystem; | 
					
						
							|  |  |  | } // namespace FileSys
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Kernel { | 
					
						
							| 
									
										
										
										
											2020-12-02 18:08:35 -08:00
										 |  |  | class GlobalSchedulerContext; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | class KernelCore; | 
					
						
							| 
									
										
										
										
											2020-02-25 13:22:11 -04:00
										 |  |  | class PhysicalCore; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | class Process; | 
					
						
							| 
									
										
										
										
											2020-12-02 18:08:35 -08:00
										 |  |  | class KScheduler; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | } // namespace Kernel
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Loader { | 
					
						
							|  |  |  | class AppLoader; | 
					
						
							|  |  |  | enum class ResultStatus : u16; | 
					
						
							|  |  |  | } // namespace Loader
 | 
					
						
							| 
									
										
										
										
											2018-08-11 20:20:19 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-31 15:10:44 -04:00
										 |  |  | namespace Core::Memory { | 
					
						
							| 
									
										
										
										
											2019-05-30 19:36:18 -04:00
										 |  |  | struct CheatEntry; | 
					
						
							| 
									
										
										
										
											2020-03-31 15:10:44 -04:00
										 |  |  | class Memory; | 
					
						
							|  |  |  | } // namespace Core::Memory
 | 
					
						
							| 
									
										
										
										
											2019-05-30 19:36:18 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-11 19:33:49 -04:00
										 |  |  | namespace Service { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace AM::Applets { | 
					
						
							|  |  |  | struct AppletFrontendSet; | 
					
						
							|  |  |  | class AppletManager; | 
					
						
							|  |  |  | } // namespace AM::Applets
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-28 22:46:31 -04:00
										 |  |  | namespace APM { | 
					
						
							|  |  |  | class Controller; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-23 08:35:33 -04:00
										 |  |  | namespace FileSystem { | 
					
						
							|  |  |  | class FileSystemController; | 
					
						
							|  |  |  | } // namespace FileSystem
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-24 19:27:35 -04:00
										 |  |  | namespace Glue { | 
					
						
							|  |  |  | class ARPManager; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-11 19:33:49 -04:00
										 |  |  | namespace SM { | 
					
						
							| 
									
										
										
										
											2018-04-20 19:29:04 -04:00
										 |  |  | class ServiceManager; | 
					
						
							| 
									
										
										
										
											2019-03-11 19:33:49 -04:00
										 |  |  | } // namespace SM
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-12 18:09:15 -07:00
										 |  |  | namespace Time { | 
					
						
							|  |  |  | class TimeManager; | 
					
						
							|  |  |  | } // namespace Time
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-11 19:33:49 -04:00
										 |  |  | } // namespace Service
 | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Tegra { | 
					
						
							|  |  |  | class DebugContext; | 
					
						
							|  |  |  | class GPU; | 
					
						
							|  |  |  | } // namespace Tegra
 | 
					
						
							| 
									
										
										
										
											2018-04-20 19:29:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | namespace VideoCore { | 
					
						
							|  |  |  | class RendererBase; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | } // namespace VideoCore
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  | namespace Core::Timing { | 
					
						
							|  |  |  | class CoreTiming; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-07 20:41:06 -04:00
										 |  |  | namespace Core::Hardware { | 
					
						
							|  |  |  | class InterruptManager; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | namespace Core { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-24 21:43:32 -04:00
										 |  |  | class ARM_Interface; | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  | class CpuManager; | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | class DeviceMemory; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | class ExclusiveMonitor; | 
					
						
							|  |  |  | class FrameLimiter; | 
					
						
							|  |  |  | class PerfStats; | 
					
						
							| 
									
										
										
										
											2019-05-17 21:45:56 -04:00
										 |  |  | class Reporter; | 
					
						
							| 
									
										
										
										
											2018-08-31 12:21:34 -04:00
										 |  |  | class TelemetrySession; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct PerfStatsResults; | 
					
						
							| 
									
										
										
										
											2018-08-24 21:43:32 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-28 14:00:44 -05:00
										 |  |  | FileSys::VirtualFile GetGameFileFromPath(const FileSys::VirtualFilesystem& vfs, | 
					
						
							|  |  |  |                                          const std::string& path); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | class System { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2019-10-06 13:02:23 -04:00
										 |  |  |     using CurrentBuildProcessID = std::array<u8, 0x20>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 10:15:00 -04:00
										 |  |  |     System(const System&) = delete; | 
					
						
							|  |  |  |     System& operator=(const System&) = delete; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     System(System&&) = delete; | 
					
						
							|  |  |  |     System& operator=(System&&) = delete; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-20 19:29:04 -04:00
										 |  |  |     ~System(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the instance of the System singleton class. | 
					
						
							|  |  |  |      * @returns Reference to the instance of the System singleton class. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-09-25 19:15:21 -04:00
										 |  |  |     [[deprecated("Use of the global system instance is deprecated")]] static System& GetInstance() { | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |         return s_instance; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Enumeration representing the return values of the System Initialize and Load process.
 | 
					
						
							|  |  |  |     enum class ResultStatus : u32 { | 
					
						
							| 
									
										
										
										
											2018-08-09 21:06:44 -04:00
										 |  |  |         Success,             ///< Succeeded
 | 
					
						
							|  |  |  |         ErrorNotInitialized, ///< Error trying to use core prior to initialization
 | 
					
						
							|  |  |  |         ErrorGetLoader,      ///< Error finding the correct application loader
 | 
					
						
							|  |  |  |         ErrorSystemFiles,    ///< Error in finding system files
 | 
					
						
							|  |  |  |         ErrorSharedFont,     ///< Error in finding shared font
 | 
					
						
							|  |  |  |         ErrorVideoCore,      ///< Error in the video core
 | 
					
						
							|  |  |  |         ErrorUnknown,        ///< Any other error
 | 
					
						
							|  |  |  |         ErrorLoader,         ///< The base for loader errors (too many to repeat)
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  |      * Run the OS and Application | 
					
						
							| 
									
										
										
										
											2020-06-27 18:20:06 -04:00
										 |  |  |      * This function will start emulation and run the relevant devices | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ResultStatus Run(); | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Pause the OS and Application | 
					
						
							| 
									
										
										
										
											2020-06-27 18:20:06 -04:00
										 |  |  |      * This function will pause emulation and stop the relevant devices | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ResultStatus Pause(); | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Step the CPU one instruction | 
					
						
							| 
									
										
										
										
											2018-01-23 14:20:18 +01:00
										 |  |  |      * @return Result status, indicating whether or not the operation succeeded. | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ResultStatus SingleStep(); | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-07 03:01:24 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Invalidate the CPU instruction caches | 
					
						
							|  |  |  |      * This function should only be used by GDB Stub to support breakpoints, memory updates and | 
					
						
							|  |  |  |      * step/continue commands. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     void InvalidateCpuInstructionCaches(); | 
					
						
							| 
									
										
										
										
											2018-08-07 03:01:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-13 23:20:32 -08:00
										 |  |  |     void InvalidateCpuInstructionCacheRange(VAddr addr, std::size_t size); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |     /// Shutdown the emulated system.
 | 
					
						
							|  |  |  |     void Shutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Load an executable application. | 
					
						
							| 
									
										
										
										
											2018-08-01 20:59:42 -04:00
										 |  |  |      * @param emu_window Reference to the host-system window used for video output and keyboard | 
					
						
							|  |  |  |      *                   input. | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |      * @param filepath String path to the executable application to load on the host file system. | 
					
						
							| 
									
										
										
										
											2020-11-24 15:16:24 -08:00
										 |  |  |      * @param program_index Specifies the index within the container of the program to launch. | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |      * @returns ResultStatus code, indicating if the operation succeeded. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-11-24 15:16:24 -08:00
										 |  |  |     [[nodiscard]] ResultStatus Load(Frontend::EmuWindow& emu_window, const std::string& filepath, | 
					
						
							|  |  |  |                                     std::size_t program_index = 0); | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Indicates if the emulated system is powered on (all subsystems initialized and able to run an | 
					
						
							|  |  |  |      * application). | 
					
						
							|  |  |  |      * @returns True if the emulated system is powered on, otherwise false. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] bool IsPoweredOn() const; | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets a reference to the telemetry session for this emulation session.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::TelemetrySession& TelemetrySession(); | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a reference to the telemetry session for this emulation session.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::TelemetrySession& TelemetrySession() const; | 
					
						
							| 
									
										
										
										
											2017-05-02 00:09:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-16 00:37:38 -05:00
										 |  |  |     /// Prepare the core emulation for a reschedule
 | 
					
						
							|  |  |  |     void PrepareReschedule(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 09:22:53 -04:00
										 |  |  |     /// Prepare the core emulation for a reschedule
 | 
					
						
							| 
									
										
										
										
											2019-06-19 09:11:18 -04:00
										 |  |  |     void PrepareReschedule(u32 core_index); | 
					
						
							| 
									
										
										
										
											2019-04-02 09:22:53 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-10 19:34:21 -04:00
										 |  |  |     /// Gets and resets core performance statistics
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] PerfStatsResults GetAndResetPerfStats(); | 
					
						
							| 
									
										
										
										
											2017-02-19 14:34:47 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-10 19:34:21 -04:00
										 |  |  |     /// Gets an ARM interface to the CPU core that is currently running
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ARM_Interface& CurrentArmInterface(); | 
					
						
							| 
									
										
										
										
											2018-05-02 22:36:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets an ARM interface to the CPU core that is currently running
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const ARM_Interface& CurrentArmInterface() const; | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-03 14:28:46 +01:00
										 |  |  |     /// Gets the index of the currently running CPU core
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] std::size_t CurrentCoreIndex() const; | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-25 13:22:11 -04:00
										 |  |  |     /// Gets the physical core for the CPU core that is currently running
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Kernel::PhysicalCore& CurrentPhysicalCore(); | 
					
						
							| 
									
										
										
										
											2020-02-25 13:22:11 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the physical core for the CPU core that is currently running
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Kernel::PhysicalCore& CurrentPhysicalCore() const; | 
					
						
							| 
									
										
										
										
											2020-02-25 13:22:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets a reference to an ARM interface for the CPU core with the specified index
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ARM_Interface& ArmInterface(std::size_t core_index); | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets a const reference to an ARM interface from the CPU core with the specified index
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const ARM_Interface& ArmInterface(std::size_t core_index) const; | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     /// Gets a reference to the underlying CPU manager.
 | 
					
						
							|  |  |  |     [[nodiscard]] CpuManager& GetCpuManager(); | 
					
						
							| 
									
										
										
										
											2018-05-05 23:54:43 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     /// Gets a const reference to the underlying CPU manager
 | 
					
						
							|  |  |  |     [[nodiscard]] const CpuManager& GetCpuManager() const; | 
					
						
							| 
									
										
										
										
											2018-10-15 09:25:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets a reference to the exclusive monitor
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] ExclusiveMonitor& Monitor(); | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  |     /// Gets a constant reference to the exclusive monitor
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const ExclusiveMonitor& Monitor() const; | 
					
						
							| 
									
										
										
										
											2018-10-28 17:37:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-26 12:33:20 -05:00
										 |  |  |     /// Gets a mutable reference to the system memory instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::Memory::Memory& Memory(); | 
					
						
							| 
									
										
										
										
											2019-11-26 12:33:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a constant reference to the system memory instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::Memory::Memory& Memory() const; | 
					
						
							| 
									
										
										
										
											2019-11-26 12:33:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  |     /// Gets a mutable reference to the GPU interface
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Tegra::GPU& GPU(); | 
					
						
							| 
									
										
										
										
											2018-02-11 23:44:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  |     /// Gets an immutable reference to the GPU interface.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Tegra::GPU& GPU() const; | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets a mutable reference to the renderer.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] VideoCore::RendererBase& Renderer(); | 
					
						
							| 
									
										
										
										
											2018-08-03 12:55:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets an immutable reference to the renderer.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const VideoCore::RendererBase& Renderer() const; | 
					
						
							| 
									
										
										
										
											2018-07-03 14:28:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-29 17:02:57 -04:00
										 |  |  |     /// Gets the global scheduler
 | 
					
						
							| 
									
										
										
										
											2020-12-02 18:08:35 -08:00
										 |  |  |     [[nodiscard]] Kernel::GlobalSchedulerContext& GlobalSchedulerContext(); | 
					
						
							| 
									
										
										
										
											2019-03-29 17:02:57 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the global scheduler
 | 
					
						
							| 
									
										
										
										
											2020-12-02 18:08:35 -08:00
										 |  |  |     [[nodiscard]] const Kernel::GlobalSchedulerContext& GlobalSchedulerContext() const; | 
					
						
							| 
									
										
										
										
											2019-03-29 17:02:57 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  |     /// Gets the manager for the guest device memory
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::DeviceMemory& DeviceMemory(); | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the manager for the guest device memory
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::DeviceMemory& DeviceMemory() const; | 
					
						
							| 
									
										
										
										
											2020-04-02 22:00:41 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-10 00:42:10 -04:00
										 |  |  |     /// Provides a pointer to the current process
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Kernel::Process* CurrentProcess(); | 
					
						
							| 
									
										
										
										
											2018-03-13 17:49:59 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-10 00:42:10 -04:00
										 |  |  |     /// Provides a constant pointer to the current process.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Kernel::Process* CurrentProcess() const; | 
					
						
							| 
									
										
										
										
											2018-09-06 20:34:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  |     /// Provides a reference to the core timing instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Timing::CoreTiming& CoreTiming(); | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Provides a constant reference to the core timing instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Timing::CoreTiming& CoreTiming() const; | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-07 20:41:06 -04:00
										 |  |  |     /// Provides a reference to the interrupt manager instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::Hardware::InterruptManager& InterruptManager(); | 
					
						
							| 
									
										
										
										
											2019-06-07 20:41:06 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Provides a constant reference to the interrupt manager instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::Hardware::InterruptManager& InterruptManager() const; | 
					
						
							| 
									
										
										
										
											2019-06-07 20:41:06 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  |     /// Provides a reference to the kernel instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Kernel::KernelCore& Kernel(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Provides a constant reference to the kernel instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Kernel::KernelCore& Kernel() const; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     /// Provides a reference to the internal PerfStats instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::PerfStats& GetPerfStats(); | 
					
						
							| 
									
										
										
										
											2018-08-23 14:12:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     /// Provides a constant reference to the internal PerfStats instance.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::PerfStats& GetPerfStats() const; | 
					
						
							| 
									
										
										
										
											2017-02-19 14:34:47 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     /// Provides a reference to the frame limiter;
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Core::FrameLimiter& FrameLimiter(); | 
					
						
							| 
									
										
										
										
											2017-04-13 01:15:23 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     /// Provides a constant referent to the frame limiter
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Core::FrameLimiter& FrameLimiter() const; | 
					
						
							| 
									
										
										
										
											2017-03-08 16:28:30 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     /// Gets the name of the current game
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Loader::ResultStatus GetGameName(std::string& out) const; | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void SetStatus(ResultStatus new_status, const char* details); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const std::string& GetStatusDetails() const; | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Loader::AppLoader& GetAppLoader(); | 
					
						
							|  |  |  |     [[nodiscard]] const Loader::AppLoader& GetAppLoader() const; | 
					
						
							| 
									
										
										
										
											2017-08-01 19:53:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::SM::ServiceManager& ServiceManager(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::SM::ServiceManager& ServiceManager() const; | 
					
						
							| 
									
										
										
										
											2018-04-20 19:29:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-16 18:14:43 -04:00
										 |  |  |     void SetFilesystem(FileSys::VirtualFilesystem vfs); | 
					
						
							| 
									
										
										
										
											2018-08-03 11:51:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] FileSys::VirtualFilesystem GetFilesystem() const; | 
					
						
							| 
									
										
										
										
											2018-08-03 11:51:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 19:36:18 -04:00
										 |  |  |     void RegisterCheatList(const std::vector<Memory::CheatEntry>& list, | 
					
						
							|  |  |  |                            const std::array<u8, 0x20>& build_id, VAddr main_region_begin, | 
					
						
							|  |  |  |                            u64 main_region_size); | 
					
						
							| 
									
										
										
										
											2018-12-22 21:32:05 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-11 19:33:49 -04:00
										 |  |  |     void SetAppletFrontendSet(Service::AM::Applets::AppletFrontendSet&& set); | 
					
						
							|  |  |  |     void SetDefaultAppletFrontendSet(); | 
					
						
							| 
									
										
										
										
											2018-11-11 16:39:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::AM::Applets::AppletManager& GetAppletManager(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::AM::Applets::AppletManager& GetAppletManager() const; | 
					
						
							| 
									
										
										
										
											2018-12-24 16:22:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-28 00:03:01 -05:00
										 |  |  |     void SetContentProvider(std::unique_ptr<FileSys::ContentProviderUnion> provider); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] FileSys::ContentProvider& GetContentProvider(); | 
					
						
							|  |  |  |     [[nodiscard]] const FileSys::ContentProvider& GetContentProvider() const; | 
					
						
							| 
									
										
										
										
											2018-12-28 00:03:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::FileSystem::FileSystemController& GetFileSystemController(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::FileSystem::FileSystemController& GetFileSystemController() const; | 
					
						
							| 
									
										
										
										
											2019-04-23 08:35:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-28 00:03:01 -05:00
										 |  |  |     void RegisterContentProvider(FileSys::ContentProviderUnionSlot slot, | 
					
						
							|  |  |  |                                  FileSys::ContentProvider* provider); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void ClearContentProvider(FileSys::ContentProviderUnionSlot slot); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const Reporter& GetReporter() const; | 
					
						
							| 
									
										
										
										
											2019-06-24 19:27:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::Glue::ARPManager& GetARPManager(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::Glue::ARPManager& GetARPManager() const; | 
					
						
							| 
									
										
										
										
											2019-06-24 19:27:35 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::APM::Controller& GetAPMController(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::APM::Controller& GetAPMController() const; | 
					
						
							| 
									
										
										
										
											2019-06-28 22:46:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] Service::Time::TimeManager& GetTimeManager(); | 
					
						
							|  |  |  |     [[nodiscard]] const Service::Time::TimeManager& GetTimeManager() const; | 
					
						
							| 
									
										
										
										
											2020-10-12 18:09:15 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-06 13:08:33 -04:00
										 |  |  |     void SetExitLock(bool locked); | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] bool GetExitLock() const; | 
					
						
							| 
									
										
										
										
											2019-07-06 13:08:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-06 13:02:23 -04:00
										 |  |  |     void SetCurrentProcessBuildID(const CurrentBuildProcessID& id); | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] const CurrentBuildProcessID& GetCurrentProcessBuildID() const; | 
					
						
							| 
									
										
										
										
											2019-04-28 18:43:48 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-22 11:13:07 -04:00
										 |  |  |     /// Register a host thread as an emulated CPU Core.
 | 
					
						
							|  |  |  |     void RegisterCoreThread(std::size_t id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Register a host thread as an auxiliary thread.
 | 
					
						
							|  |  |  |     void RegisterHostThread(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-12 16:48:43 -04:00
										 |  |  |     /// Enter Dynarmic Microprofile
 | 
					
						
							|  |  |  |     void EnterDynarmicProfile(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Exit Dynarmic Microprofile
 | 
					
						
							|  |  |  |     void ExitDynarmicProfile(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-29 15:00:17 -04:00
										 |  |  |     /// Tells if system is running on multicore.
 | 
					
						
							| 
									
										
										
										
											2020-11-18 02:06:42 -05:00
										 |  |  |     [[nodiscard]] bool IsMulticore() const; | 
					
						
							| 
									
										
										
										
											2020-05-29 15:00:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-24 15:16:24 -08:00
										 |  |  |     /// Type used for the frontend to designate a callback for System to re-launch the application
 | 
					
						
							|  |  |  |     /// using a specified program index.
 | 
					
						
							|  |  |  |     using ExecuteProgramCallback = std::function<void(std::size_t)>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Registers a callback from the frontend for System to re-launch the application using a | 
					
						
							|  |  |  |      * specified program index. | 
					
						
							|  |  |  |      * @param callback Callback from the frontend to relaunch the application. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void RegisterExecuteProgramCallback(ExecuteProgramCallback&& callback); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Instructs the frontend to re-launch the application using the specified program_index. | 
					
						
							|  |  |  |      * @param program_index Specifies the index within the application of the program to launch. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void ExecuteProgram(std::size_t program_index); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-14 16:07:40 -07:00
										 |  |  |     /// Applies any changes to settings to this core instance.
 | 
					
						
							|  |  |  |     void ApplySettings(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-07-18 18:15:16 -04:00
										 |  |  |     System(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-30 10:50:54 -04:00
										 |  |  |     struct Impl; | 
					
						
							|  |  |  |     std::unique_ptr<Impl> impl; | 
					
						
							| 
									
										
										
										
											2017-05-02 00:09:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  |     static System s_instance; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2013-09-05 18:33:46 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 19:01:48 -05:00
										 |  |  | } // namespace Core
 |