summaryrefslogtreecommitdiff
path: root/sys/kern/uipc_mbuf.c
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2004-04-19 22:52:34 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2004-04-19 22:52:34 +0000
commit9bc570a1a157252d3dde353d2da5ccfd24665616 (patch)
tree88a9ac63023de5d94546a8e9129d1c3ecfe7a66b /sys/kern/uipc_mbuf.c
parentdd55ffea5bfb74d9d44db416eb54a9c0b02fdd3a (diff)
introduce a new km_page allocator that gets pages from kernel_map using
an interrupt safe thread. use this as the new backend for mbpool and mclpool, eliminating the mb_map. introduce a sysctl kern.maxclusters which controls the limit of clusters allocated. testing by many people, works everywhere but m68k. ok deraadt@ this essentially deprecates the NMBCLUSTERS option, don't use it. this should reduce pressure on the kmem_map and the uvm reserve of static map entries.
Diffstat (limited to 'sys/kern/uipc_mbuf.c')
-rw-r--r--sys/kern/uipc_mbuf.c40
1 files changed, 20 insertions, 20 deletions
diff --git a/sys/kern/uipc_mbuf.c b/sys/kern/uipc_mbuf.c
index 13c00cb32d5..9a8fd13e121 100644
--- a/sys/kern/uipc_mbuf.c
+++ b/sys/kern/uipc_mbuf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uipc_mbuf.c,v 1.66 2004/04/17 10:18:12 mcbride Exp $ */
+/* $OpenBSD: uipc_mbuf.c,v 1.67 2004/04/19 22:52:33 tedu Exp $ */
/* $NetBSD: uipc_mbuf.c,v 1.15.4.1 1996/06/13 17:11:44 cgd Exp $ */
/*
@@ -102,9 +102,11 @@ int max_datalen; /* MHLEN - max_hdr */
void *mclpool_alloc(struct pool *, int);
void mclpool_release(struct pool *, void *);
struct mbuf *m_copym0(struct mbuf *, int, int, int, int);
+void nmbclust_update(void);
+
const char *mclpool_warnmsg =
- "WARNING: mclpool limit reached; increase NMBCLUSTERS";
+ "WARNING: mclpool limit reached; increase kern.maxclusters";
struct pool_allocator mclpool_allocator = {
mclpool_alloc, mclpool_release, 0,
@@ -116,24 +118,13 @@ struct pool_allocator mclpool_allocator = {
void
mbinit()
{
- vaddr_t minaddr, maxaddr;
-
- minaddr = vm_map_min(kernel_map);
- mb_map = uvm_km_suballoc(kernel_map, &minaddr, &maxaddr,
- nmbclust*(MCLBYTES), VM_MAP_INTRSAFE, FALSE, NULL);
-
- pool_init(&mbpool, MSIZE, 0, 0, 0, "mbpl", NULL);
+ pool_init(&mbpool, MSIZE, 0, 0, 0, "mbpl", &mclpool_allocator);
pool_init(&mclpool, MCLBYTES, 0, 0, 0, "mclpl", &mclpool_allocator);
pool_set_drain_hook(&mbpool, m_reclaim, NULL);
pool_set_drain_hook(&mclpool, m_reclaim, NULL);
- /*
- * Set the hard limit on the mclpool to the number of
- * mbuf clusters the kernel is to support. Log the limit
- * reached message max once a minute.
- */
- (void)pool_sethardlimit(&mclpool, nmbclust, mclpool_warnmsg, 60);
+ nmbclust_update();
/*
* Set a low water mark for both mbufs and clusters. This should
@@ -145,20 +136,29 @@ mbinit()
pool_setlowat(&mclpool, mcllowat);
}
+void
+nmbclust_update(void)
+{
+ /*
+ * Set the hard limit on the mclpool to the number of
+ * mbuf clusters the kernel is to support. Log the limit
+ * reached message max once a minute.
+ */
+ (void)pool_sethardlimit(&mclpool, nmbclust, mclpool_warnmsg, 60);
+}
+
+
void *
mclpool_alloc(struct pool *pp, int flags)
{
- boolean_t waitok = (flags & PR_WAITOK) ? TRUE : FALSE;
-
- return ((void *)uvm_km_alloc_poolpage1(mb_map, uvmexp.mb_object,
- waitok));
+ return uvm_km_getpage();
}
void
mclpool_release(struct pool *pp, void *v)
{
- uvm_km_free_poolpage1(mb_map, (vaddr_t)v);
+ uvm_km_putpage(v);
}
void