user: implement mlibc as the libc, finally.

It's finally done..

Signed-off-by: kaguya <vpshinomiya@protonmail.com>
This commit is contained in:
kaguya
2026-05-02 03:31:49 -04:00
parent 2fa39ad85a
commit 9a9b91c940
2387 changed files with 152741 additions and 315 deletions
@@ -0,0 +1,12 @@
#ifndef MLIBC_ARCH_DEFS_HPP
#define MLIBC_ARCH_DEFS_HPP
#include <stddef.h>
namespace mlibc {
inline constexpr size_t page_size = 0x1000;
} // namespace mlibc
#endif // MLIBC_ARCH_DEFS_HPP
@@ -0,0 +1,21 @@
#pragma once
#include <stdint.h>
#include <mlibc/tcb.hpp>
namespace mlibc {
inline Tcb *get_current_tcb() {
// On AArch64, TPIDR_EL0 points to 0x10 bytes before the first TLS block.
uintptr_t ptr;
asm volatile ("mrs %0, tpidr_el0" : "=r"(ptr));
return reinterpret_cast<Tcb *>(ptr + 0x10 - sizeof(Tcb));
}
inline uintptr_t get_sp() {
uintptr_t sp;
asm volatile ("mov %0, sp" : "=r"(sp));
return sp;
}
} // namespace mlibc