671a9b5887
core: Add PIT timer code to preempt the scheduler
2025-02-16 11:58:01 +01:00
a209ba7b99
core: Allocate a stack for each core's idle thread
2025-02-16 11:57:27 +01:00
4554bce8a8
core: Add thread states
2025-02-16 11:57:04 +01:00
f87426753b
core: Add global FrameAllocator with locking
2025-02-16 11:56:14 +01:00
14862ec271
core: Add spinlock code
2025-02-16 11:52:45 +01:00
ea952efe8a
core: Fix a few bugs in threading code
...
g_threads is processor-specific now, so it's unused, and setPageDirectory() needs the physical address.
2025-02-15 22:58:34 +01:00
58481a76b1
Update README.md
2025-02-15 22:55:13 +01:00
a76e94c517
core: Add a simple ELF loader
...
We only need the ELF loader for init, and possibly a few other modules. The bulk of loading executables is going to be done by userspace, so we only need the basics here.
2025-02-15 22:46:28 +01:00
ed324fcf9e
core: Add basic threading code
2025-02-15 22:45:32 +01:00
fa04363a51
core/x86_64: Set up a second stack in the TSS to handle system calls
2025-02-15 22:40:48 +01:00
56f2c018a7
core: Fix a couple of bugs in VMM and add a few utility functions
2025-02-15 22:23:00 +01:00
f93158645b
core/x86_64: Enable the NX bit before using it
...
Spent an embarrassing amount of time trying to figure out why there was a page fault with "reserved bits set". Turns out, I had set the NX bit without enabling it.
2025-02-15 22:22:04 +01:00
36b9832053
core/x86_64: Add general protection fault handler
2025-02-15 22:19:08 +01:00
090e4148b8
core: Reserve physical page 0
...
In the kernel's early stages we access physical memory identity-mapped, so it's not very good for us to allocate that frame and then try to use it.
2025-02-15 22:18:49 +01:00
8bfc8a5781
core: Make findMultibootTags take a context argument
...
Will be useful later.
2025-02-15 22:18:05 +01:00
adffd408bc
core: Add a page fault handler
2025-02-15 15:18:40 +01:00
8d70a0f0a1
core: Enable interrupts in platformEndInit()
...
This way, each architecture can re-enable interrupts whenever necessary
2025-02-15 15:18:24 +01:00
5d26b114a4
core: Add workaround for QEMU-specific triple-faults without KVM
...
Without KVM, qemu inserts an invalid 12-GiB reserved entry at the end of the physical address space, making the kernel reserve way more space than necessary for the page bitmap (and overwriting the page directory pages).
2025-02-15 15:16:50 +01:00
13ec4bee87
Ready. Set. Go!
...
Microkernel development in Zig, should be fun! =]
2025-02-13 22:39:48 +01:00