summaryrefslogtreecommitdiff
path: root/lib/libc/dlfcn
diff options
context:
space:
mode:
authorPaul Irofti <pirofti@cvs.openbsd.org>2020-07-06 13:33:10 +0000
committerPaul Irofti <pirofti@cvs.openbsd.org>2020-07-06 13:33:10 +0000
commitb7e506b86a1d9691ff26019343ff523bfd30b393 (patch)
tree8a57536b8a2a17951281291a4bd58752705f500f /lib/libc/dlfcn
parentcce3edda7285834fa934f9d3e3316d3da5a4f28a (diff)
Add support for timeconting in userland.
This diff exposes parts of clock_gettime(2) and gettimeofday(2) to userland via libc eliberating processes from the need for a context switch everytime they want to count the passage of time. If a timecounter clock can be exposed to userland than it needs to set its tc_user member to a non-zero value. Tested with one or multiple counters per architecture. The timing data is shared through a pointer found in the new ELF auxiliary vector AUX_openbsd_timekeep containing timehands information that is frequently updated by the kernel. Timing differences between the last kernel update and the current time are adjusted in userland by the tc_get_timecount() function inside the MD usertc.c file. This permits a much more responsive environment, quite visible in browsers, office programs and gaming (apparently one is are able to fly in Minecraft now). Tested by robert@, sthen@, naddy@, kmos@, phessler@, and many others! OK from at least kettenis@, cheloha@, naddy@, sthen@
Diffstat (limited to 'lib/libc/dlfcn')
-rw-r--r--lib/libc/dlfcn/init.c14
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/libc/dlfcn/init.c b/lib/libc/dlfcn/init.c
index 270f54aada5..3df61076dff 100644
--- a/lib/libc/dlfcn/init.c
+++ b/lib/libc/dlfcn/init.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: init.c,v 1.7 2019/06/02 01:03:01 guenther Exp $ */
+/* $OpenBSD: init.c,v 1.8 2020/07/06 13:33:05 pirofti Exp $ */
/*
* Copyright (c) 2014,2015 Philip Guenther <guenther@openbsd.org>
*
@@ -20,6 +20,7 @@
#include <sys/types.h>
#include <sys/syscall.h>
+#include <sys/timetc.h> /* timekeep */
#ifndef PIC
#include <sys/mman.h>
@@ -45,8 +46,9 @@
/* XXX should be in an include file shared with csu */
char ***_csu_finish(char **_argv, char **_envp, void (*_cleanup)(void));
-/* provide definition for this */
+/* provide definitions for these */
int _pagesize = 0;
+struct timekeep *_timekeep;
/*
* In dynamicly linked binaries environ and __progname are overriden by
@@ -105,6 +107,14 @@ _libc_preinit(int argc, char **argv, char **envp, dl_cb_cb *cb)
phnum = aux->au_v;
break;
#endif /* !PIC */
+ case AUX_openbsd_timekeep:
+ if (_tc_get_timecount) {
+ _timekeep = (void *)aux->au_v;
+ if (_timekeep &&
+ _timekeep->tk_version != TK_VERSION)
+ _timekeep = NULL;
+ }
+ break;
}
}