2018-10-16 11:01:38 +02:00
|
|
|
#pragma once
|
|
|
|
|
2018-10-22 13:55:11 +02:00
|
|
|
#include <AK/Types.h>
|
2019-02-26 13:30:57 +01:00
|
|
|
#include <LibC/fd_set.h>
|
2018-10-22 13:55:11 +02:00
|
|
|
|
2018-11-06 13:23:22 +01:00
|
|
|
#define ENUMERATE_SYSCALLS \
|
|
|
|
__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(chdir) \
|
|
|
|
__ENUMERATE_SYSCALL(uname) \
|
|
|
|
__ENUMERATE_SYSCALL(set_mmap_name) \
|
|
|
|
__ENUMERATE_SYSCALL(readlink) \
|
|
|
|
__ENUMERATE_SYSCALL(write) \
|
|
|
|
__ENUMERATE_SYSCALL(ttyname_r) \
|
|
|
|
__ENUMERATE_SYSCALL(stat) \
|
|
|
|
__ENUMERATE_SYSCALL(getsid) \
|
|
|
|
__ENUMERATE_SYSCALL(setsid) \
|
|
|
|
__ENUMERATE_SYSCALL(getpgid) \
|
|
|
|
__ENUMERATE_SYSCALL(setpgid) \
|
|
|
|
__ENUMERATE_SYSCALL(getpgrp) \
|
|
|
|
__ENUMERATE_SYSCALL(fork) \
|
|
|
|
__ENUMERATE_SYSCALL(execve) \
|
|
|
|
__ENUMERATE_SYSCALL(geteuid) \
|
|
|
|
__ENUMERATE_SYSCALL(getegid) \
|
|
|
|
__ENUMERATE_SYSCALL(isatty) \
|
|
|
|
__ENUMERATE_SYSCALL(getdtablesize) \
|
|
|
|
__ENUMERATE_SYSCALL(dup) \
|
|
|
|
__ENUMERATE_SYSCALL(dup2) \
|
|
|
|
__ENUMERATE_SYSCALL(sigaction) \
|
2018-11-06 13:33:06 +01:00
|
|
|
__ENUMERATE_SYSCALL(getppid) \
|
2018-11-06 13:40:23 +01:00
|
|
|
__ENUMERATE_SYSCALL(umask) \
|
2018-11-07 01:38:51 +01:00
|
|
|
__ENUMERATE_SYSCALL(getgroups) \
|
|
|
|
__ENUMERATE_SYSCALL(setgroups) \
|
2018-11-07 21:19:47 +01:00
|
|
|
__ENUMERATE_SYSCALL(sigreturn) \
|
2018-11-10 23:29:07 +01:00
|
|
|
__ENUMERATE_SYSCALL(sigprocmask) \
|
|
|
|
__ENUMERATE_SYSCALL(sigpending) \
|
2018-11-11 00:20:53 +01:00
|
|
|
__ENUMERATE_SYSCALL(pipe) \
|
|
|
|
__ENUMERATE_SYSCALL(killpg) \
|
|
|
|
__ENUMERATE_SYSCALL(setuid) \
|
|
|
|
__ENUMERATE_SYSCALL(setgid) \
|
|
|
|
__ENUMERATE_SYSCALL(alarm) \
|
|
|
|
__ENUMERATE_SYSCALL(fstat) \
|
|
|
|
__ENUMERATE_SYSCALL(access) \
|
2018-11-11 10:38:33 +01:00
|
|
|
__ENUMERATE_SYSCALL(fcntl) \
|
2018-11-16 13:11:21 +01:00
|
|
|
__ENUMERATE_SYSCALL(ioctl) \
|
2018-11-18 14:57:41 +01:00
|
|
|
__ENUMERATE_SYSCALL(mkdir) \
|
2018-12-03 01:12:26 +01:00
|
|
|
__ENUMERATE_SYSCALL(times) \
|
2018-12-19 21:14:55 +01:00
|
|
|
__ENUMERATE_SYSCALL(utime) \
|
2018-12-20 00:39:29 +01:00
|
|
|
__ENUMERATE_SYSCALL(sync) \
|
2019-01-15 06:30:19 +01:00
|
|
|
__ENUMERATE_SYSCALL(ptsname_r) \
|
2019-01-24 23:40:12 +01:00
|
|
|
__ENUMERATE_SYSCALL(select) \
|
|
|
|
__ENUMERATE_SYSCALL(unlink) \
|
|
|
|
__ENUMERATE_SYSCALL(poll) \
|
2019-01-25 02:09:29 +01:00
|
|
|
__ENUMERATE_SYSCALL(read_tsc) \
|
2019-01-28 04:16:01 +01:00
|
|
|
__ENUMERATE_SYSCALL(rmdir) \
|
2019-01-29 04:55:08 +01:00
|
|
|
__ENUMERATE_SYSCALL(chmod) \
|
2019-02-03 16:11:28 +01:00
|
|
|
__ENUMERATE_SYSCALL(usleep) \
|
2019-02-14 14:17:38 +01:00
|
|
|
__ENUMERATE_SYSCALL(socket) \
|
|
|
|
__ENUMERATE_SYSCALL(bind) \
|
|
|
|
__ENUMERATE_SYSCALL(accept) \
|
|
|
|
__ENUMERATE_SYSCALL(listen) \
|
|
|
|
__ENUMERATE_SYSCALL(connect) \
|
2019-02-16 12:13:43 +01:00
|
|
|
__ENUMERATE_SYSCALL(create_shared_buffer) \
|
|
|
|
__ENUMERATE_SYSCALL(get_shared_buffer) \
|
|
|
|
__ENUMERATE_SYSCALL(release_shared_buffer) \
|
2019-02-21 13:26:40 +01:00
|
|
|
__ENUMERATE_SYSCALL(link) \
|
2019-02-27 12:32:53 +01:00
|
|
|
__ENUMERATE_SYSCALL(chown) \
|
2019-03-01 10:39:19 +01:00
|
|
|
__ENUMERATE_SYSCALL(fchmod) \
|
2019-03-02 01:50:34 +01:00
|
|
|
__ENUMERATE_SYSCALL(symlink) \
|
2019-03-05 10:34:08 +01:00
|
|
|
__ENUMERATE_SYSCALL(restore_signal_mask) \
|
2019-03-08 12:22:55 +01:00
|
|
|
__ENUMERATE_SYSCALL(get_shared_buffer_size) \
|
|
|
|
__ENUMERATE_SYSCALL(seal_shared_buffer) \
|
2019-03-12 15:51:42 +01:00
|
|
|
__ENUMERATE_SYSCALL(sendto) \
|
2019-03-12 17:27:07 +01:00
|
|
|
__ENUMERATE_SYSCALL(recvfrom) \
|
2019-03-13 13:13:23 +01:00
|
|
|
__ENUMERATE_SYSCALL(getsockopt) \
|
|
|
|
__ENUMERATE_SYSCALL(setsockopt) \
|
2019-03-23 22:59:08 +01:00
|
|
|
__ENUMERATE_SYSCALL(create_thread) \
|
2019-03-25 13:03:49 +01:00
|
|
|
__ENUMERATE_SYSCALL(gettid) \
|
|
|
|
__ENUMERATE_SYSCALL(donate) \
|
2019-01-14 15:25:34 +01:00
|
|
|
|
2018-11-06 13:23:22 +01:00
|
|
|
|
2018-10-16 11:01:38 +02:00
|
|
|
namespace Syscall {
|
|
|
|
|
|
|
|
enum Function {
|
2018-11-06 13:23:22 +01:00
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define __ENUMERATE_SYSCALL(x) SC_ ##x ,
|
|
|
|
ENUMERATE_SYSCALLS
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
2018-10-16 11:01:38 +02:00
|
|
|
};
|
|
|
|
|
2019-01-31 17:31:23 +01:00
|
|
|
inline constexpr const char* to_string(Function function)
|
2018-11-06 13:23:22 +01:00
|
|
|
{
|
|
|
|
switch (function) {
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define __ENUMERATE_SYSCALL(x) case SC_ ##x: return #x;
|
|
|
|
ENUMERATE_SYSCALLS
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
}
|
2018-11-07 21:19:47 +01:00
|
|
|
return "Unknown";
|
2018-11-06 13:23:22 +01:00
|
|
|
}
|
|
|
|
|
2019-01-25 05:19:29 +01:00
|
|
|
#ifdef SERENITY
|
2018-11-08 11:37:01 +01:00
|
|
|
struct SC_mmap_params {
|
|
|
|
uint32_t addr;
|
|
|
|
uint32_t size;
|
|
|
|
int32_t prot;
|
|
|
|
int32_t flags;
|
|
|
|
int32_t fd;
|
2018-11-09 10:09:46 +01:00
|
|
|
int32_t offset; // FIXME: 64-bit off_t?
|
2018-11-08 11:37:01 +01:00
|
|
|
};
|
|
|
|
|
2019-01-15 23:12:20 +01:00
|
|
|
struct SC_select_params {
|
|
|
|
int nfds;
|
|
|
|
fd_set* readfds;
|
|
|
|
fd_set* writefds;
|
|
|
|
fd_set* exceptfds;
|
|
|
|
struct timeval* timeout;
|
|
|
|
};
|
|
|
|
|
2019-03-12 15:51:42 +01:00
|
|
|
struct SC_sendto_params {
|
|
|
|
int sockfd;
|
|
|
|
const void* data;
|
|
|
|
size_t data_length;
|
|
|
|
int flags;
|
|
|
|
const void* addr; // const sockaddr*
|
|
|
|
size_t addr_length; // socklen_t
|
|
|
|
};
|
|
|
|
|
2019-03-12 17:27:07 +01:00
|
|
|
struct SC_recvfrom_params {
|
|
|
|
int sockfd;
|
|
|
|
void* buffer;
|
|
|
|
size_t buffer_length;
|
|
|
|
int flags;
|
2019-03-13 14:47:21 +01:00
|
|
|
void* addr; // sockaddr*
|
|
|
|
void* addr_length; // socklen_t*
|
2019-03-12 17:27:07 +01:00
|
|
|
};
|
|
|
|
|
2019-03-13 13:13:23 +01:00
|
|
|
struct SC_getsockopt_params {
|
|
|
|
int sockfd;
|
|
|
|
int level;
|
|
|
|
int option;
|
|
|
|
void* value;
|
|
|
|
void* value_size; // socklen_t*
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SC_setsockopt_params {
|
|
|
|
int sockfd;
|
|
|
|
int level;
|
|
|
|
int option;
|
|
|
|
const void* value;
|
|
|
|
size_t value_size; // socklen_t
|
|
|
|
};
|
|
|
|
|
2018-10-16 11:01:38 +02:00
|
|
|
void initialize();
|
2018-12-20 02:41:55 +01:00
|
|
|
int sync();
|
2018-10-18 13:05:00 +02:00
|
|
|
|
2018-11-16 13:11:21 +01:00
|
|
|
inline dword invoke(Function function)
|
2018-10-18 13:05:00 +02:00
|
|
|
{
|
2018-10-22 13:55:11 +02:00
|
|
|
dword result;
|
2019-02-26 12:57:02 +01:00
|
|
|
asm volatile("int $0x82":"=a"(result):"a"(function):"memory");
|
2018-10-18 13:05:00 +02:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-12-21 03:02:06 +01:00
|
|
|
template<typename T1>
|
|
|
|
inline dword invoke(Function function, T1 arg1)
|
2018-10-18 13:05:00 +02:00
|
|
|
{
|
2018-10-22 13:55:11 +02:00
|
|
|
dword result;
|
2019-02-26 12:57:02 +01:00
|
|
|
asm volatile("int $0x82":"=a"(result):"a"(function),"d"((dword)arg1):"memory");
|
2018-10-18 13:05:00 +02:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-12-21 03:02:06 +01:00
|
|
|
template<typename T1, typename T2>
|
|
|
|
inline dword invoke(Function function, T1 arg1, T2 arg2)
|
2018-10-18 13:05:00 +02:00
|
|
|
{
|
2018-10-22 13:55:11 +02:00
|
|
|
dword result;
|
2019-02-26 12:57:02 +01:00
|
|
|
asm volatile("int $0x82":"=a"(result):"a"(function),"d"((dword)arg1),"c"((dword)arg2):"memory");
|
2018-10-18 13:05:00 +02:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-12-21 03:02:06 +01:00
|
|
|
template<typename T1, typename T2, typename T3>
|
|
|
|
inline dword invoke(Function function, T1 arg1, T2 arg2, T3 arg3)
|
2018-10-18 13:05:00 +02:00
|
|
|
{
|
2018-10-22 13:55:11 +02:00
|
|
|
dword result;
|
2019-02-26 12:57:02 +01:00
|
|
|
asm volatile("int $0x82":"=a"(result):"a"(function),"d"((dword)arg1),"c"((dword)arg2),"b"((dword)arg3):"memory");
|
2018-10-18 13:05:00 +02:00
|
|
|
return result;
|
|
|
|
}
|
2019-01-25 05:19:29 +01:00
|
|
|
#endif
|
2018-10-16 11:01:38 +02:00
|
|
|
|
|
|
|
}
|
2018-12-21 03:02:06 +01:00
|
|
|
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define __ENUMERATE_SYSCALL(x) using Syscall::SC_ ##x;
|
|
|
|
ENUMERATE_SYSCALLS
|
|
|
|
#undef __ENUMERATE_SYSCALL
|
|
|
|
#define syscall Syscall::invoke
|