From a13e1c0911c0627184bc38f18c7fdda64447b3ad Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Sun, 23 Mar 2025 19:13:48 +0100 Subject: meta(kernel): Reworked repository's filesystem structure. Removing useless parts of the project too. Signed-off-by: Amlal El Mahrouss --- dev/Kernel/KernelKit/ThreadLocalStorage.inl | 99 ----------------------------- 1 file changed, 99 deletions(-) delete mode 100644 dev/Kernel/KernelKit/ThreadLocalStorage.inl (limited to 'dev/Kernel/KernelKit/ThreadLocalStorage.inl') diff --git a/dev/Kernel/KernelKit/ThreadLocalStorage.inl b/dev/Kernel/KernelKit/ThreadLocalStorage.inl deleted file mode 100644 index d912f5aa..00000000 --- a/dev/Kernel/KernelKit/ThreadLocalStorage.inl +++ /dev/null @@ -1,99 +0,0 @@ -/* ------------------------------------------- - - Copyright (C) 2024-2025, Amlal EL Mahrouss, all rights reserved. - -------------------------------------------- */ - -//! @file ThreadLocalStorage.inl -//! @brief Allocate resources from the process's heap storage. - -#ifndef INC_PROCESS_SCHEDULER_H -#include -#endif - -template -inline T* tls_new_ptr(void) noexcept -{ - using namespace NeOS; - - auto ref_process = UserProcessScheduler::The().CurrentProcess(); - MUST_PASS(ref_process); - - auto pointer = ref_process.Leak().New(sizeof(T)); - - if (pointer.Error()) - return nullptr; - - return reinterpret_cast(pointer.Leak().Leak()); -} - -//! @brief Delete process pointer. -//! @param obj The pointer to delete. -template -inline NeOS::Bool tls_delete_ptr(T* obj) noexcept -{ - using namespace NeOS; - - if (!obj) - return No; - - auto ref_process = UserProcessScheduler::The().CurrentProcess(); - MUST_PASS(ref_process); - - ErrorOr obj_wrapped{obj}; - - return ref_process.Leak().Delete(obj_wrapped, sizeof(T)); -} - -//! @brief Delete process pointer. -//! @param obj The pointer to delete. -template -inline NeOS::Bool tls_delete_ptr(NeOS::ErrorOr obj) noexcept -{ - return tls_delete_ptr(obj.Leak()); -} - -//! @brief Delete process pointer. -//! @param obj The pointer to delete. -template -inline NeOS::Bool tls_delete_ptr(NeOS::ErrorOr obj) noexcept -{ - return tls_delete_ptr(obj->Leak()); -} - -/// @brief Allocate a C++ class, and then call the constructor of it. -/// @tparam T class type. -/// @tparam ...Args varg class type. -/// @param args arguments list. -/// @return Class instance. -template -T* tls_new_class(Args&&... args) -{ - using namespace NeOS; - - T* obj = tls_new_ptr(); - - if (obj) - { - *obj = T(forward(args)...); - return obj; - } - - return nullptr; -} - -/// @brief Delete a C++ class (call constructor first.) -/// @tparam T -/// @param obj -/// @return -template -inline NeOS::Bool tls_delete_class(T* obj) -{ - using namespace NeOS; - - if (!obj) - return No; - - obj->~T(); - return tls_delete_ptr(obj); -} -- cgit v1.2.3