2018-10-16 09:01:38 +00:00
|
|
|
#pragma once
|
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
#include <AK/Types.h>
|
|
|
|
|
2018-11-06 12:23:22 +00:00
|
|
|
#define ENUMERATE_SYSCALLS \
|
|
|
|
__ENUMERATE_SYSCALL(spawn) \
|
|
|
|
__ENUMERATE_SYSCALL(sleep) \
|
|
|
|
__ENUMERATE_SYSCALL(yield) \
|
|
|
|
__ENUMERATE_SYSCALL(putch) \
|
|
|
|
__ENUMERATE_SYSCALL(open) \
|
|
|
|
__ENUMERATE_SYSCALL(close) \
|
|
|
|
__ENUMERATE_SYSCALL(read) \
|
|
|
|
__ENUMERATE_SYSCALL(lseek) \
|
|
|
|
__ENUMERATE_SYSCALL(kill) \
|
|
|
|
__ENUMERATE_SYSCALL(getuid) \
|
|
|
|
__ENUMERATE_SYSCALL(exit) \
|
|
|
|
__ENUMERATE_SYSCALL(getgid) \
|
|
|
|
__ENUMERATE_SYSCALL(getpid) \
|
|
|
|
__ENUMERATE_SYSCALL(waitpid) \
|
|
|
|
__ENUMERATE_SYSCALL(mmap) \
|
|
|
|
__ENUMERATE_SYSCALL(munmap) \
|
|
|
|
__ENUMERATE_SYSCALL(get_dir_entries) \
|
|
|
|
__ENUMERATE_SYSCALL(lstat) \
|
|
|
|
__ENUMERATE_SYSCALL(getcwd) \
|
|
|
|
__ENUMERATE_SYSCALL(gettimeofday) \
|
|
|
|
__ENUMERATE_SYSCALL(gethostname) \
|
|
|
|
__ENUMERATE_SYSCALL(get_arguments) \
|
|
|
|
__ENUMERATE_SYSCALL(chdir) \
|
|
|
|
__ENUMERATE_SYSCALL(uname) \
|
|
|
|
__ENUMERATE_SYSCALL(set_mmap_name) \
|
|
|
|
__ENUMERATE_SYSCALL(readlink) \
|
|
|
|
__ENUMERATE_SYSCALL(write) \
|
|
|
|
__ENUMERATE_SYSCALL(ttyname_r) \
|
|
|
|
__ENUMERATE_SYSCALL(stat) \
|
|
|
|
__ENUMERATE_SYSCALL(get_environment) \
|
|
|
|
__ENUMERATE_SYSCALL(getsid) \
|
|
|
|
__ENUMERATE_SYSCALL(setsid) \
|
|
|
|
__ENUMERATE_SYSCALL(getpgid) \
|
|
|
|
__ENUMERATE_SYSCALL(setpgid) \
|
|
|
|
__ENUMERATE_SYSCALL(getpgrp) \
|
|
|
|
__ENUMERATE_SYSCALL(tcsetpgrp) \
|
|
|
|
__ENUMERATE_SYSCALL(tcgetpgrp) \
|
|
|
|
__ENUMERATE_SYSCALL(fork) \
|
|
|
|
__ENUMERATE_SYSCALL(execve) \
|
|
|
|
__ENUMERATE_SYSCALL(geteuid) \
|
|
|
|
__ENUMERATE_SYSCALL(getegid) \
|
|
|
|
__ENUMERATE_SYSCALL(signal) \
|
|
|
|
__ENUMERATE_SYSCALL(isatty) \
|
|
|
|
__ENUMERATE_SYSCALL(getdtablesize) \
|
|
|
|
__ENUMERATE_SYSCALL(dup) \
|
|
|
|
__ENUMERATE_SYSCALL(dup2) \
|
|
|
|
__ENUMERATE_SYSCALL(sigaction) \
|
2018-11-06 12:33:06 +00:00
|
|
|
__ENUMERATE_SYSCALL(getppid) \
|
2018-11-06 12:40:23 +00:00
|
|
|
__ENUMERATE_SYSCALL(umask) \
|
2018-11-07 00:38:51 +00:00
|
|
|
__ENUMERATE_SYSCALL(getgroups) \
|
|
|
|
__ENUMERATE_SYSCALL(setgroups) \
|
2018-11-07 20:19:47 +00:00
|
|
|
__ENUMERATE_SYSCALL(sigreturn) \
|
2018-11-06 12:23:22 +00:00
|
|
|
|
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
#define DO_SYSCALL_A0(function) Syscall::invoke((dword)(function))
|
|
|
|
#define DO_SYSCALL_A1(function, arg1) Syscall::invoke((dword)(function), (dword)(arg1))
|
|
|
|
#define DO_SYSCALL_A2(function, arg1, arg2) Syscall::invoke((dword)(function), (dword)(arg1), (dword)(arg2))
|
|
|
|
#define DO_SYSCALL_A3(function, arg1, arg2, arg3) Syscall::invoke((dword)(function), (dword)(arg1), (dword)(arg2), (dword)arg3)
|
2018-10-16 09:01:38 +00:00
|
|
|
|
|
|
|
namespace Syscall {
|
|
|
|
|
|
|
|
enum Function {
|
2018-11-06 12:23:22 +00:00
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define __ENUMERATE_SYSCALL(x) SC_ ##x ,
|
|
|
|
ENUMERATE_SYSCALLS
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
2018-10-16 09:01:38 +00:00
|
|
|
};
|
|
|
|
|
2018-11-06 12:23:22 +00:00
|
|
|
inline constexpr const char* toString(Function function)
|
|
|
|
{
|
|
|
|
switch (function) {
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define __ENUMERATE_SYSCALL(x) case SC_ ##x: return #x;
|
|
|
|
ENUMERATE_SYSCALLS
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
}
|
2018-11-07 20:19:47 +00:00
|
|
|
return "Unknown";
|
2018-11-06 12:23:22 +00:00
|
|
|
}
|
|
|
|
|
2018-10-16 09:01:38 +00:00
|
|
|
void initialize();
|
2018-10-18 11:05:00 +00:00
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
inline dword invoke(dword function)
|
2018-10-18 11:05:00 +00:00
|
|
|
{
|
2018-10-22 11:55:11 +00:00
|
|
|
dword result;
|
2018-10-22 09:43:55 +00:00
|
|
|
asm volatile("int $0x80":"=a"(result):"a"(function));
|
2018-10-18 11:05:00 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
inline dword invoke(dword function, dword arg1)
|
2018-10-18 11:05:00 +00:00
|
|
|
{
|
2018-10-22 11:55:11 +00:00
|
|
|
dword result;
|
2018-10-22 09:43:55 +00:00
|
|
|
asm volatile("int $0x80":"=a"(result):"a"(function),"d"(arg1));
|
2018-10-18 11:05:00 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
inline dword invoke(dword function, dword arg1, dword arg2)
|
2018-10-18 11:05:00 +00:00
|
|
|
{
|
2018-10-22 11:55:11 +00:00
|
|
|
dword result;
|
2018-10-22 09:43:55 +00:00
|
|
|
asm volatile("int $0x80":"=a"(result):"a"(function),"d"(arg1),"c"(arg2));
|
2018-10-18 11:05:00 +00:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-10-22 11:55:11 +00:00
|
|
|
inline dword invoke(dword function, dword arg1, dword arg2, dword arg3)
|
2018-10-18 11:05:00 +00:00
|
|
|
{
|
2018-10-22 11:55:11 +00:00
|
|
|
dword result;
|
2018-10-18 11:05:00 +00:00
|
|
|
asm volatile("int $0x80":"=a"(result):"a"(function),"d"(arg1),"c"(arg2),"b"(arg3));
|
|
|
|
return result;
|
|
|
|
}
|
2018-10-16 09:01:38 +00:00
|
|
|
|
|
|
|
}
|