2022-04-23 10:59:50 +02:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2014-05-10 04:11:18 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-03-01 17:14:17 +01:00
|
|
|
#include <array>
|
2021-09-09 02:04:29 +02:00
|
|
|
#include <functional>
|
2019-12-08 04:09:20 +01:00
|
|
|
#include <memory>
|
2018-09-02 17:58:58 +02:00
|
|
|
#include <string>
|
|
|
|
#include <unordered_map>
|
2019-11-25 02:15:51 +01:00
|
|
|
#include <vector>
|
2023-02-18 22:26:48 +01:00
|
|
|
|
|
|
|
#include "common/polyfill_thread.h"
|
2020-03-01 17:14:17 +01:00
|
|
|
#include "core/hardware_properties.h"
|
2021-04-10 07:10:14 +02:00
|
|
|
#include "core/hle/kernel/k_auto_object.h"
|
|
|
|
#include "core/hle/kernel/k_slab_heap.h"
|
2021-04-24 11:40:31 +02:00
|
|
|
#include "core/hle/kernel/svc_common.h"
|
2018-08-28 18:30:33 +02:00
|
|
|
|
2019-03-05 18:28:10 +01:00
|
|
|
namespace Core {
|
2020-01-25 23:55:32 +01:00
|
|
|
class ExclusiveMonitor;
|
2019-03-05 18:28:10 +01:00
|
|
|
class System;
|
2020-01-26 21:14:18 +01:00
|
|
|
} // namespace Core
|
2019-03-05 18:28:10 +01:00
|
|
|
|
2019-02-12 18:32:15 +01:00
|
|
|
namespace Core::Timing {
|
2019-02-14 18:42:58 +01:00
|
|
|
class CoreTiming;
|
2018-08-28 18:30:33 +02:00
|
|
|
struct EventType;
|
2019-02-14 18:42:58 +01:00
|
|
|
} // namespace Core::Timing
|
2014-05-10 04:11:18 +02:00
|
|
|
|
2023-02-18 22:26:48 +01:00
|
|
|
namespace Service {
|
|
|
|
class ServerManager;
|
|
|
|
}
|
|
|
|
|
2021-05-11 00:57:59 +02:00
|
|
|
namespace Service::SM {
|
|
|
|
class ServiceManager;
|
|
|
|
}
|
|
|
|
|
2014-05-21 00:13:25 +02:00
|
|
|
namespace Kernel {
|
|
|
|
|
2021-04-22 06:43:25 +02:00
|
|
|
class KClientPort;
|
2020-12-03 03:08:35 +01:00
|
|
|
class GlobalSchedulerContext;
|
2021-04-04 04:11:46 +02:00
|
|
|
class KAutoObjectWithListContainer;
|
2021-04-14 02:48:37 +02:00
|
|
|
class KClientSession;
|
2022-10-29 23:45:09 +02:00
|
|
|
class KDebug;
|
2023-01-29 21:03:29 +01:00
|
|
|
class KDeviceAddressSpace;
|
2022-10-29 23:45:09 +02:00
|
|
|
class KDynamicPageManager;
|
2021-04-10 07:10:14 +02:00
|
|
|
class KEvent;
|
2022-10-29 23:45:09 +02:00
|
|
|
class KEventInfo;
|
2021-04-24 11:40:31 +02:00
|
|
|
class KHandleTable;
|
2022-12-18 22:50:02 +01:00
|
|
|
class KHardwareTimer;
|
2022-02-26 19:46:31 +01:00
|
|
|
class KMemoryLayout;
|
2021-02-13 02:38:40 +01:00
|
|
|
class KMemoryManager;
|
2023-02-17 05:16:08 +01:00
|
|
|
class KObjectName;
|
|
|
|
class KObjectNameGlobalData;
|
2022-03-12 01:11:57 +01:00
|
|
|
class KPageBuffer;
|
2022-10-29 23:45:09 +02:00
|
|
|
class KPageBufferSlabHeap;
|
2021-04-24 02:00:15 +02:00
|
|
|
class KPort;
|
2021-04-24 07:04:28 +02:00
|
|
|
class KProcess;
|
2021-01-30 10:40:49 +01:00
|
|
|
class KResourceLimit;
|
2020-12-03 03:08:35 +01:00
|
|
|
class KScheduler;
|
2022-10-16 07:53:56 +02:00
|
|
|
class KServerPort;
|
2021-07-03 00:19:04 +02:00
|
|
|
class KServerSession;
|
2021-04-14 02:48:37 +02:00
|
|
|
class KSession;
|
2022-10-15 03:24:25 +02:00
|
|
|
class KSessionRequest;
|
2021-02-06 08:14:31 +01:00
|
|
|
class KSharedMemory;
|
2021-09-25 17:01:53 +02:00
|
|
|
class KSharedMemoryInfo;
|
2022-10-29 23:45:09 +02:00
|
|
|
class KSecureSystemResource;
|
2021-02-13 02:38:40 +01:00
|
|
|
class KThread;
|
2022-03-12 01:11:57 +01:00
|
|
|
class KThreadLocalPage;
|
2021-04-17 09:52:53 +02:00
|
|
|
class KTransferMemory;
|
2022-01-15 01:25:37 +01:00
|
|
|
class KWorkerTaskManager;
|
2021-12-05 21:04:08 +01:00
|
|
|
class KCodeMemory;
|
2021-02-13 02:38:40 +01:00
|
|
|
class PhysicalCore;
|
2022-10-16 07:53:56 +02:00
|
|
|
|
2021-05-05 06:35:42 +02:00
|
|
|
namespace Init {
|
|
|
|
struct KSlabResourceCounts;
|
|
|
|
}
|
|
|
|
|
2021-02-13 01:21:12 +01:00
|
|
|
template <typename T>
|
|
|
|
class KSlabHeap;
|
|
|
|
|
2018-08-28 18:30:33 +02:00
|
|
|
/// Represents a single instance of the kernel.
|
|
|
|
class KernelCore {
|
|
|
|
public:
|
2019-03-05 18:28:10 +01: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 18:30:33 +02:00
|
|
|
~KernelCore();
|
|
|
|
|
|
|
|
KernelCore(const KernelCore&) = delete;
|
|
|
|
KernelCore& operator=(const KernelCore&) = delete;
|
|
|
|
|
|
|
|
KernelCore(KernelCore&&) = delete;
|
|
|
|
KernelCore& operator=(KernelCore&&) = delete;
|
|
|
|
|
2020-03-09 03:39:41 +01:00
|
|
|
/// Sets if emulation is multicore or single core, must be set before Initialize
|
|
|
|
void SetMulticore(bool is_multicore);
|
|
|
|
|
2018-08-28 18:30:33 +02:00
|
|
|
/// Resets the kernel to a clean slate for use.
|
2019-03-05 18:28:10 +01:00
|
|
|
void Initialize();
|
2018-08-28 18:30:33 +02:00
|
|
|
|
2020-11-13 20:11:12 +01:00
|
|
|
/// Initializes the CPU cores.
|
|
|
|
void InitializeCores();
|
|
|
|
|
2018-08-28 18:30:33 +02:00
|
|
|
/// Clears all resources in use by the kernel instance.
|
|
|
|
void Shutdown();
|
|
|
|
|
2022-07-17 00:48:45 +02:00
|
|
|
/// Close all active services in use by the kernel instance.
|
|
|
|
void CloseServices();
|
|
|
|
|
2018-11-19 18:54:06 +01:00
|
|
|
/// Retrieves a shared pointer to the system resource limit instance.
|
2021-04-21 06:28:11 +02:00
|
|
|
const KResourceLimit* GetSystemResourceLimit() const;
|
|
|
|
|
|
|
|
/// Retrieves a shared pointer to the system resource limit instance.
|
|
|
|
KResourceLimit* GetSystemResourceLimit();
|
2018-08-28 18:30:33 +02:00
|
|
|
|
|
|
|
/// Retrieves a shared pointer to a Thread instance within the thread wakeup handle table.
|
2021-04-04 04:11:46 +02:00
|
|
|
KScopedAutoObject<KThread> RetrieveThreadFromGlobalHandleTable(Handle handle) const;
|
2018-08-28 18:30:33 +02:00
|
|
|
|
|
|
|
/// Adds the given shared pointer to an internal list of active processes.
|
2021-04-24 07:04:28 +02:00
|
|
|
void AppendNewProcess(KProcess* process);
|
2018-08-28 18:30:33 +02:00
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Makes the given process the new application process.
|
|
|
|
void MakeApplicationProcess(KProcess* process);
|
2018-09-07 02:34:51 +02:00
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Retrieves a pointer to the application process.
|
|
|
|
KProcess* ApplicationProcess();
|
2018-09-07 02:34:51 +02:00
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Retrieves a const pointer to the application process.
|
|
|
|
const KProcess* ApplicationProcess() const;
|
2018-09-07 02:34:51 +02:00
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Closes the application process.
|
|
|
|
void CloseApplicationProcess();
|
2022-10-02 23:26:30 +02:00
|
|
|
|
2019-03-20 20:03:52 +01:00
|
|
|
/// Retrieves the list of processes.
|
2021-04-24 07:04:28 +02:00
|
|
|
const std::vector<KProcess*>& GetProcessList() const;
|
2019-03-20 20:03:52 +01:00
|
|
|
|
2019-03-29 22:02:57 +01:00
|
|
|
/// Gets the sole instance of the global scheduler
|
2020-12-03 03:08:35 +01:00
|
|
|
Kernel::GlobalSchedulerContext& GlobalSchedulerContext();
|
2019-03-29 22:02:57 +01:00
|
|
|
|
|
|
|
/// Gets the sole instance of the global scheduler
|
2020-12-03 03:08:35 +01:00
|
|
|
const Kernel::GlobalSchedulerContext& GlobalSchedulerContext() const;
|
2019-03-29 22:02:57 +01:00
|
|
|
|
2020-02-14 03:04:10 +01:00
|
|
|
/// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
|
2020-12-03 03:08:35 +01:00
|
|
|
Kernel::KScheduler& Scheduler(std::size_t id);
|
2020-02-14 03:04:10 +01:00
|
|
|
|
|
|
|
/// Gets the sole instance of the Scheduler assoviated with cpu core 'id'
|
2020-12-03 03:08:35 +01:00
|
|
|
const Kernel::KScheduler& Scheduler(std::size_t id) const;
|
2020-02-14 03:04:10 +01:00
|
|
|
|
2020-01-25 23:55:32 +01: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-07 07:45:18 +02:00
|
|
|
/// Gets the current physical core index for the running host thread.
|
|
|
|
std::size_t CurrentPhysicalCoreIndex() const;
|
|
|
|
|
2020-02-25 03:04:12 +01:00
|
|
|
/// Gets the sole instance of the Scheduler at the current running core.
|
2020-12-03 03:08:35 +01:00
|
|
|
Kernel::KScheduler* CurrentScheduler();
|
2020-02-25 03:04:12 +01: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;
|
|
|
|
|
2022-12-18 22:50:02 +01:00
|
|
|
/// Gets the an instance of the hardware timer.
|
|
|
|
Kernel::KHardwareTimer& HardwareTimer();
|
2020-02-14 15:56:27 +01:00
|
|
|
|
2020-01-25 23:55:32 +01: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-04 04:11:46 +02:00
|
|
|
KAutoObjectWithListContainer& ObjectListContainer();
|
|
|
|
|
|
|
|
const KAutoObjectWithListContainer& ObjectListContainer() const;
|
|
|
|
|
2020-01-25 23:55:32 +01:00
|
|
|
void InvalidateAllInstructionCaches();
|
|
|
|
|
2020-11-14 08:20:32 +01:00
|
|
|
void InvalidateCpuInstructionCacheRange(VAddr addr, std::size_t size);
|
|
|
|
|
2021-06-28 23:38:14 +02: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 12:55:20 +02: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);
|
|
|
|
|
2023-02-18 22:26:48 +01:00
|
|
|
// Runs the given server manager until shutdown.
|
|
|
|
void RunServer(std::unique_ptr<Service::ServerManager>&& server_manager);
|
2018-09-02 17:58:58 +02:00
|
|
|
|
2021-01-21 22:00:16 +01:00
|
|
|
/// Gets the current host_thread/guest_thread pointer.
|
|
|
|
KThread* GetCurrentEmuThread() const;
|
2020-02-14 14:30:53 +01:00
|
|
|
|
2022-06-16 16:35:52 +02:00
|
|
|
/// Sets the current guest_thread pointer.
|
|
|
|
void SetCurrentEmuThread(KThread* thread);
|
|
|
|
|
2020-02-14 14:30:53 +01:00
|
|
|
/// Gets the current host_thread handle.
|
2020-02-22 15:27:40 +01:00
|
|
|
u32 GetCurrentHostThreadID() const;
|
2020-02-14 14:30:53 +01: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.
|
2022-11-03 01:21:32 +01:00
|
|
|
void RegisterHostThread(KThread* existing_thread = nullptr);
|
2020-02-14 14:30:53 +01:00
|
|
|
|
2023-02-18 22:26:48 +01:00
|
|
|
void RunOnGuestCoreProcess(std::string&& process_name, std::function<void()> func);
|
|
|
|
|
|
|
|
std::jthread RunOnHostCoreProcess(std::string&& process_name, std::function<void()> func);
|
|
|
|
|
|
|
|
std::jthread RunOnHostCoreThread(std::string&& thread_name, std::function<void()> func);
|
|
|
|
|
2023-02-17 05:16:08 +01:00
|
|
|
/// Gets global data for KObjectName.
|
|
|
|
KObjectNameGlobalData& ObjectNameGlobalData();
|
|
|
|
|
2020-04-09 03:06:37 +02:00
|
|
|
/// Gets the virtual memory manager for the kernel.
|
2021-02-13 02:38:40 +01:00
|
|
|
KMemoryManager& MemoryManager();
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the virtual memory manager for the kernel.
|
2021-02-13 02:38:40 +01:00
|
|
|
const KMemoryManager& MemoryManager() const;
|
2020-04-09 03:06:37 +02:00
|
|
|
|
2023-02-11 06:03:39 +01:00
|
|
|
/// Gets the application resource manager.
|
|
|
|
KSystemResource& GetAppSystemResource();
|
|
|
|
|
|
|
|
/// Gets the application resource manager.
|
|
|
|
const KSystemResource& GetAppSystemResource() const;
|
|
|
|
|
2022-10-29 23:45:09 +02:00
|
|
|
/// Gets the system resource manager.
|
|
|
|
KSystemResource& GetSystemSystemResource();
|
2022-09-17 08:33:47 +02:00
|
|
|
|
2022-10-29 23:45:09 +02:00
|
|
|
/// Gets the system resource manager.
|
|
|
|
const KSystemResource& GetSystemSystemResource() const;
|
2022-09-17 08:33:47 +02:00
|
|
|
|
2020-04-09 03:06:37 +02:00
|
|
|
/// Gets the shared memory object for HID services.
|
2021-02-06 08:14:31 +01:00
|
|
|
Kernel::KSharedMemory& GetHidSharedMem();
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for HID services.
|
2021-02-06 08:14:31 +01:00
|
|
|
const Kernel::KSharedMemory& GetHidSharedMem() const;
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for font services.
|
2021-02-06 08:14:31 +01:00
|
|
|
Kernel::KSharedMemory& GetFontSharedMem();
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for font services.
|
2021-02-06 08:14:31 +01:00
|
|
|
const Kernel::KSharedMemory& GetFontSharedMem() const;
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for IRS services.
|
2021-02-06 08:14:31 +01:00
|
|
|
Kernel::KSharedMemory& GetIrsSharedMem();
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for IRS services.
|
2021-02-06 08:14:31 +01:00
|
|
|
const Kernel::KSharedMemory& GetIrsSharedMem() const;
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for Time services.
|
2021-02-06 08:14:31 +01:00
|
|
|
Kernel::KSharedMemory& GetTimeSharedMem();
|
2020-04-09 03:06:37 +02:00
|
|
|
|
|
|
|
/// Gets the shared memory object for Time services.
|
2021-02-06 08:14:31 +01:00
|
|
|
const Kernel::KSharedMemory& GetTimeSharedMem() const;
|
2020-04-09 03:06:37 +02:00
|
|
|
|
2021-05-03 01:41:03 +02:00
|
|
|
/// Gets the shared memory object for HIDBus services.
|
|
|
|
Kernel::KSharedMemory& GetHidBusSharedMem();
|
|
|
|
|
|
|
|
/// Gets the shared memory object for HIDBus services.
|
|
|
|
const Kernel::KSharedMemory& GetHidBusSharedMem() const;
|
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Suspend/unsuspend application process.
|
|
|
|
void SuspendApplication(bool suspend);
|
2020-02-25 03:04:12 +01:00
|
|
|
|
2023-02-13 17:21:43 +01:00
|
|
|
/// Exceptional exit application process.
|
|
|
|
void ExceptionalExitApplication();
|
2020-02-25 03:04:12 +01:00
|
|
|
|
2022-06-14 00:36:30 +02:00
|
|
|
/// Notify emulated CPU cores to shut down.
|
|
|
|
void ShutdownCores();
|
|
|
|
|
2020-03-10 18:13:39 +01:00
|
|
|
bool IsMulticore() const;
|
|
|
|
|
2021-11-26 05:46:17 +01:00
|
|
|
bool IsShuttingDown() const;
|
|
|
|
|
2020-03-12 21:48:43 +01:00
|
|
|
void EnterSVCProfile();
|
|
|
|
|
|
|
|
void ExitSVCProfile();
|
|
|
|
|
2020-12-31 11:13:02 +01:00
|
|
|
/// Workaround for single-core mode when preempting threads while idle.
|
|
|
|
bool IsPhantomModeForSingleCore() const;
|
|
|
|
void SetIsPhantomModeForSingleCore(bool value);
|
|
|
|
|
2021-04-04 04:11:46 +02:00
|
|
|
Core::System& System();
|
|
|
|
const Core::System& System() const;
|
|
|
|
|
2021-04-10 07:10:14 +02:00
|
|
|
/// Gets the slab heap for the specified kernel object type.
|
|
|
|
template <typename T>
|
2023-02-23 21:49:42 +01:00
|
|
|
KSlabHeap<T>& SlabHeap();
|
2021-04-10 07:10:14 +02:00
|
|
|
|
2021-05-05 06:35:42 +02:00
|
|
|
/// Gets the current slab resource counts.
|
|
|
|
Init::KSlabResourceCounts& SlabResourceCounts();
|
|
|
|
|
|
|
|
/// Gets the current slab resource counts.
|
|
|
|
const Init::KSlabResourceCounts& SlabResourceCounts() const;
|
|
|
|
|
2022-01-15 01:25:37 +01: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 19:46:31 +01:00
|
|
|
/// Gets the memory layout.
|
|
|
|
const KMemoryLayout& MemoryLayout() const;
|
|
|
|
|
2018-08-28 18:30:33 +02:00
|
|
|
private:
|
2021-04-24 07:04:28 +02:00
|
|
|
friend class KProcess;
|
2020-12-31 08:01:08 +01:00
|
|
|
friend class KThread;
|
2018-08-28 18:30:33 +02: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-10 06:28:33 +02:00
|
|
|
u64 CreateNewKernelProcessID();
|
|
|
|
|
|
|
|
/// Creates a new process ID, incrementing the internal process ID counter;
|
|
|
|
u64 CreateNewUserProcessID();
|
2018-08-28 18:30:33 +02:00
|
|
|
|
|
|
|
/// Creates a new thread ID, incrementing the internal thread ID counter.
|
2018-12-19 04:37:01 +01:00
|
|
|
u64 CreateNewThreadID();
|
2018-08-28 18:30:33 +02:00
|
|
|
|
2020-02-14 14:30:53 +01:00
|
|
|
/// Provides a reference to the global handle table.
|
2021-04-24 11:40:31 +02:00
|
|
|
KHandleTable& GlobalHandleTable();
|
2018-08-28 18:30:33 +02:00
|
|
|
|
2020-02-14 14:30:53 +01:00
|
|
|
/// Provides a const reference to the global handle table.
|
2021-04-24 11:40:31 +02:00
|
|
|
const KHandleTable& GlobalHandleTable() const;
|
2014-06-11 04:43:50 +02:00
|
|
|
|
2018-08-28 18:30:33 +02:00
|
|
|
struct Impl;
|
|
|
|
std::unique_ptr<Impl> impl;
|
2021-04-10 07:10:14 +02:00
|
|
|
|
2020-02-25 03:04:12 +01:00
|
|
|
bool exception_exited{};
|
2021-04-10 07:10:14 +02:00
|
|
|
|
|
|
|
private:
|
2021-04-10 08:16:13 +02:00
|
|
|
/// Helper to encapsulate all slab heaps in a single heap allocated container
|
2023-02-23 21:49:42 +01:00
|
|
|
struct SlabHeapContainer;
|
2021-04-10 08:16:13 +02:00
|
|
|
|
|
|
|
std::unique_ptr<SlabHeapContainer> slab_heap_container;
|
2018-08-28 18:30:33 +02:00
|
|
|
};
|
2014-06-11 04:43:50 +02:00
|
|
|
|
2017-07-21 06:52:50 +02:00
|
|
|
} // namespace Kernel
|