From owner-cvs-src@FreeBSD.ORG Mon Jul 7 21:57:37 2003 Return-Path: Delivered-To: cvs-src@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id D7EFF37B401; Mon, 7 Jul 2003 21:57:37 -0700 (PDT) Received: from gw.catspoiler.org (217-ip-163.nccn.net [209.79.217.163]) by mx1.FreeBSD.org (Postfix) with ESMTP id F0BF143FB1; Mon, 7 Jul 2003 21:57:36 -0700 (PDT) (envelope-from truckman@FreeBSD.org) Received: from FreeBSD.org (mousie.catspoiler.org [192.168.101.2]) by gw.catspoiler.org (8.12.9/8.12.9) with ESMTP id h684vRM7009343; Mon, 7 Jul 2003 21:57:31 -0700 (PDT) (envelope-from truckman@FreeBSD.org) Message-Id: <200307080457.h684vRM7009343@gw.catspoiler.org> Date: Mon, 7 Jul 2003 21:57:27 -0700 (PDT) From: Don Lewis To: silby@FreeBSD.org In-Reply-To: <200307080402.h6842VtT064702@repoman.freebsd.org> MIME-Version: 1.0 Content-Type: TEXT/plain; charset=us-ascii cc: cvs-src@FreeBSD.org cc: src-committers@FreeBSD.org cc: cvs-all@FreeBSD.org Subject: Re: cvs commit: src/sys/kern subr_param.c sys_pipe.c src/sys/sys pipe.h X-BeenThere: cvs-src@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: CVS commit messages for the src tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 08 Jul 2003 04:57:38 -0000 On 7 Jul, Mike Silbersack wrote: > silby 2003/07/07 21:02:31 PDT > > FreeBSD src repository > > Modified files: > sys/kern subr_param.c sys_pipe.c > sys/sys pipe.h > Log: > Put some concrete limits on pipe memory consumption: > > - Limit the total number of pipes so that we do not > exhaust all vm objects in the kernel map. When > this limit is reached, a ratelimited message will > be printed to the console. > > - Put a soft limit on the amount of memory consumable > by pipes. Once the limit has been reached, all new > pipes will be limited to 4K in size, rather than the > default of 16K. > > - Put a limit on the number of pages that may be used > for high speed page flipping in order to reduce the > amount of wired memory. Pipe writes that occur > while this limit is exceeded will fall back to > non-page flipping mode. > > The above values are auto-tuned in subr_param.c and > are scaled to take into account both the size of > physical memory and the size of the kernel map. > > These limits help to reduce the "kernel resources exhausted" > panics that could be caused by opening a large > number of pipes. (Pipes alone are no longer able > to exhaust all resources, but other kernel memory hogs > in league with pipes may still be able to do so.) There should probably be a per-user limit(s) as well. At a minimum, the number of pipes per user should be limited. The limit should be stored in struct plimit, and the current usage should be tracked in struct uidinfo.