From 83d870e58457a1d335a1d9b9966a6a1887cc297b Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Mon, 24 Nov 2025 03:02:43 +0100 Subject: feat! breaking changes on kernel sources. Signed-off-by: Amlal El Mahrouss --- dev/kernel/KernelKit/LockDelegate.h | 58 ------------------------------------- 1 file changed, 58 deletions(-) delete mode 100644 dev/kernel/KernelKit/LockDelegate.h (limited to 'dev/kernel/KernelKit/LockDelegate.h') diff --git a/dev/kernel/KernelKit/LockDelegate.h b/dev/kernel/KernelKit/LockDelegate.h deleted file mode 100644 index 8ff67f19..00000000 --- a/dev/kernel/KernelKit/LockDelegate.h +++ /dev/null @@ -1,58 +0,0 @@ -/* ======================================== - - Copyright (C) 2024-2025, Amlal El Mahrouss, licensed under the Apache 2.0 license. - -======================================== */ - -#pragma once - -#include -#include - -namespace Kernel { -enum { - kLockInvalid = 0, - kLockDone = 200, - kLockTimedOut = 300, - kLockCount = 3, -}; - -/// @brief Lock condition pointer. -typedef Boolean* LockPtr; - -/// @brief Locking delegate class, hangs until limit. -/// @tparam N the amount of cycles to wait. -template -class LockDelegate final { - public: - LockDelegate() = delete; - - public: - explicit LockDelegate(LockPtr expr) { - auto spin = 0U; - - while (spin < N) { - if (*expr) { - fLockStatus | kLockDone; - break; - } - - ++spin; - } - - if (spin > N) fLockStatus | kLockTimedOut; - } - - ~LockDelegate() = default; - - LockDelegate& operator=(const LockDelegate&) = delete; - LockDelegate(const LockDelegate&) = delete; - - bool Done() { return fLockStatus[kLockDone] == kLockDone; } - - bool HasTimedOut() { return fLockStatus[kLockTimedOut] != kLockTimedOut; } - - private: - Atom fLockStatus; -}; -} // namespace Kernel -- cgit v1.2.3