summaryrefslogtreecommitdiff
path: root/sys/kern
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/kern_event.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/sys/kern/kern_event.c b/sys/kern/kern_event.c
index 1a854e3eb1d..e7aaffebca1 100644
--- a/sys/kern/kern_event.c
+++ b/sys/kern/kern_event.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kern_event.c,v 1.8 2001/05/14 12:38:46 art Exp $ */
+/* $OpenBSD: kern_event.c,v 1.9 2001/07/17 01:51:37 provos Exp $ */
/*-
* Copyright (c) 1999,2000,2001 Jonathan Lemon <jlemon@FreeBSD.org>
@@ -41,6 +41,7 @@
#include <sys/queue.h>
#include <sys/event.h>
#include <sys/eventvar.h>
+#include <sys/pool.h>
#include <sys/protosw.h>
#include <sys/socket.h>
#include <sys/socketvar.h>
@@ -79,6 +80,7 @@ void knote_attach(struct knote *kn, struct filedesc *fdp);
void knote_drop(struct knote *kn, struct proc *p);
void knote_enqueue(struct knote *kn);
void knote_dequeue(struct knote *kn);
+void knote_init(void);
struct knote *knote_alloc(void);
void knote_free(struct knote *kn);
@@ -96,6 +98,8 @@ struct filterops proc_filtops =
struct filterops file_filtops =
{ 1, filt_fileattach, NULL, NULL };
+struct pool knote_pool;
+
#define KNOTE_ACTIVATE(kn) do { \
kn->kn_status |= KN_ACTIVE; \
if ((kn->kn_status & (KN_QUEUED | KN_DISABLED)) == 0) \
@@ -883,14 +887,28 @@ knote_dequeue(struct knote *kn)
splx(s);
}
+void
+knote_init(void)
+{
+ pool_init(&knote_pool, sizeof(struct knote), 0, 0, 0, "knotepl",
+ 0, pool_page_alloc_nointr, pool_page_free_nointr, M_KNOTE);
+}
+
struct knote *
knote_alloc(void)
{
- return (malloc(sizeof (struct knote), M_KNOTE, M_NOWAIT));
+ static int knote_pool_initialised;
+
+ if (!knote_pool_initialised) {
+ knote_init();
+ knote_pool_initialised++;
+ }
+
+ return (pool_get(&knote_pool, PR_WAITOK));
}
void
knote_free(struct knote *kn)
{
- free(kn, M_KNOTE);
+ pool_put(&knote_pool, kn);
}