summaryrefslogtreecommitdiff
path: root/sys/kern/kern_idle.c
diff options
context:
space:
mode:
authorMike Smith <msmith@FreeBSD.org>2000-09-22 03:19:24 +0000
committerMike Smith <msmith@FreeBSD.org>2000-09-22 03:19:24 +0000
commitbdf3d8b95493310afe0787f7b7ea8198c20ed058 (patch)
treee24a08af61495f637a40abed8e06d00ae3dff865 /sys/kern/kern_idle.c
parent72b535ef459a47ad88439bd113f0bec730cf8321 (diff)
Notes
Diffstat (limited to 'sys/kern/kern_idle.c')
-rw-r--r--sys/kern/kern_idle.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/sys/kern/kern_idle.c b/sys/kern/kern_idle.c
index d9f55ae28682..1a95e2856af8 100644
--- a/sys/kern/kern_idle.c
+++ b/sys/kern/kern_idle.c
@@ -18,6 +18,7 @@
#include <sys/unistd.h>
#include <sys/kthread.h>
#include <sys/queue.h>
+#include <sys/eventhandler.h>
#include <vm/vm.h>
#include <vm/vm_extern.h>
#ifdef KTRACE
@@ -44,6 +45,8 @@ SYSINIT(idle_setup, SI_SUB_SCHED_IDLE, SI_ORDER_FIRST, idle_setup, NULL)
static void idle_proc(void *dummy);
+EVENTHANDLER_FAST_DEFINE(idle_event, idle_eventhandler_t);
+
/*
* setup per-cpu idle process contexts
*/
@@ -88,9 +91,13 @@ idle_proc(void *dummy)
* This is a good place to put things to be done in
* the background, including sanity checks.
*/
+
if (count++ < 0)
CTR0(KTR_PROC, "idle_proc: timed out waiting"
" for a process");
+
+ /* call out to any cpu-becoming-idle events */
+ EVENTHANDLER_FAST_INVOKE(idle_event, count);
}
mtx_enter(&sched_lock, MTX_SPIN);