summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authordzwdz2022-05-02 21:47:11 +0200
committerdzwdz2022-05-02 21:47:11 +0200
commit8e276c64c9394d0964506bd6eaa7d4e0547d1ead (patch)
tree4ebefd7507061a04128764f84b56a60b76b7c521 /src
parent577ed9e01a83c13bf151b5137e6fe1eace1c4f7c (diff)
meta: write a script to generate `src/init/syscalls.c`
Diffstat (limited to 'src')
-rw-r--r--src/init/syscalls.c33
-rw-r--r--src/shared/syscalls.h8
2 files changed, 23 insertions, 18 deletions
diff --git a/src/init/syscalls.c b/src/init/syscalls.c
index a374976..daddde9 100644
--- a/src/init/syscalls.c
+++ b/src/init/syscalls.c
@@ -1,37 +1,41 @@
-// this file could probably just get generated by a script
+/* generated by tools/syscall_wrappers.awk
+ * don't modify manually, instead run:
+ * make src/init/syscalls.c
+ */
#include <shared/syscalls.h>
+
_Noreturn void _syscall_exit(int ret) {
_syscall(_SYSCALL_EXIT, ret, 0, 0, 0);
__builtin_unreachable();
}
-int _syscall_fork(int flags) {
- return _syscall(_SYSCALL_FORK, flags, 0, 0, 0);
-}
-
int _syscall_await(void) {
return _syscall(_SYSCALL_AWAIT, 0, 0, 0, 0);
}
+int _syscall_fork(int flags) {
+ return _syscall(_SYSCALL_FORK, flags, 0, 0, 0);
+}
+
handle_t _syscall_open(const char __user *path, int len) {
return _syscall(_SYSCALL_OPEN, (int)path, len, 0, 0);
}
-int _syscall_mount(handle_t handle, const char __user *path, int len) {
- return _syscall(_SYSCALL_MOUNT, handle, (int)path, len, 0);
+int _syscall_mount(handle_t h, const char __user *path, int len) {
+ return _syscall(_SYSCALL_MOUNT, (int)h, (int)path, len, 0);
}
-int _syscall_read(handle_t handle, void __user *buf, size_t len, int offset) {
- return _syscall(_SYSCALL_READ, handle, (int)buf, (int)len, offset);
+int _syscall_read(handle_t h, void __user *buf, size_t len, int offset) {
+ return _syscall(_SYSCALL_READ, (int)h, (int)buf, (int)len, offset);
}
-int _syscall_write(handle_t handle, const void __user *buf, size_t len, int offset) {
- return _syscall(_SYSCALL_WRITE, handle, (int)buf, (int)len, offset);
+int _syscall_write(handle_t h, const void __user *buf, size_t len, int offset) {
+ return _syscall(_SYSCALL_WRITE, (int)h, (int)buf, (int)len, offset);
}
-int _syscall_close(handle_t handle) {
- return _syscall(_SYSCALL_CLOSE, handle, 0, 0, 0);
+int _syscall_close(handle_t h) {
+ return _syscall(_SYSCALL_CLOSE, (int)h, 0, 0, 0);
}
handle_t _syscall_fs_fork2(void) {
@@ -47,5 +51,6 @@ int _syscall_fs_respond(char __user *buf, int ret) {
}
int _syscall_memflag(void __user *addr, size_t len, int flags) {
- return _syscall(_SYSCALL_MEMFLAG, (int)addr, len, flags, 0);
+ return _syscall(_SYSCALL_MEMFLAG, (int)addr, (int)len, flags, 0);
}
+
diff --git a/src/shared/syscalls.h b/src/shared/syscalls.h
index 5773190..d986d11 100644
--- a/src/shared/syscalls.h
+++ b/src/shared/syscalls.h
@@ -44,10 +44,10 @@ int _syscall_fork(int flags);
handle_t _syscall_open(const char __user *path, int len);
-int _syscall_mount(handle_t, const char __user *path, int len);
-int _syscall_read(handle_t, void __user *buf, size_t len, int offset);
-int _syscall_write(handle_t, const void __user *buf, size_t len, int offset);
-int _syscall_close(handle_t);
+int _syscall_mount(handle_t h, const char __user *path, int len);
+int _syscall_read(handle_t h, void __user *buf, size_t len, int offset);
+int _syscall_write(handle_t h, const void __user *buf, size_t len, int offset);
+int _syscall_close(handle_t h);
handle_t _syscall_fs_fork2(void);