2023-04-12 17:53:02 +03:00
|
|
|
#include <BAN/Assert.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <stddef.h>
|
2023-04-25 12:38:08 +03:00
|
|
|
#include <stdio.h>
|
2023-04-12 17:53:02 +03:00
|
|
|
#include <sys/syscall.h>
|
2023-04-05 23:58:40 +03:00
|
|
|
#include <unistd.h>
|
|
|
|
|
2023-04-12 17:53:02 +03:00
|
|
|
void _exit(int status)
|
|
|
|
{
|
|
|
|
syscall(SYS_EXIT, status);
|
|
|
|
ASSERT_NOT_REACHED();
|
|
|
|
}
|
|
|
|
|
|
|
|
long syscall(long syscall, ...)
|
|
|
|
{
|
|
|
|
va_list args;
|
|
|
|
va_start(args, syscall);
|
|
|
|
|
2023-04-25 12:38:08 +03:00
|
|
|
long ret = -1;
|
2023-04-12 17:53:02 +03:00
|
|
|
|
|
|
|
switch (syscall)
|
|
|
|
{
|
2023-04-22 15:29:15 +03:00
|
|
|
case SYS_EXIT:
|
|
|
|
{
|
|
|
|
int exit_code = va_arg(args, int);
|
|
|
|
ret = Kernel::syscall(SYS_EXIT, exit_code);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SYS_READ:
|
|
|
|
{
|
|
|
|
int fd = va_arg(args, int);
|
|
|
|
void* buffer = va_arg(args, void*);
|
|
|
|
size_t bytes = va_arg(args, size_t);
|
|
|
|
ret = Kernel::syscall(SYS_READ, fd, buffer, bytes);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SYS_WRITE:
|
|
|
|
{
|
|
|
|
int fd = va_arg(args, int);
|
|
|
|
const char* string = va_arg(args, const char*);
|
|
|
|
size_t bytes = va_arg(args, size_t);
|
|
|
|
ret = Kernel::syscall(SYS_WRITE, fd, string, bytes);
|
|
|
|
break;
|
|
|
|
}
|
2023-04-25 12:38:08 +03:00
|
|
|
case SYS_TERMID:
|
|
|
|
{
|
|
|
|
char* buffer = va_arg(args, char*);
|
|
|
|
Kernel::syscall(SYS_TERMID, buffer);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SYS_CLOSE:
|
|
|
|
{
|
|
|
|
int fd = va_arg(args, int);
|
|
|
|
ret = Kernel::syscall(SYS_CLOSE, fd);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SYS_SEEK:
|
|
|
|
{
|
|
|
|
int fd = va_arg(args, int);
|
|
|
|
long offset = va_arg(args, long);
|
|
|
|
ret = Kernel::syscall(SYS_SEEK, fd, offset);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SYS_OPEN:
|
|
|
|
{
|
|
|
|
const char* path = va_arg(args, const char*);
|
|
|
|
int oflags = va_arg(args, int);
|
|
|
|
ret = Kernel::syscall(SYS_OPEN, path, oflags);
|
|
|
|
break;
|
|
|
|
}
|
2023-05-06 18:10:38 +03:00
|
|
|
case SYS_ALLOC:
|
|
|
|
{
|
|
|
|
size_t bytes = va_arg(args, size_t);
|
|
|
|
ret = Kernel::syscall(SYS_ALLOC, bytes);
|
|
|
|
break;
|
|
|
|
}
|
2023-05-07 01:21:50 +03:00
|
|
|
case SYS_FREE:
|
|
|
|
{
|
|
|
|
void* ptr = va_arg(args, void*);
|
|
|
|
ret = Kernel::syscall(SYS_FREE, ptr);
|
|
|
|
break;
|
|
|
|
}
|
2023-04-25 12:38:08 +03:00
|
|
|
default:
|
|
|
|
puts("LibC: Unhandeled syscall");
|
2023-04-12 17:53:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
va_end(args);
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2023-04-05 23:58:40 +03:00
|
|
|
pid_t fork(void)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int execv(const char*, char* const[])
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int execve(const char*, char* const[], char* const[])
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int execvp(const char*, char* const[])
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
pid_t getpid(void)
|
|
|
|
{
|
|
|
|
return -1;
|
|
|
|
}
|