From 4cc8124f0715a5d336071be06a4efd574471e691 Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Fri, 20 Mar 2026 12:34:54 +0100 Subject: [CHORE] Working on libThread for NeKernel's thread implementation. Signed-off-by: Amlal El Mahrouss --- frameworks/libThread.fwrk/dist/.keep | 0 frameworks/libThread.fwrk/libThread.fwrk.json | 20 +++++++++++++ frameworks/libThread.fwrk/src/ThreadManager.cpp | 37 +++++++++++++++++++++++++ 3 files changed, 57 insertions(+) create mode 100644 frameworks/libThread.fwrk/dist/.keep create mode 100644 frameworks/libThread.fwrk/libThread.fwrk.json create mode 100644 frameworks/libThread.fwrk/src/ThreadManager.cpp (limited to 'frameworks') diff --git a/frameworks/libThread.fwrk/dist/.keep b/frameworks/libThread.fwrk/dist/.keep new file mode 100644 index 0000000..e69de29 diff --git a/frameworks/libThread.fwrk/libThread.fwrk.json b/frameworks/libThread.fwrk/libThread.fwrk.json new file mode 100644 index 0000000..1fd7e12 --- /dev/null +++ b/frameworks/libThread.fwrk/libThread.fwrk.json @@ -0,0 +1,20 @@ +{ + "compiler_path": "x86_64-w64-mingw32-g++", + "compiler_std": "c++20", + "headers_path": ["../", "./", "../src/kernel/src/", "../src/kernel/src/kernel"], + "sources_path": ["src/*.cpp"], + "output_name": "./dist/libThread.fwrk.dylib", + "compiler_flags": [ + "-ffreestanding", + "-shared", + "-fno-rtti", + "-fno-exceptions", + "-Wl,--subsystem=17" + ], + "cpp_macros": [ + "kKTVersion=0x0100", + "kKTVersionHighest=0x0100", + "kKTVersionLowest=0x0100" + ] + } + diff --git a/frameworks/libThread.fwrk/src/ThreadManager.cpp b/frameworks/libThread.fwrk/src/ThreadManager.cpp new file mode 100644 index 0000000..9b222ab --- /dev/null +++ b/frameworks/libThread.fwrk/src/ThreadManager.cpp @@ -0,0 +1,37 @@ +// SPDX-License-Identifier: Apache-2.0 +// Copyright 2026, Amlal El Mahrouss (amlal@nekernel.org) +// Licensed under the Apache License, Version 2.0 (see LICENSE file) +// Official repository: https://github.com/ne-foss-org/ne_system + +#include + +#define kThreadMapMax (1024UL) +#define kThreadBaseHash (0x5555ffff6ULL) + +/// @brief The registered thread for a specific process. +static ThreadRef kThreadMap[kThreadMapMax]; + +/// @brief This hash-list stores the thread to be run. +static ThreadRef kThreadHeads[kThreadMapMax]; + +IMPORT_C ThreadRef ThrCreateThread(const Char* thread_name, ThrProcKind procedure, + SInt32 argument_count, VoidPtr args, SInt32 flags) { + ThreadRef ref = new REF_TYPE; + if (!ref) return nullptr; + + if (!thread_name || !procedure) { + delete ref; + ref = nullptr; + return nullptr; + } + + ref->__hash = *(UInt32*) thread_name; + ref->__hash += kThreadBaseHash; + + ref->__self = (VoidPtr) procedure; + + kThreadMap[kThreadMapMax % ref->__hash] = ref; + kThreadHeads[kThreadMapMax % ref->__hash] = ref; + + return ref; +} -- cgit v1.2.3