summaryrefslogtreecommitdiffhomepage
path: root/Private/KernelKit/SMPManager.hpp
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-26 22:26:48 +0100
committerAmlal El Mahrouss <amlal.elmahrouss@icloud.com>2024-01-26 22:27:09 +0100
commiteba8b7ddd0a455d9e49f32dcae712c5612c0093c (patch)
tree749a3d34546d055507a920bce4ab10e8a9945719 /Private/KernelKit/SMPManager.hpp
parentdd192787a70a973f2474720aea49af3f6ddabb7a (diff)
Kernel: Major repository refactor.
Rework the repo into Private and Public modules. Signed-off-by: Amlal El Mahrouss <amlal.elmahrouss@icloud.com>
Diffstat (limited to 'Private/KernelKit/SMPManager.hpp')
-rw-r--r--Private/KernelKit/SMPManager.hpp121
1 files changed, 121 insertions, 0 deletions
diff --git a/Private/KernelKit/SMPManager.hpp b/Private/KernelKit/SMPManager.hpp
new file mode 100644
index 00000000..61e9ac3f
--- /dev/null
+++ b/Private/KernelKit/SMPManager.hpp
@@ -0,0 +1,121 @@
+/*
+ * ========================================================
+ *
+ * hCore
+ * Copyright 2024 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;
+
+ };
+
+ // @brief wakes up thread.
+ // wakes up thread from hang.
+ void rt_wakeup_thread(HAL::StackFrame* stack);
+
+ // @brief makes thread sleep.
+ // hooks and hangs thread to prevent code from executing.
+ void rt_hang_thread(HAL::StackFrame* stack);
+} // namespace hCore
+
+#endif // !_INC_SMP_MANAGER_HPP