From 8c7b8d9e4ec40c38c657851354fc74428f0df1ac Mon Sep 17 00:00:00 2001 From: dzwdz Date: Sat, 4 May 2024 18:22:23 +0200 Subject: user/ntpfs: implement a basic ntp client time() will probably end up doing io. That sounded bad at first, but Plan 9 does that too (see /sys/src/libc/9sys/nsec.c), so it's probably fine. I might need better service management soon. Also, dunno what it should return before it makes contact with NTP. I could implement RTC support, but eh. Doesn't feel that necessary. I'll also need to remember how the hell threading works, so it can talk with the ntp daemon on another thread. --- src/cmd/init/init.c | 7 +++++++ 1 file changed, 7 insertions(+) (limited to 'src/cmd/init') diff --git a/src/cmd/init/init.c b/src/cmd/init/init.c index d8cb1f4..68268bf 100644 --- a/src/cmd/init/init.c +++ b/src/cmd/init/init.c @@ -129,6 +129,13 @@ int main(void) { MOUNT_AT("/") { fs_whitelist(allow); } execv(argv[0], (void*)argv); } + MOUNT_AT("/dev/ntp") { + const char *allow[] = {"/bin/ntpfs", "/net/connect/", NULL}; + const char *argv[] = {"/bin/ntpfs", "/net/connect/0/10.69.0.1/udp/123", NULL}; + MOUNT_AT("/") { fs_whitelist(allow); } + _sys_sleep(1000); /* hack, waits until the network goes up */ + execv(argv[0], (void*)argv); + } if (!fork()) { redirect("/bin/shell", "/dev/com1", "/dev/com1"); -- cgit v1.2.3