| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project / PPSSPP Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-07 22:09:20 -05:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  | #include <string>
 | 
					
						
							|  |  |  | #include <unordered_map>
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  | #include <vector>
 | 
					
						
							| 
									
										
										
										
											2020-04-08 21:06:37 -04:00
										 |  |  | #include "core/hle/kernel/memory/memory_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | #include "core/hle/kernel/object.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-05 12:28:10 -05:00
										 |  |  | namespace Core { | 
					
						
							| 
									
										
										
										
											2020-02-22 10:27:40 -04:00
										 |  |  | struct EmuThreadHandle; | 
					
						
							| 
									
										
										
										
											2020-01-25 18:55:32 -04:00
										 |  |  | class ExclusiveMonitor; | 
					
						
							| 
									
										
										
										
											2019-03-05 12:28:10 -05:00
										 |  |  | class System; | 
					
						
							| 
									
										
										
										
											2020-01-26 16:14:18 -04:00
										 |  |  | } // namespace Core
 | 
					
						
							| 
									
										
										
										
											2019-03-05 12:28:10 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-12 12:32:15 -05:00
										 |  |  | namespace Core::Timing { | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  | class CoreTiming; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | struct EventType; | 
					
						
							| 
									
										
										
										
											2019-02-14 12:42:58 -05:00
										 |  |  | } // namespace Core::Timing
 | 
					
						
							| 
									
										
										
										
											2014-05-09 22:11:18 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-20 18:13:25 -04:00
										 |  |  | namespace Kernel { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 21:06:37 -04:00
										 |  |  | namespace Memory { | 
					
						
							|  |  |  | class MemoryManager; | 
					
						
							|  |  |  | template <typename T> | 
					
						
							|  |  |  | class SlabHeap; | 
					
						
							|  |  |  | } // namespace Memory
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-05 11:54:06 -05:00
										 |  |  | class AddressArbiter; | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  | class ClientPort; | 
					
						
							| 
									
										
										
										
											2019-10-12 10:13:25 -04:00
										 |  |  | class GlobalScheduler; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | class HandleTable; | 
					
						
							| 
									
										
										
										
											2020-01-25 18:55:32 -04:00
										 |  |  | class PhysicalCore; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | class Process; | 
					
						
							|  |  |  | class ResourceLimit; | 
					
						
							| 
									
										
										
										
											2020-02-13 22:04:10 -04:00
										 |  |  | class Scheduler; | 
					
						
							| 
									
										
										
										
											2020-04-08 21:06:37 -04:00
										 |  |  | class SharedMemory; | 
					
						
							| 
									
										
										
										
											2020-02-11 17:36:39 -04:00
										 |  |  | class Synchronization; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | class Thread; | 
					
						
							| 
									
										
										
										
											2020-02-14 10:56:27 -04:00
										 |  |  | class TimeManager; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// Represents a single instance of the kernel.
 | 
					
						
							|  |  |  | class KernelCore { | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  |     using NamedPortTable = std::unordered_map<std::string, std::shared_ptr<ClientPort>>; | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2019-03-05 12:28:10 -05:00
										 |  |  |     /// Constructs an instance of the kernel using the given System
 | 
					
						
							|  |  |  |     /// instance as a context for any necessary system-related state,
 | 
					
						
							|  |  |  |     /// such as threads, CPU core state, etc.
 | 
					
						
							|  |  |  |     ///
 | 
					
						
							|  |  |  |     /// @post After execution of the constructor, the provided System
 | 
					
						
							|  |  |  |     ///       object *must* outlive the kernel instance itself.
 | 
					
						
							|  |  |  |     ///
 | 
					
						
							|  |  |  |     explicit KernelCore(Core::System& system); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  |     ~KernelCore(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     KernelCore(const KernelCore&) = delete; | 
					
						
							|  |  |  |     KernelCore& operator=(const KernelCore&) = delete; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     KernelCore(KernelCore&&) = delete; | 
					
						
							|  |  |  |     KernelCore& operator=(KernelCore&&) = delete; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Resets the kernel to a clean slate for use.
 | 
					
						
							| 
									
										
										
										
											2019-03-05 12:28:10 -05:00
										 |  |  |     void Initialize(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Clears all resources in use by the kernel instance.
 | 
					
						
							|  |  |  |     void Shutdown(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-19 12:54:06 -05:00
										 |  |  |     /// Retrieves a shared pointer to the system resource limit instance.
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  |     std::shared_ptr<ResourceLimit> GetSystemResourceLimit() const; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Retrieves a shared pointer to a Thread instance within the thread wakeup handle table.
 | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  |     std::shared_ptr<Thread> RetrieveThreadFromGlobalHandleTable(Handle handle) const; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Adds the given shared pointer to an internal list of active processes.
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  |     void AppendNewProcess(std::shared_ptr<Process> process); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-06 20:34:51 -04:00
										 |  |  |     /// Makes the given process the new current process.
 | 
					
						
							| 
									
										
										
										
											2018-10-10 00:42:10 -04:00
										 |  |  |     void MakeCurrentProcess(Process* process); | 
					
						
							| 
									
										
										
										
											2018-09-06 20:34:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-10 00:42:10 -04:00
										 |  |  |     /// Retrieves a pointer to the current process.
 | 
					
						
							|  |  |  |     Process* CurrentProcess(); | 
					
						
							| 
									
										
										
										
											2018-09-06 20:34:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-10 00:42:10 -04:00
										 |  |  |     /// Retrieves a const pointer to the current process.
 | 
					
						
							|  |  |  |     const Process* CurrentProcess() const; | 
					
						
							| 
									
										
										
										
											2018-09-06 20:34:51 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-20 15:03:52 -04:00
										 |  |  |     /// Retrieves the list of processes.
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  |     const std::vector<std::shared_ptr<Process>>& GetProcessList() const; | 
					
						
							| 
									
										
										
										
											2019-03-20 15:03:52 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-29 17:02:57 -04:00
										 |  |  |     /// Gets the sole instance of the global scheduler
 | 
					
						
							|  |  |  |     Kernel::GlobalScheduler& GlobalScheduler(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the sole instance of the global scheduler
 | 
					
						
							|  |  |  |     const Kernel::GlobalScheduler& GlobalScheduler() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-13 22:04:10 -04:00
										 |  |  |     /// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
 | 
					
						
							|  |  |  |     Kernel::Scheduler& Scheduler(std::size_t id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
 | 
					
						
							|  |  |  |     const Kernel::Scheduler& Scheduler(std::size_t id) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-25 18:55:32 -04:00
										 |  |  |     /// Gets the an instance of the respective physical CPU core.
 | 
					
						
							|  |  |  |     Kernel::PhysicalCore& PhysicalCore(std::size_t id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the an instance of the respective physical CPU core.
 | 
					
						
							|  |  |  |     const Kernel::PhysicalCore& PhysicalCore(std::size_t id) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  |     /// Gets the sole instance of the Scheduler at the current running core.
 | 
					
						
							|  |  |  |     Kernel::Scheduler& CurrentScheduler(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the sole instance of the Scheduler at the current running core.
 | 
					
						
							|  |  |  |     const Kernel::Scheduler& CurrentScheduler() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the an instance of the current physical CPU core.
 | 
					
						
							|  |  |  |     Kernel::PhysicalCore& CurrentPhysicalCore(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the an instance of the current physical CPU core.
 | 
					
						
							|  |  |  |     const Kernel::PhysicalCore& CurrentPhysicalCore() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-11 17:36:39 -04:00
										 |  |  |     /// Gets the an instance of the Synchronization Interface.
 | 
					
						
							|  |  |  |     Kernel::Synchronization& Synchronization(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the an instance of the Synchronization Interface.
 | 
					
						
							|  |  |  |     const Kernel::Synchronization& Synchronization() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-14 10:56:27 -04:00
										 |  |  |     /// Gets the an instance of the TimeManager Interface.
 | 
					
						
							|  |  |  |     Kernel::TimeManager& TimeManager(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the an instance of the TimeManager Interface.
 | 
					
						
							|  |  |  |     const Kernel::TimeManager& TimeManager() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-25 18:55:32 -04:00
										 |  |  |     /// Stops execution of 'id' core, in order to reschedule a new thread.
 | 
					
						
							|  |  |  |     void PrepareReschedule(std::size_t id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Core::ExclusiveMonitor& GetExclusiveMonitor(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const Core::ExclusiveMonitor& GetExclusiveMonitor() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void InvalidateAllInstructionCaches(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  |     /// Adds a port to the named port table
 | 
					
						
							| 
									
										
										
										
											2019-11-24 20:15:51 -05:00
										 |  |  |     void AddNamedPort(std::string name, std::shared_ptr<ClientPort> port); | 
					
						
							| 
									
										
										
										
											2018-09-02 11:58:58 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Finds a port within the named port table with the given name.
 | 
					
						
							|  |  |  |     NamedPortTable::iterator FindNamedPort(const std::string& name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Finds a port within the named port table with the given name.
 | 
					
						
							|  |  |  |     NamedPortTable::const_iterator FindNamedPort(const std::string& name) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Determines whether or not the given port is a valid named port.
 | 
					
						
							|  |  |  |     bool IsValidNamedPort(NamedPortTable::const_iterator port) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  |     /// Gets the current host_thread/guest_thread handle.
 | 
					
						
							| 
									
										
										
										
											2020-02-22 10:27:40 -04:00
										 |  |  |     Core::EmuThreadHandle GetCurrentEmuThreadID() const; | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the current host_thread handle.
 | 
					
						
							| 
									
										
										
										
											2020-02-22 10:27:40 -04:00
										 |  |  |     u32 GetCurrentHostThreadID() const; | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Register the current thread as a CPU Core Thread.
 | 
					
						
							|  |  |  |     void RegisterCoreThread(std::size_t core_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Register the current thread as a non CPU core thread.
 | 
					
						
							|  |  |  |     void RegisterHostThread(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-08 21:06:37 -04:00
										 |  |  |     /// Gets the virtual memory manager for the kernel.
 | 
					
						
							|  |  |  |     Memory::MemoryManager& MemoryManager(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the virtual memory manager for the kernel.
 | 
					
						
							|  |  |  |     const Memory::MemoryManager& MemoryManager() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the slab heap allocated for user space pages.
 | 
					
						
							|  |  |  |     Memory::SlabHeap<Memory::Page>& GetUserSlabHeapPages(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the slab heap allocated for user space pages.
 | 
					
						
							|  |  |  |     const Memory::SlabHeap<Memory::Page>& GetUserSlabHeapPages() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for HID services.
 | 
					
						
							|  |  |  |     Kernel::SharedMemory& GetHidSharedMem(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for HID services.
 | 
					
						
							|  |  |  |     const Kernel::SharedMemory& GetHidSharedMem() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for font services.
 | 
					
						
							|  |  |  |     Kernel::SharedMemory& GetFontSharedMem(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for font services.
 | 
					
						
							|  |  |  |     const Kernel::SharedMemory& GetFontSharedMem() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for IRS services.
 | 
					
						
							|  |  |  |     Kernel::SharedMemory& GetIrsSharedMem(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for IRS services.
 | 
					
						
							|  |  |  |     const Kernel::SharedMemory& GetIrsSharedMem() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for Time services.
 | 
					
						
							|  |  |  |     Kernel::SharedMemory& GetTimeSharedMem(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Gets the shared memory object for Time services.
 | 
					
						
							|  |  |  |     const Kernel::SharedMemory& GetTimeSharedMem() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  |     /// Suspend/unsuspend the OS.
 | 
					
						
							|  |  |  |     void Suspend(bool in_suspention); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Exceptional exit the OS.
 | 
					
						
							|  |  |  |     void ExceptionalExit(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | private: | 
					
						
							|  |  |  |     friend class Object; | 
					
						
							|  |  |  |     friend class Process; | 
					
						
							|  |  |  |     friend class Thread; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Creates a new object ID, incrementing the internal object ID counter.
 | 
					
						
							|  |  |  |     u32 CreateNewObjectID(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Creates a new process ID, incrementing the internal process ID counter;
 | 
					
						
							| 
									
										
										
										
											2019-06-10 00:28:33 -04:00
										 |  |  |     u64 CreateNewKernelProcessID(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// Creates a new process ID, incrementing the internal process ID counter;
 | 
					
						
							|  |  |  |     u64 CreateNewUserProcessID(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Creates a new thread ID, incrementing the internal thread ID counter.
 | 
					
						
							| 
									
										
										
										
											2018-12-18 22:37:01 -05:00
										 |  |  |     u64 CreateNewThreadID(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// Retrieves the event type used for thread wakeup callbacks.
 | 
					
						
							| 
									
										
										
										
											2019-11-26 21:48:56 -05:00
										 |  |  |     const std::shared_ptr<Core::Timing::EventType>& ThreadWakeupCallbackEventType() const; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  |     /// Provides a reference to the global handle table.
 | 
					
						
							|  |  |  |     Kernel::HandleTable& GlobalHandleTable(); | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-14 09:30:53 -04:00
										 |  |  |     /// Provides a const reference to the global handle table.
 | 
					
						
							|  |  |  |     const Kernel::HandleTable& GlobalHandleTable() const; | 
					
						
							| 
									
										
										
										
											2014-06-10 22:43:50 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  |     struct Impl; | 
					
						
							|  |  |  |     std::unique_ptr<Impl> impl; | 
					
						
							| 
									
										
										
										
											2020-02-24 22:04:12 -04:00
										 |  |  |     bool exception_exited{}; | 
					
						
							| 
									
										
										
										
											2018-08-28 12:30:33 -04:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2014-06-10 22:43:50 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-20 23:52:50 -05:00
										 |  |  | } // namespace Kernel
 |