mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 05:37:34 +00:00
Kernel: Initialize and use interrupts in the aarch64 Kernel
Now that everything is in place, we can actually use interrupts in the aarch64 Kernel build. :^)
This commit is contained in:
parent
dab6dbe893
commit
1072d523e2
1 changed files with 14 additions and 9 deletions
|
@ -10,6 +10,8 @@
|
||||||
#include <AK/Format.h>
|
#include <AK/Format.h>
|
||||||
#include <AK/Types.h>
|
#include <AK/Types.h>
|
||||||
|
|
||||||
|
#include <Kernel/Arch/InterruptManagement.h>
|
||||||
|
#include <Kernel/Arch/Interrupts.h>
|
||||||
#include <Kernel/Arch/Processor.h>
|
#include <Kernel/Arch/Processor.h>
|
||||||
#include <Kernel/Arch/aarch64/BootPPMParser.h>
|
#include <Kernel/Arch/aarch64/BootPPMParser.h>
|
||||||
#include <Kernel/Arch/aarch64/CPU.h>
|
#include <Kernel/Arch/aarch64/CPU.h>
|
||||||
|
@ -106,6 +108,10 @@ extern "C" [[noreturn]] void init()
|
||||||
|
|
||||||
load_kernel_symbol_table();
|
load_kernel_symbol_table();
|
||||||
|
|
||||||
|
initialize_interrupts();
|
||||||
|
InterruptManagement::initialize();
|
||||||
|
Processor::enable_interrupts();
|
||||||
|
|
||||||
auto firmware_version = query_firmware_version();
|
auto firmware_version = query_firmware_version();
|
||||||
dbgln("Firmware version: {}", firmware_version);
|
dbgln("Firmware version: {}", firmware_version);
|
||||||
|
|
||||||
|
@ -117,17 +123,16 @@ extern "C" [[noreturn]] void init()
|
||||||
draw_logo();
|
draw_logo();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto& timer = RPi::Timer::the();
|
||||||
|
timer.set_interrupt_interval_usec(1'000'000);
|
||||||
|
timer.enable_interrupt_mode();
|
||||||
|
|
||||||
dbgln("Enter loop");
|
dbgln("Enter loop");
|
||||||
|
|
||||||
auto& timer = RPi::Timer::the();
|
// This will not disable interrupts, so the timer will still fire and show that
|
||||||
u64 start_musec = 0;
|
// interrupts are working!
|
||||||
for (;;) {
|
for (;;)
|
||||||
u64 now_musec;
|
asm volatile("wfi");
|
||||||
while ((now_musec = timer.microseconds_since_boot()) - start_musec < 1'000'000)
|
|
||||||
;
|
|
||||||
start_musec = now_musec;
|
|
||||||
dbgln("Timer: {}", now_musec);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class QueryFirmwareVersionMboxMessage : RPi::Mailbox::Message {
|
class QueryFirmwareVersionMboxMessage : RPi::Mailbox::Message {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue