forked from Bananymous/banan-os
Kernel: Remove now obsolete CriticalScope
All critical scopes in kernel are now replaced by SpinLocks. This allows proper locking in actual multiprocessing with multiple cores.
This commit is contained in:
parent
8d7dd577ab
commit
a667d88f93
|
@ -1,5 +1,4 @@
|
||||||
#include <BAN/ScopeGuard.h>
|
#include <BAN/ScopeGuard.h>
|
||||||
#include <kernel/CriticalScope.h>
|
|
||||||
#include <kernel/Memory/Heap.h>
|
#include <kernel/Memory/Heap.h>
|
||||||
#include <kernel/Lock/LockGuard.h>
|
#include <kernel/Lock/LockGuard.h>
|
||||||
#include <LibELF/LoadableELF.h>
|
#include <LibELF/LoadableELF.h>
|
||||||
|
|
|
@ -1,30 +0,0 @@
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <BAN/NoCopyMove.h>
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
|
|
||||||
namespace Kernel
|
|
||||||
{
|
|
||||||
|
|
||||||
class CriticalScope
|
|
||||||
{
|
|
||||||
BAN_NON_COPYABLE(CriticalScope);
|
|
||||||
BAN_NON_MOVABLE(CriticalScope);
|
|
||||||
|
|
||||||
public:
|
|
||||||
CriticalScope()
|
|
||||||
{
|
|
||||||
asm volatile("pushf; cli; pop %0" : "=r"(m_flags) :: "memory");
|
|
||||||
}
|
|
||||||
|
|
||||||
~CriticalScope()
|
|
||||||
{
|
|
||||||
asm volatile("push %0; popf" :: "rm"(m_flags) : "memory", "cc");
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
size_t m_flags;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,4 +1,3 @@
|
||||||
#include <kernel/CriticalScope.h>
|
|
||||||
#include <kernel/Lock/LockGuard.h>
|
#include <kernel/Lock/LockGuard.h>
|
||||||
#include <kernel/Memory/Heap.h>
|
#include <kernel/Memory/Heap.h>
|
||||||
#include <kernel/Memory/PageTable.h>
|
#include <kernel/Memory/PageTable.h>
|
||||||
|
|
Loading…
Reference in New Issue