2021-03-20 00:53:00 -07:00
|
|
|
// Copyright 2021 yuzu Emulator Project
|
2014-12-16 21:38:14 -08:00
|
|
|
// Licensed under GPLv2 or any later version
|
2014-11-19 00:49:13 -08:00
|
|
|
// Refer to the license.txt file included.
|
2014-05-09 19:11:18 -07:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-03-01 08:14:17 -08:00
|
|
|
#include <array>
|
2021-09-08 17:04:29 -07:00
|
|
|
#include <functional>
|
2019-12-07 19:09:20 -08:00
|
|
|
#include <memory>
|
2018-09-02 08:58:58 -07:00
|
|
|
#include <string>
|
|
|
|
#include <unordered_map>
|
2019-11-24 17:15:51 -08:00
|
|
|
#include <vector>
|
2020-07-16 10:51:51 -07:00
|
|
|
#include "core/arm/cpu_interrupt_handler.h"
|
2020-03-01 08:14:17 -08:00
|
|
|
#include "core/hardware_properties.h"
|
2021-04-09 22:10:14 -07:00
|
|
|
#include "core/hle/kernel/k_auto_object.h"
|
|
|
|
#include "core/hle/kernel/k_slab_heap.h"
|
2021-04-24 02:40:31 -07:00
|
|
|
#include "core/hle/kernel/svc_common.h"
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2019-03-05 09:28:10 -08:00
|
|
|
namespace Core {
|
2020-03-01 08:14:17 -08:00
|
|
|
class CPUInterruptHandler;
|
2020-01-25 14:55:32 -08:00
|
|
|
class ExclusiveMonitor;
|
2019-03-05 09:28:10 -08:00
|
|
|
class System;
|
2020-01-26 12:14:18 -08:00
|
|
|
} // namespace Core
|
2019-03-05 09:28:10 -08:00
|
|
|
|
2019-02-12 09:32:15 -08:00
|
|
|
namespace Core::Timing {
|
2019-02-14 09:42:58 -08:00
|
|
|
class CoreTiming;
|
2018-08-28 09:30:33 -07:00
|
|
|
struct EventType;
|
2019-02-14 09:42:58 -08:00
|
|
|
} // namespace Core::Timing
|
2014-05-09 19:11:18 -07:00
|
|
|
|
2021-05-10 15:57:59 -07:00
|
|
|
namespace Service::SM {
|
|
|
|
class ServiceManager;
|
|
|
|
}
|
|
|
|
|
2014-05-20 15:13:25 -07:00
|
|
|
namespace Kernel {
|
|
|
|
|
2021-04-21 21:43:25 -07:00
|
|
|
class KClientPort;
|
2020-12-02 18:08:35 -08:00
|
|
|
class GlobalSchedulerContext;
|
2021-04-03 19:11:46 -07:00
|
|
|
class KAutoObjectWithListContainer;
|
2021-04-13 17:48:37 -07:00
|
|
|
class KClientSession;
|
2021-04-09 22:10:14 -07:00
|
|
|
class KEvent;
|
2021-04-24 02:40:31 -07:00
|
|
|
class KHandleTable;
|
2021-04-09 22:10:14 -07:00
|
|
|
class KLinkedListNode;
|
2022-02-26 10:46:31 -08:00
|
|
|
class KMemoryLayout;
|
2021-02-12 17:38:40 -08:00
|
|
|
class KMemoryManager;
|
2022-03-11 16:11:57 -08:00
|
|
|
class KPageBuffer;
|
2021-04-23 17:00:15 -07:00
|
|
|
class KPort;
|
2021-04-23 22:04:28 -07:00
|
|
|
class KProcess;
|
2021-01-30 01:40:49 -08:00
|
|
|
class KResourceLimit;
|
2020-12-02 18:08:35 -08:00
|
|
|
class KScheduler;
|
2021-07-02 15:19:04 -07:00
|
|
|
class KServerSession;
|
2021-04-13 17:48:37 -07:00
|
|
|
class KSession;
|
2021-02-05 23:14:31 -08:00
|
|
|
class KSharedMemory;
|
2021-09-25 08:01:53 -07:00
|
|
|
class KSharedMemoryInfo;
|
2021-02-12 17:38:40 -08:00
|
|
|
class KThread;
|
2022-03-11 16:11:57 -08:00
|
|
|
class KThreadLocalPage;
|
2021-04-17 00:52:53 -07:00
|
|
|
class KTransferMemory;
|
2022-01-14 16:25:37 -08:00
|
|
|
class KWorkerTaskManager;
|
2021-04-10 02:34:26 -07:00
|
|
|
class KWritableEvent;
|
2021-12-05 12:04:08 -08:00
|
|
|
class KCodeMemory;
|
2021-02-12 17:38:40 -08:00
|
|
|
class PhysicalCore;
|
2020-12-15 00:41:48 -08:00
|
|
|
class ServiceThread;
|
2020-02-11 13:36:39 -08:00
|
|
|
class Synchronization;
|
2020-02-14 06:56:27 -08:00
|
|
|
class TimeManager;
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2021-05-10 15:57:59 -07:00
|
|
|
using ServiceInterfaceFactory =
|
|
|
|
std::function<KClientPort&(Service::SM::ServiceManager&, Core::System&)>;
|
|
|
|
|
2021-05-04 21:35:42 -07:00
|
|
|
namespace Init {
|
|
|
|
struct KSlabResourceCounts;
|
|
|
|
}
|
|
|
|
|
2021-02-12 16:21:12 -08:00
|
|
|
template <typename T>
|
|
|
|
class KSlabHeap;
|
|
|
|
|
2021-01-19 21:07:07 -08:00
|
|
|
using EmuThreadHandle = uintptr_t;
|
|
|
|
constexpr EmuThreadHandle EmuThreadHandleInvalid{};
|
|
|
|
constexpr EmuThreadHandle EmuThreadHandleReserved{1ULL << 63};
|
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
/// Represents a single instance of the kernel.
|
|
|
|
class KernelCore {
|
2018-09-02 08:58:58 -07:00
|
|
|
private:
|
2021-04-21 21:43:25 -07:00
|
|
|
using NamedPortTable = std::unordered_map<std::string, KClientPort*>;
|
2018-09-02 08:58:58 -07:00
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
public:
|
2019-03-05 09:28:10 -08: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 09:30:33 -07:00
|
|
|
~KernelCore();
|
|
|
|
|
|
|
|
KernelCore(const KernelCore&) = delete;
|
|
|
|
KernelCore& operator=(const KernelCore&) = delete;
|
|
|
|
|
|
|
|
KernelCore(KernelCore&&) = delete;
|
|
|
|
KernelCore& operator=(KernelCore&&) = delete;
|
|
|
|
|
2020-03-08 19:39:41 -07:00
|
|
|
/// Sets if emulation is multicore or single core, must be set before Initialize
|
|
|
|
void SetMulticore(bool is_multicore);
|
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
/// Resets the kernel to a clean slate for use.
|
2019-03-05 09:28:10 -08:00
|
|
|
void Initialize();
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2020-11-13 11:11:12 -08:00
|
|
|
/// Initializes the CPU cores.
|
|
|
|
void InitializeCores();
|
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
/// Clears all resources in use by the kernel instance.
|
|
|
|
void Shutdown();
|
|
|
|
|
2018-11-19 09:54:06 -08:00
|
|
|
/// Retrieves a shared pointer to the system resource limit instance.
|
2021-04-20 21:28:11 -07:00
|
|
|
const KResourceLimit* GetSystemResourceLimit() const;
|
|
|
|
|
|
|
|
/// Retrieves a shared pointer to the system resource limit instance.
|
|
|
|
KResourceLimit* GetSystemResourceLimit();
|
2018-08-28 09:30:33 -07:00
|
|
|
|
|
|
|
/// Retrieves a shared pointer to a Thread instance within the thread wakeup handle table.
|
2021-04-03 19:11:46 -07:00
|
|
|
KScopedAutoObject<KThread> RetrieveThreadFromGlobalHandleTable(Handle handle) const;
|
2018-08-28 09:30:33 -07:00
|
|
|
|
|
|
|
/// Adds the given shared pointer to an internal list of active processes.
|
2021-04-23 22:04:28 -07:00
|
|
|
void AppendNewProcess(KProcess* process);
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2018-09-06 17:34:51 -07:00
|
|
|
/// Makes the given process the new current process.
|
2021-04-23 22:04:28 -07:00
|
|
|
void MakeCurrentProcess(KProcess* process);
|
2018-09-06 17:34:51 -07:00
|
|
|
|
2018-10-09 21:42:10 -07:00
|
|
|
/// Retrieves a pointer to the current process.
|
2021-04-23 22:04:28 -07:00
|
|
|
KProcess* CurrentProcess();
|
2018-09-06 17:34:51 -07:00
|
|
|
|
2018-10-09 21:42:10 -07:00
|
|
|
/// Retrieves a const pointer to the current process.
|
2021-04-23 22:04:28 -07:00
|
|
|
const KProcess* CurrentProcess() const;
|
2018-09-06 17:34:51 -07:00
|
|
|
|
2019-03-20 12:03:52 -07:00
|
|
|
/// Retrieves the list of processes.
|
2021-04-23 22:04:28 -07:00
|
|
|
const std::vector<KProcess*>& GetProcessList() const;
|
2019-03-20 12:03:52 -07:00
|
|
|
|
2019-03-29 14:02:57 -07:00
|
|
|
/// Gets the sole instance of the global scheduler
|
2020-12-02 18:08:35 -08:00
|
|
|
Kernel::GlobalSchedulerContext& GlobalSchedulerContext();
|
2019-03-29 14:02:57 -07:00
|
|
|
|
|
|
|
/// Gets the sole instance of the global scheduler
|
2020-12-02 18:08:35 -08:00
|
|
|
const Kernel::GlobalSchedulerContext& GlobalSchedulerContext() const;
|
2019-03-29 14:02:57 -07:00
|
|
|
|
2020-02-13 18:04:10 -08:00
|
|
|
/// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
|
2020-12-02 18:08:35 -08:00
|
|
|
Kernel::KScheduler& Scheduler(std::size_t id);
|
2020-02-13 18:04:10 -08:00
|
|
|
|
|
|
|
/// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
|
2020-12-02 18:08:35 -08:00
|
|
|
const Kernel::KScheduler& Scheduler(std::size_t id) const;
|
2020-02-13 18:04:10 -08:00
|
|
|
|
2020-01-25 14:55:32 -08: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;
|
|
|
|
|
2021-08-06 22:45:18 -07:00
|
|
|
/// Gets the current physical core index for the running host thread.
|
|
|
|
std::size_t CurrentPhysicalCoreIndex() const;
|
|
|
|
|
2020-02-24 18:04:12 -08:00
|
|
|
/// Gets the sole instance of the Scheduler at the current running core.
|
2020-12-02 18:08:35 -08:00
|
|
|
Kernel::KScheduler* CurrentScheduler();
|
2020-02-24 18:04:12 -08:00
|
|
|
|
|
|
|
/// 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-14 06:56:27 -08: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 14:55:32 -08: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;
|
|
|
|
|
2021-04-03 19:11:46 -07:00
|
|
|
KAutoObjectWithListContainer& ObjectListContainer();
|
|
|
|
|
|
|
|
const KAutoObjectWithListContainer& ObjectListContainer() const;
|
|
|
|
|
2020-03-01 08:14:17 -08:00
|
|
|
std::array<Core::CPUInterruptHandler, Core::Hardware::NUM_CPU_CORES>& Interrupts();
|
|
|
|
|
|
|
|
const std::array<Core::CPUInterruptHandler, Core::Hardware::NUM_CPU_CORES>& Interrupts() const;
|
|
|
|
|
2020-01-25 14:55:32 -08:00
|
|
|
void InvalidateAllInstructionCaches();
|
|
|
|
|
2020-11-13 23:20:32 -08:00
|
|
|
void InvalidateCpuInstructionCacheRange(VAddr addr, std::size_t size);
|
|
|
|
|
2021-05-10 15:57:59 -07:00
|
|
|
/// Registers a named HLE service, passing a factory used to open a port to that service.
|
|
|
|
void RegisterNamedService(std::string name, ServiceInterfaceFactory&& factory);
|
2018-09-02 08:58:58 -07:00
|
|
|
|
2021-05-10 15:57:59 -07:00
|
|
|
/// Opens a port to a service previously registered with RegisterNamedService.
|
|
|
|
KClientPort* CreateNamedServicePort(std::string name);
|
2018-09-02 08:58:58 -07:00
|
|
|
|
2021-06-28 14:38:14 -07:00
|
|
|
/// Registers all kernel objects with the global emulation state, this is purely for tracking
|
|
|
|
/// leaks after emulation has been shutdown.
|
|
|
|
void RegisterKernelObject(KAutoObject* object);
|
|
|
|
|
|
|
|
/// Unregisters a kernel object previously registered with RegisterKernelObject when it was
|
|
|
|
/// destroyed during the current emulation session.
|
|
|
|
void UnregisterKernelObject(KAutoObject* object);
|
|
|
|
|
2021-10-25 03:55:20 -07:00
|
|
|
/// Registers kernel objects with guest in use state, this is purely for close
|
|
|
|
/// after emulation has been shutdown.
|
|
|
|
void RegisterInUseObject(KAutoObject* object);
|
|
|
|
|
|
|
|
/// Unregisters a kernel object previously registered with RegisterInUseObject when it was
|
|
|
|
/// destroyed during the current emulation session.
|
|
|
|
void UnregisterInUseObject(KAutoObject* object);
|
|
|
|
|
2018-09-02 08:58:58 -07:00
|
|
|
/// Determines whether or not the given port is a valid named port.
|
|
|
|
bool IsValidNamedPort(NamedPortTable::const_iterator port) const;
|
|
|
|
|
2021-01-21 13:00:16 -08:00
|
|
|
/// Gets the current host_thread/guest_thread pointer.
|
|
|
|
KThread* GetCurrentEmuThread() const;
|
2020-02-14 05:30:53 -08:00
|
|
|
|
|
|
|
/// Gets the current host_thread handle.
|
2020-02-22 06:27:40 -08:00
|
|
|
u32 GetCurrentHostThreadID() const;
|
2020-02-14 05:30:53 -08: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 18:06:37 -07:00
|
|
|
/// Gets the virtual memory manager for the kernel.
|
2021-02-12 17:38:40 -08:00
|
|
|
KMemoryManager& MemoryManager();
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the virtual memory manager for the kernel.
|
2021-02-12 17:38:40 -08:00
|
|
|
const KMemoryManager& MemoryManager() const;
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for HID services.
|
2021-02-05 23:14:31 -08:00
|
|
|
Kernel::KSharedMemory& GetHidSharedMem();
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for HID services.
|
2021-02-05 23:14:31 -08:00
|
|
|
const Kernel::KSharedMemory& GetHidSharedMem() const;
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for font services.
|
2021-02-05 23:14:31 -08:00
|
|
|
Kernel::KSharedMemory& GetFontSharedMem();
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for font services.
|
2021-02-05 23:14:31 -08:00
|
|
|
const Kernel::KSharedMemory& GetFontSharedMem() const;
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for IRS services.
|
2021-02-05 23:14:31 -08:00
|
|
|
Kernel::KSharedMemory& GetIrsSharedMem();
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for IRS services.
|
2021-02-05 23:14:31 -08:00
|
|
|
const Kernel::KSharedMemory& GetIrsSharedMem() const;
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for Time services.
|
2021-02-05 23:14:31 -08:00
|
|
|
Kernel::KSharedMemory& GetTimeSharedMem();
|
2020-04-08 18:06:37 -07:00
|
|
|
|
|
|
|
/// Gets the shared memory object for Time services.
|
2021-02-05 23:14:31 -08:00
|
|
|
const Kernel::KSharedMemory& GetTimeSharedMem() const;
|
2020-04-08 18:06:37 -07:00
|
|
|
|
2020-02-24 18:04:12 -08:00
|
|
|
/// Suspend/unsuspend the OS.
|
|
|
|
void Suspend(bool in_suspention);
|
|
|
|
|
|
|
|
/// Exceptional exit the OS.
|
|
|
|
void ExceptionalExit();
|
|
|
|
|
2020-03-10 10:13:39 -07:00
|
|
|
bool IsMulticore() const;
|
|
|
|
|
2021-11-25 20:46:17 -08:00
|
|
|
bool IsShuttingDown() const;
|
|
|
|
|
2020-03-12 13:48:43 -07:00
|
|
|
void EnterSVCProfile();
|
|
|
|
|
|
|
|
void ExitSVCProfile();
|
|
|
|
|
2020-12-15 00:41:48 -08:00
|
|
|
/**
|
2022-03-30 21:11:11 -07:00
|
|
|
* Creates a host thread to execute HLE service requests, which are used to execute service
|
|
|
|
* routines asynchronously. While these are allocated per ServerSession, these need to be owned
|
|
|
|
* and managed outside of ServerSession to avoid a circular dependency. In general, most
|
|
|
|
* services can just use the default service thread, and not need their own host service thread.
|
|
|
|
* See GetDefaultServiceThread.
|
2021-04-09 22:10:14 -07:00
|
|
|
* @param name String name for the ServerSession creating this thread, used for debug
|
|
|
|
* purposes.
|
2020-12-15 00:41:48 -08:00
|
|
|
* @returns The a weak pointer newly created service thread.
|
|
|
|
*/
|
|
|
|
std::weak_ptr<Kernel::ServiceThread> CreateServiceThread(const std::string& name);
|
|
|
|
|
2022-03-30 21:11:11 -07:00
|
|
|
/**
|
|
|
|
* Gets the default host service thread, which executes HLE service requests. Unless service
|
|
|
|
* requests need to block on the host, the default service thread should be used in favor of
|
|
|
|
* creating a new service thread.
|
|
|
|
* @returns The a weak pointer for the default service thread.
|
|
|
|
*/
|
|
|
|
std::weak_ptr<Kernel::ServiceThread> GetDefaultServiceThread() const;
|
|
|
|
|
2020-12-15 00:41:48 -08:00
|
|
|
/**
|
|
|
|
* Releases a HLE service thread, instructing KernelCore to free it. This should be called when
|
|
|
|
* the ServerSession associated with the thread is destroyed.
|
|
|
|
* @param service_thread Service thread to release.
|
|
|
|
*/
|
|
|
|
void ReleaseServiceThread(std::weak_ptr<Kernel::ServiceThread> service_thread);
|
|
|
|
|
2020-12-31 02:13:02 -08:00
|
|
|
/// Workaround for single-core mode when preempting threads while idle.
|
|
|
|
bool IsPhantomModeForSingleCore() const;
|
|
|
|
void SetIsPhantomModeForSingleCore(bool value);
|
|
|
|
|
2021-04-03 19:11:46 -07:00
|
|
|
Core::System& System();
|
|
|
|
const Core::System& System() const;
|
|
|
|
|
2021-04-09 22:10:14 -07:00
|
|
|
/// Gets the slab heap for the specified kernel object type.
|
|
|
|
template <typename T>
|
|
|
|
KSlabHeap<T>& SlabHeap() {
|
2021-04-20 21:28:11 -07:00
|
|
|
if constexpr (std::is_same_v<T, KClientSession>) {
|
|
|
|
return slab_heap_container->client_session;
|
2021-04-09 22:10:14 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KEvent>) {
|
2021-04-09 23:16:13 -07:00
|
|
|
return slab_heap_container->event;
|
2021-04-09 22:10:14 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KLinkedListNode>) {
|
2021-04-09 23:16:13 -07:00
|
|
|
return slab_heap_container->linked_list_node;
|
2021-04-23 17:00:15 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KPort>) {
|
|
|
|
return slab_heap_container->port;
|
2021-04-23 22:04:28 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KProcess>) {
|
2021-04-20 21:28:11 -07:00
|
|
|
return slab_heap_container->process;
|
|
|
|
} else if constexpr (std::is_same_v<T, KResourceLimit>) {
|
|
|
|
return slab_heap_container->resource_limit;
|
2021-04-13 17:48:37 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KSession>) {
|
|
|
|
return slab_heap_container->session;
|
2021-04-20 21:28:11 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KSharedMemory>) {
|
|
|
|
return slab_heap_container->shared_memory;
|
2021-09-25 08:01:53 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KSharedMemoryInfo>) {
|
|
|
|
return slab_heap_container->shared_memory_info;
|
2021-04-20 21:28:11 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KThread>) {
|
|
|
|
return slab_heap_container->thread;
|
2021-04-17 00:52:53 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KTransferMemory>) {
|
|
|
|
return slab_heap_container->transfer_memory;
|
2021-04-20 21:28:11 -07:00
|
|
|
} else if constexpr (std::is_same_v<T, KWritableEvent>) {
|
|
|
|
return slab_heap_container->writeable_event;
|
2021-12-05 12:04:08 -08:00
|
|
|
} else if constexpr (std::is_same_v<T, KCodeMemory>) {
|
|
|
|
return slab_heap_container->code_memory;
|
2022-03-11 16:11:57 -08:00
|
|
|
} else if constexpr (std::is_same_v<T, KPageBuffer>) {
|
|
|
|
return slab_heap_container->page_buffer;
|
|
|
|
} else if constexpr (std::is_same_v<T, KThreadLocalPage>) {
|
|
|
|
return slab_heap_container->thread_local_page;
|
2021-04-09 22:10:14 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-04 21:35:42 -07:00
|
|
|
/// Gets the current slab resource counts.
|
|
|
|
Init::KSlabResourceCounts& SlabResourceCounts();
|
|
|
|
|
|
|
|
/// Gets the current slab resource counts.
|
|
|
|
const Init::KSlabResourceCounts& SlabResourceCounts() const;
|
|
|
|
|
2022-01-14 16:25:37 -08:00
|
|
|
/// Gets the current worker task manager, used for dispatching KThread/KProcess tasks.
|
|
|
|
KWorkerTaskManager& WorkerTaskManager();
|
|
|
|
|
|
|
|
/// Gets the current worker task manager, used for dispatching KThread/KProcess tasks.
|
|
|
|
const KWorkerTaskManager& WorkerTaskManager() const;
|
|
|
|
|
2022-02-26 10:46:31 -08:00
|
|
|
/// Gets the memory layout.
|
|
|
|
const KMemoryLayout& MemoryLayout() const;
|
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
private:
|
2021-04-23 22:04:28 -07:00
|
|
|
friend class KProcess;
|
2020-12-30 23:01:08 -08:00
|
|
|
friend class KThread;
|
2018-08-28 09:30:33 -07:00
|
|
|
|
|
|
|
/// 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-09 21:28:33 -07:00
|
|
|
u64 CreateNewKernelProcessID();
|
|
|
|
|
|
|
|
/// Creates a new process ID, incrementing the internal process ID counter;
|
|
|
|
u64 CreateNewUserProcessID();
|
2018-08-28 09:30:33 -07:00
|
|
|
|
|
|
|
/// Creates a new thread ID, incrementing the internal thread ID counter.
|
2018-12-18 19:37:01 -08:00
|
|
|
u64 CreateNewThreadID();
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2020-02-14 05:30:53 -08:00
|
|
|
/// Provides a reference to the global handle table.
|
2021-04-24 02:40:31 -07:00
|
|
|
KHandleTable& GlobalHandleTable();
|
2018-08-28 09:30:33 -07:00
|
|
|
|
2020-02-14 05:30:53 -08:00
|
|
|
/// Provides a const reference to the global handle table.
|
2021-04-24 02:40:31 -07:00
|
|
|
const KHandleTable& GlobalHandleTable() const;
|
2014-06-10 19:43:50 -07:00
|
|
|
|
2018-08-28 09:30:33 -07:00
|
|
|
struct Impl;
|
|
|
|
std::unique_ptr<Impl> impl;
|
2021-04-09 22:10:14 -07:00
|
|
|
|
2020-02-24 18:04:12 -08:00
|
|
|
bool exception_exited{};
|
2021-04-09 22:10:14 -07:00
|
|
|
|
|
|
|
private:
|
2021-04-09 23:16:13 -07:00
|
|
|
/// Helper to encapsulate all slab heaps in a single heap allocated container
|
|
|
|
struct SlabHeapContainer {
|
2021-04-20 21:28:11 -07:00
|
|
|
KSlabHeap<KClientSession> client_session;
|
2021-04-09 23:16:13 -07:00
|
|
|
KSlabHeap<KEvent> event;
|
|
|
|
KSlabHeap<KLinkedListNode> linked_list_node;
|
2021-04-23 17:00:15 -07:00
|
|
|
KSlabHeap<KPort> port;
|
2021-04-23 22:04:28 -07:00
|
|
|
KSlabHeap<KProcess> process;
|
2021-04-20 21:28:11 -07:00
|
|
|
KSlabHeap<KResourceLimit> resource_limit;
|
2021-04-13 17:48:37 -07:00
|
|
|
KSlabHeap<KSession> session;
|
2021-04-20 21:28:11 -07:00
|
|
|
KSlabHeap<KSharedMemory> shared_memory;
|
2021-09-25 08:01:53 -07:00
|
|
|
KSlabHeap<KSharedMemoryInfo> shared_memory_info;
|
2021-04-20 21:28:11 -07:00
|
|
|
KSlabHeap<KThread> thread;
|
2021-04-17 00:52:53 -07:00
|
|
|
KSlabHeap<KTransferMemory> transfer_memory;
|
2021-04-20 21:28:11 -07:00
|
|
|
KSlabHeap<KWritableEvent> writeable_event;
|
2021-12-05 12:04:08 -08:00
|
|
|
KSlabHeap<KCodeMemory> code_memory;
|
2022-03-11 16:11:57 -08:00
|
|
|
KSlabHeap<KPageBuffer> page_buffer;
|
|
|
|
KSlabHeap<KThreadLocalPage> thread_local_page;
|
2021-04-09 23:16:13 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
std::unique_ptr<SlabHeapContainer> slab_heap_container;
|
2018-08-28 09:30:33 -07:00
|
|
|
};
|
2014-06-10 19:43:50 -07:00
|
|
|
|
2017-07-20 21:52:50 -07:00
|
|
|
} // namespace Kernel
|