From owner-freebsd-arch@FreeBSD.ORG Wed May 30 03:07:23 2007 Return-Path: X-Original-To: freebsd-arch@freebsd.org Delivered-To: freebsd-arch@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id DCFC616A421; Wed, 30 May 2007 03:07:23 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from mail24.syd.optusnet.com.au (mail24.syd.optusnet.com.au [211.29.133.165]) by mx1.freebsd.org (Postfix) with ESMTP id 7BE8913C43E; Wed, 30 May 2007 03:07:23 +0000 (UTC) (envelope-from brde@optusnet.com.au) Received: from besplex.bde.org (c211-30-225-63.carlnfd3.nsw.optusnet.com.au [211.30.225.63]) by mail24.syd.optusnet.com.au (8.13.1/8.13.1) with ESMTP id l4U379d0023367 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Wed, 30 May 2007 13:07:12 +1000 Date: Wed, 30 May 2007 13:07:10 +1000 (EST) From: Bruce Evans X-X-Sender: bde@besplex.bde.org To: Jeff Roberson In-Reply-To: <20070529141342.D661@10.0.0.1> Message-ID: <20070530125553.G12128@besplex.bde.org> References: <20070529105856.L661@10.0.0.1> <200705291456.38515.jhb@freebsd.org> <20070529121653.P661@10.0.0.1> <20070530065423.H93410@delplex.bde.org> <20070529141342.D661@10.0.0.1> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: freebsd-arch@freebsd.org Subject: Re: rusage breakdown and cpu limits. X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 30 May 2007 03:07:23 -0000 On Tue, 29 May 2007, Jeff Roberson wrote: > On Wed, 30 May 2007, Bruce Evans wrote: > >> On Tue, 29 May 2007, Jeff Roberson wrote: >>> a few cases where which will be complicated, and cpulimit is one of them. >> >> No, cpulimit is simple because it can be fuzzy, unlike calcru() which >> require >> the rusage to be up to date. > > cpulimit is complicated because it requires aggregate statistics from all > threads like rusage. It may be queried infrequently however. It's just one > of the few cases where we actually examine the values as if we still only > have one thread per process. It still doesn't need very accurate statistics, unlike the others. However, as you point out, almost all of the other cases are already more aware of multiple threads and heavyweight to handle it (e.g., calcru() already had a related accumulation loop until it was broken). cpulimit is complicated and/or different because it shouldn't do heavyweight accumulation. >> I see how rusage accumulation can help for everything _except_ the >> runtime and tick counts (i.e., for stuff updated by statclock()). For >> the runtime and tick counts, the possible savings seem to be small and >> negative. calcru() would have to run the accumulation code and the >> accumulation code would have to acquire something like sched_lock to >> transfer the per-thread data (since the lock for updating that data >> is something like sched_lock). This is has the same locking overheads >> and larger non-locking overheads than accumulating the runtime directly >> into the rusage at context switch time -- calcru() needs to acquire >> something like sched_lock either way. > > Yes, it will make calcru() more expensive. However, this should be > infrequent relative to context switches. It's only used for calls to > getrusage(), fill_kinfo_proc(), and certain clock_gettime() calls. > > The thing that will protect mi_switch() is not process global. I want to > keep process global locks out of mi_switch() or we reduce concurrency for > multi-threaded applications. This became clearer with patches and would have been clearer with (smaller) diffs in mail -- mi_switch() still needs locking but it isn't sched locking. Bruce