LibC: add needed stubs to build executables with our compiler
This commit is contained in:
@@ -15,6 +15,9 @@
|
||||
#define SEEK_END 1
|
||||
#define SEEK_SET 2
|
||||
|
||||
#define EXIT_FAILURE 1
|
||||
#define EXIT_SUCCESS 0
|
||||
|
||||
__BEGIN_DECLS
|
||||
|
||||
struct FILE;
|
||||
|
||||
@@ -6,6 +6,7 @@
|
||||
__BEGIN_DECLS
|
||||
|
||||
[[noreturn]] void abort(void);
|
||||
[[noreturn]] void exit(int);
|
||||
|
||||
int abs(int);
|
||||
|
||||
|
||||
3
libc/include/sys/syscall.h
Normal file
3
libc/include/sys/syscall.h
Normal file
@@ -0,0 +1,3 @@
|
||||
#pragma once
|
||||
|
||||
#include <kernel/Syscall.h>
|
||||
@@ -6,16 +6,17 @@
|
||||
#define STDOUT_FILENO 1
|
||||
#define STDERR_FILENO 2
|
||||
|
||||
// fork(), execv(), execve(), execvp(), getpid()
|
||||
|
||||
__BEGIN_DECLS
|
||||
|
||||
[[noreturn]] void _exit(int);
|
||||
|
||||
pid_t fork(void);
|
||||
pid_t getpid(void);
|
||||
|
||||
int execv(const char*, char* const[]);
|
||||
int execve(const char*, char* const[], char* const[]);
|
||||
int execvp(const char*, char* const[]);
|
||||
|
||||
pid_t getpid(void);
|
||||
long syscall(long, ...);
|
||||
|
||||
__END_DECLS
|
||||
@@ -1,10 +1,18 @@
|
||||
#include <BAN/Assert.h>
|
||||
#include <ctype.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <ctype.h>
|
||||
#include <unistd.h>
|
||||
|
||||
void abort(void)
|
||||
{
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
|
||||
void exit(int status)
|
||||
{
|
||||
_exit(status);
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
|
||||
int abs(int val)
|
||||
|
||||
@@ -1,5 +1,40 @@
|
||||
#include <BAN/Assert.h>
|
||||
#include <stdarg.h>
|
||||
#include <stddef.h>
|
||||
#include <sys/syscall.h>
|
||||
#include <unistd.h>
|
||||
|
||||
void _exit(int status)
|
||||
{
|
||||
syscall(SYS_EXIT, status);
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
|
||||
long syscall(long syscall, ...)
|
||||
{
|
||||
va_list args;
|
||||
va_start(args, syscall);
|
||||
|
||||
long ret = 0;
|
||||
|
||||
switch (syscall)
|
||||
{
|
||||
case SYS_EXIT:
|
||||
ret = Kernel::syscall(SYS_EXIT, va_arg(args, int));
|
||||
break;
|
||||
case SYS_READ:
|
||||
ret = Kernel::syscall(SYS_READ, va_arg(args, int), va_arg(args, void*), va_arg(args, size_t));
|
||||
break;
|
||||
case SYS_WRITE:
|
||||
ret = Kernel::syscall(SYS_WRITE, va_arg(args, int), va_arg(args, const void*), va_arg(args, size_t));
|
||||
break;
|
||||
}
|
||||
|
||||
va_end(args);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
pid_t fork(void)
|
||||
{
|
||||
return -1;
|
||||
|
||||
Reference in New Issue
Block a user