Date: Sat, 11 Feb 2006 23:36:39 +0000 (GMT) From: Robert Watson <rwatson@FreeBSD.org> To: Peter Wemm <peter@FreeBSD.org> Cc: Perforce Change Reviews <perforce@freebsd.org> Subject: Re: PERFORCE change 91580 for review Message-ID: <20060211233448.D71792@fledge.watson.org> In-Reply-To: <200602111826.k1BIQLrI082592@repoman.freebsd.org> References: <200602111826.k1BIQLrI082592@repoman.freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sat, 11 Feb 2006, Peter Wemm wrote: > http://perforce.freebsd.org/chv.cgi?CH=91580 > > Change 91580 by peter@peter_daintree on 2006/02/11 18:25:50 > > Try making the nmbclusters sysctl actually do something. Out of paranoia, > do not allow it to reduce the current value - ie: increase only. It would > probably work, but wouldn't be healthy to the network stack if we allowed it > to be run into the ground. ... > -/* XXX: These should be tuneables. Can't change UMA limits on the fly. */ > -SYSCTL_INT(_kern_ipc, OID_AUTO, nmbclusters, CTLFLAG_RW, &nmbclusters, 0, > - "Maximum number of mbuf clusters allowed"); > +static int > +nmbcheck(SYSCTL_HANDLER_ARGS) > +{ > + int error, oldnmbclusters; > + > + oldnmbclusters = nmbclusters; > + error = sysctl_handle_int(oidp, oidp->oid_arg1, oidp->oid_arg2, req); Should this be: error = sysctl_handle_int(oidp, &nmbclusters, NULL, req); > + if (error == 0 && req->newptr) { > + if (nmbclusters < oldnmbclusters) { > + nmbclusters = oldnmbclusters; > + return (EINVAL); > + } Would it be better to use a newnmbclusters variable so as to avoid frobbing the global back and forth in the event that you abort the change? If the value does change, we also don't need to call into UMA, we can just return. Robert N M Watson
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20060211233448.D71792>