summaryrefslogtreecommitdiffhomepage
path: root/KernelKit/SMPManager.hpp
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-06 09:14:11 +0100
committerAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-06 09:14:11 +0100
commit5339d016c07bf717ee388f4feb73544087324af0 (patch)
tree94be6f67ed626091f24aee24ec3b3be03d01e4e7 /KernelKit/SMPManager.hpp
git: port from mercurial repo.
Signed-off-by: Amlal El Mahrouss <amlal.elmahrouss@icloud.com>
Diffstat (limited to 'KernelKit/SMPManager.hpp')
-rw-r--r--KernelKit/SMPManager.hpp113
1 files changed, 113 insertions, 0 deletions
diff --git a/KernelKit/SMPManager.hpp b/KernelKit/SMPManager.hpp
new file mode 100644
index 00000000..4ebc944a
--- /dev/null
+++ b/KernelKit/SMPManager.hpp
@@ -0,0 +1,113 @@
+/*
+ * ========================================================
+ *
+ * hCore
+ * Copyright Mahrouss Logic, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#ifndef _INC_SMP_MANAGER_HPP
+#define _INC_SMP_MANAGER_HPP
+
+#include <CompilerKit/Compiler.hpp>
+#include <ArchKit/Arch.hpp>
+#include <NewKit/Ref.hpp>
+
+#define kMaxHarts 8
+
+namespace hCore
+{
+ using ThreadID = UInt32;
+
+ enum ThreadKind
+ {
+ kSystemReserved, // System reserved thread, well user can't use it
+ kStandard, // user thread, cannot be used by kernel
+ kFallback, // fallback thread, cannot be used by user if not clear or used by kernel.
+ kBoot, // The core we booted from, the mama.
+ };
+
+ ///
+ /// \name ProcessorCore
+ /// CPU core (PowerPC, Intel, or NewCPU)
+ ///
+
+ class ProcessorCore final
+ {
+ public:
+ explicit ProcessorCore();
+ ~ProcessorCore();
+
+ public:
+ HCORE_COPY_DEFAULT(ProcessorCore)
+
+ public:
+ operator bool();
+
+ public:
+ void Wake(const bool wakeup = false) noexcept;
+ void Busy(const bool busy = false) noexcept;
+
+ public:
+ bool Switch(HAL::StackFrame* stack);
+ bool IsWakeup() noexcept;
+
+ public:
+ HAL::StackFrame* StackFrame() noexcept;
+ const ThreadKind& Kind() noexcept;
+ bool IsBusy() noexcept;
+ const ThreadID& ID() noexcept;
+
+ private:
+ HAL::StackFrame* m_Stack;
+ ThreadKind m_Kind;
+ ThreadID m_ID;
+ bool m_Wakeup;
+ bool m_Busy;
+ Int64 m_PID;
+
+ private:
+ friend class SMPManager;
+
+ };
+
+ ///
+ /// \name ProcessorCore
+ ///
+ /// Multi processor manager to manage other cores and dispatch tasks.
+ ///
+
+ class SMPManager final
+ {
+ private:
+ explicit SMPManager();
+
+ public:
+ ~SMPManager();
+
+ public:
+ HCORE_COPY_DEFAULT(SMPManager);
+
+ public:
+ bool Switch(HAL::StackFrame* the);
+ HAL::StackFramePtr GetStack() noexcept;
+
+ public:
+ Ref<ProcessorCore> operator[](const SizeT& idx);
+ bool operator!() noexcept;
+ operator bool() noexcept;
+
+ public:
+ /// @brief Shared instance of the SMP Manager.
+ /// @return the reference to the smp manager.
+ static Ref<SMPManager> Shared();
+
+ private:
+ Array<ProcessorCore, kMaxHarts> m_ThreadList;
+ ThreadID m_CurrentThread;
+
+ };
+} // namespace hCore
+
+#endif // !_INC_SMP_MANAGER_HPP