ref: 2968225196d6078203e88d26572a51216f545c1d
parent: 23de6808f70552beeb4b3a3374543f7aaf31c4c8
author: kvik <[email protected]>
date: Wed Sep 23 13:17:52 EDT 2020
syscall: fix build problem caused by stale tab.h Recently the script which generates tab.h and the code including it got incompatibly changed. People reported problems involving syntax errors when trying to rebuild the system following a sysupdate. The problem was with the script being embedded within a mkfile rule, meaning that mk didn't notice it changing and therefore didn't rebuild the target file. For people who were rebuilding the system this meant that the old tab.h got included, causing syntax errors. This patch moves the codegen script into a file and tells mk about this new dependency, so that tab.h will get rebuilt for everyone. I also took an opportunity to rewrite the script, hopefuly making it easier to follow.
--- a/sys/src/cmd/syscall/mkfile
+++ b/sys/src/cmd/syscall/mkfile
@@ -16,25 +16,8 @@
SYSCALL=/sys/src/libc/9syscall/sys.h
-tab.h: $SYSCALL
- awk '
- BEGIN{ print "enum{" }
- { printf "%s, ", $2 }
- END{
- print "READ, WRITE, NTAB"
- print "};"
- }' <$SYSCALL >$target
- awk '
- BEGIN{ print "struct Call tab[] = {" }
- { printf "[%s] \"%s\", (int(*)(...))%s,\n",
- $2, tolower($2), tolower($2)
- }
- END{
- print "[READ] \"read\", (int(*)(...))read,"
- print "[WRITE] \"write\", (int(*)(...))write,"
- print "[NTAB] nil, 0"
- print "};"
- }' <$SYSCALL >>$target
+tab.h: $SYSCALL mktab.awk
+ mktab.awk $SYSCALL >$target
clean:V:
rm -f *.[$OS] [$OS].out $TARG $HFILES
--- /dev/null
+++ b/sys/src/cmd/syscall/mktab.awk
@@ -1,0 +1,14 @@
+#!/bin/awk -f
+{ e = e $2 ", "
+ s = s sprintf("[%s] \"%s\", (int(*)(...))%s,\n",
+ $2, tolower($2), tolower($2))
+}
+END{
+ e = e "READ, WRITE, NTAB"
+ s = s "[READ] \"read\", (int(*)(...))read,\n"
+ s = s "[WRITE] \"write\", (int(*)(...))write,\n"
+ s = s "[NTAB] nil, 0\n"
+
+ print "enum{", e, "};"
+ print "struct Call tab[] = {\n", s, "};"
+}