summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/kern/kern_resource.c27
1 files changed, 16 insertions, 11 deletions
diff --git a/sys/kern/kern_resource.c b/sys/kern/kern_resource.c
index 91a2afe7f0c..57411a751d2 100644
--- a/sys/kern/kern_resource.c
+++ b/sys/kern/kern_resource.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kern_resource.c,v 1.17 2001/12/20 21:56:19 nordin Exp $ */
+/* $OpenBSD: kern_resource.c,v 1.18 2002/01/25 14:54:00 art Exp $ */
/* $NetBSD: kern_resource.c,v 1.38 1996/10/23 07:19:38 matthias Exp $ */
/*-
@@ -46,7 +46,7 @@
#include <sys/kernel.h>
#include <sys/file.h>
#include <sys/resourcevar.h>
-#include <sys/malloc.h>
+#include <sys/pool.h>
#include <sys/proc.h>
#include <sys/mount.h>
@@ -425,19 +425,26 @@ ruadd(ru, ru2)
*ip++ += *ip2++;
}
+struct pool plimit_pool;
+
/*
* Make a copy of the plimit structure.
* We share these structures copy-on-write after fork,
* and copy when a limit is changed.
*/
struct plimit *
-limcopy(lim)
- struct plimit *lim;
+limcopy(struct plimit *lim)
{
- register struct plimit *newlim;
+ struct plimit *newlim;
+ static int initialized;
+
+ if (!initialized) {
+ pool_init(&plimit_pool, sizeof(struct plimit), 0, 0, 0,
+ "plimitpl", &pool_allocator_nointr);
+ initialized = 1;
+ }
- MALLOC(newlim, struct plimit *, sizeof(struct plimit),
- M_SUBPROC, M_WAITOK);
+ newlim = pool_get(&plimit_pool, PR_WAITOK);
bcopy(lim->pl_rlimit, newlim->pl_rlimit,
sizeof(struct rlimit) * RLIM_NLIMITS);
newlim->p_lflags = 0;
@@ -446,11 +453,9 @@ limcopy(lim)
}
void
-limfree(lim)
- struct plimit *lim;
+limfree(struct plimit *lim)
{
-
if (--lim->p_refcnt > 0)
return;
- FREE(lim, M_SUBPROC);
+ pool_put(&plimit_pool, lim);
}