mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 06:27:45 +00:00
Kernel/aarch64: Implement Processor::{clear,restore}_critical()
This commit is contained in:
parent
993b7495ba
commit
fbfe669f6d
2 changed files with 9 additions and 3 deletions
|
@ -11,6 +11,7 @@
|
||||||
#include <Kernel/Arch/TrapFrame.h>
|
#include <Kernel/Arch/TrapFrame.h>
|
||||||
#include <Kernel/Arch/aarch64/ASM_wrapper.h>
|
#include <Kernel/Arch/aarch64/ASM_wrapper.h>
|
||||||
#include <Kernel/Arch/aarch64/CPU.h>
|
#include <Kernel/Arch/aarch64/CPU.h>
|
||||||
|
#include <Kernel/InterruptDisabler.h>
|
||||||
#include <Kernel/Scheduler.h>
|
#include <Kernel/Scheduler.h>
|
||||||
#include <Kernel/Thread.h>
|
#include <Kernel/Thread.h>
|
||||||
#include <Kernel/Time/TimeManagement.h>
|
#include <Kernel/Time/TimeManagement.h>
|
||||||
|
@ -60,7 +61,13 @@ void Processor::flush_tlb(Memory::PageDirectory const*, VirtualAddress vaddr, si
|
||||||
|
|
||||||
u32 Processor::clear_critical()
|
u32 Processor::clear_critical()
|
||||||
{
|
{
|
||||||
TODO_AARCH64();
|
InterruptDisabler disabler;
|
||||||
|
auto prev_critical = in_critical();
|
||||||
|
auto& proc = current();
|
||||||
|
proc.m_in_critical = 0;
|
||||||
|
if (proc.m_in_irq == 0)
|
||||||
|
proc.check_invoke_scheduler();
|
||||||
|
return prev_critical;
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 Processor::smp_wake_n_idle_processors(u32 wake_count)
|
u32 Processor::smp_wake_n_idle_processors(u32 wake_count)
|
||||||
|
|
|
@ -192,8 +192,7 @@ public:
|
||||||
|
|
||||||
ALWAYS_INLINE static void restore_critical(u32 prev_critical)
|
ALWAYS_INLINE static void restore_critical(u32 prev_critical)
|
||||||
{
|
{
|
||||||
(void)prev_critical;
|
current().m_in_critical = prev_critical;
|
||||||
TODO_AARCH64();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ALWAYS_INLINE static u32 in_critical()
|
ALWAYS_INLINE static u32 in_critical()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue