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,63 @@
#include <bits/ensure.h>
#include <errno.h>
#include <limits.h>
#include <sched.h>
#include <mlibc/debug.hpp>
#include <mlibc/posix-sysdeps.hpp>
int sched_yield(void) {
if(mlibc::sys_yield) {
mlibc::sys_yield();
}else{
// Missing sched_yield() is not an error.
MLIBC_MISSING_SYSDEP();
}
return 0;
}
int sched_get_priority_max(int policy) {
int res = 0;
auto sysdep = MLIBC_CHECK_OR_ENOSYS(mlibc::sys_get_max_priority, -1);
if(int e = sysdep(policy, &res); e) {
errno = e;
return -1;
}
return res;
}
int sched_get_priority_min(int policy) {
int res = 0;
auto sysdep = MLIBC_CHECK_OR_ENOSYS(mlibc::sys_get_min_priority, -1);
if(int e = sysdep(policy, &res); e) {
errno = e;
return -1;
}
return res;
}
int sched_setscheduler(pid_t, int, const struct sched_param *) {
__ensure(!"Not implemented");
__builtin_unreachable();
}
int sched_getparam(pid_t pid, struct sched_param *param) {
auto sysdep = MLIBC_CHECK_OR_ENOSYS(mlibc::sys_getparam, -1);
if(int e = sysdep(pid, param); e) {
errno = e;
return -1;
}
return 0;
}
int sched_setparam(pid_t pid, const struct sched_param *param) {
auto sysdep = MLIBC_CHECK_OR_ENOSYS(mlibc::sys_setparam, -1);
if(int e = sysdep(pid, param); e) {
errno = e;
return -1;
}
return 0;
}