From 516efdab62108ff03af7f1d91e6dcba02f6aad47 Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Thu, 7 Nov 2024 16:30:10 +0100 Subject: Kernel: lots of fixes and improvements. Signed-off-by: Amlal El Mahrouss --- dev/ZKAKit/src/HardwareThreadScheduler.cc | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'dev/ZKAKit/src/HardwareThreadScheduler.cc') diff --git a/dev/ZKAKit/src/HardwareThreadScheduler.cc b/dev/ZKAKit/src/HardwareThreadScheduler.cc index 7651185d..48fcd5b4 100644 --- a/dev/ZKAKit/src/HardwareThreadScheduler.cc +++ b/dev/ZKAKit/src/HardwareThreadScheduler.cc @@ -90,13 +90,13 @@ namespace Kernel /// @note Those symbols are needed in order to switch and validate the stack. EXTERN Bool hal_check_stack(HAL::StackFramePtr frame_ptr); - EXTERN_C Bool mp_register_process(VoidPtr image, Ptr8 stack_ptr, HAL::StackFramePtr frame_ptr); + EXTERN_C Bool mp_register_process(VoidPtr image, Ptr8 stack_ptr, HAL::StackFramePtr frame, ProcessID pid); /// @brief Switch to hardware thread. /// @param stack the new hardware thread. /// @retval true stack was changed, code is running. /// @retval false stack is invalid, previous code is running. - Bool HardwareThread::Switch(VoidPtr image, Ptr8 stack_ptr, HAL::StackFramePtr frame) + Bool HardwareThread::Switch(VoidPtr image, Ptr8 stack_ptr, HAL::StackFramePtr frame, const ProcessID& pid) { if (!frame || !image || @@ -112,9 +112,11 @@ namespace Kernel if (!hal_check_stack(frame)) return No; - fStack = frame; + this->fStack = frame; + this->fSourcePID = pid; - Bool ret = mp_register_process(image, stack_ptr, fStack); + + Bool ret = mp_register_process(image, stack_ptr, fStack, this->fSourcePID); if (ret) this->Busy(true); -- cgit v1.2.3