summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authordzwdz2022-07-11 21:54:51 +0200
committerdzwdz2022-07-11 21:54:51 +0200
commit2e79a2e5af3affa7a6a3becdffb1c91d89af90af (patch)
treec253761c4ec010ad14b08f9ee8dfc1a50411b30f /tools
parent6c01d9a7e34e1fccc2775b0e2187ac5e50dd4392 (diff)
user: reorganize the userland sources
Diffstat (limited to 'tools')
-rw-r--r--tools/syscall_wrappers.awk51
1 files changed, 0 insertions, 51 deletions
diff --git a/tools/syscall_wrappers.awk b/tools/syscall_wrappers.awk
deleted file mode 100644
index 4a295f2..0000000
--- a/tools/syscall_wrappers.awk
+++ /dev/null
@@ -1,51 +0,0 @@
-BEGIN {
- print "\
-/* generated by tools/syscall_wrappers.awk\n\
- * don't modify manually, instead run:\n\
- * make src/init/syscalls.c\n\
- */\n\
-#include <shared/syscalls.h>\n\
-\n";
-}
-
-/_syscall\(/ { next; } # skipping _syscall(), it's implemented elsewhere
-
-/\);/ {
- sub(/;/, " {");
- print $0;
-
- name = substr($0, match($0, /_syscall_[^(]+/), RLENGTH);
- rets = substr($0, 0, RSTART - 1);
- sub(/ *$/, "", rets)
-
- params = substr($0, match($0, /\(.+\)/) + 1, RLENGTH - 2);
- gsub(/\[[^\]]\]/, "", params);
- if (params == "void") params = ""
-
- split(params, p, /,/);
- for (i = 0; i <= 4; i += 1) {
- if (p[i]) {
- # p[i] is a parameter, convert it into an expression to pass to _syscall()
- sub(/^ */, "", p[i]); # strip
- split(p[i], words, / /);
- if (length(words) != 1) {
- var = words[length(words)];
- sub(/\*/, "", var);
- if (words[1] != "int") var = "(int)" var;
- }
- p[i] = var;
- } else {
- p[i] = 0;
- }
- }
-
- printf "\t";
- if (!index($0, "_Noreturn")) {
- printf "return ";
- if (rets != "int") printf "(%s)", rets;
- }
- printf "_syscall(%s, %s, %s, %s, %s);\n", toupper(name), p[1], p[2], p[3], p[4];
- if (index($0, "_Noreturn")) print "\t__builtin_unreachable();";
-
- print "}\n";
-}