Skip site navigation (1)Skip section navigation (2)
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>