From owner-freebsd-current Tue Apr 8 18:30:45 1997 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id SAA17401 for current-outgoing; Tue, 8 Apr 1997 18:30:45 -0700 (PDT) Received: from parkplace.cet.co.jp (parkplace.cet.co.jp [202.32.64.1]) by freefall.freebsd.org (8.8.5/8.8.5) with ESMTP id SAA17367; Tue, 8 Apr 1997 18:30:40 -0700 (PDT) Received: from localhost (michaelh@localhost) by parkplace.cet.co.jp (8.8.5/CET-v2.1) with SMTP id BAA15672; Wed, 9 Apr 1997 01:30:32 GMT Date: Wed, 9 Apr 1997 10:30:32 +0900 (JST) From: Michael Hancock To: Terry Lambert cc: current@FreeBSD.ORG, freebsd-fs@FreeBSD.ORG Subject: Re: DISCUSS: vnode references as open instances In-Reply-To: Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-current@FreeBSD.ORG X-Loop: FreeBSD.org Precedence: bulk On Tue, 8 Apr 1997, Michael Hancock wrote: > > Though vnodes are currently globally accounted, I beleive that > > there should be a per FS interface, initially to the global > > accounting interface, for freeing vnodes in an FS specific > > manner. > > > > The eventual intent of this change is to allow per-FS management > > of vnodes as part of the FS's [*,i]node pool, and to therefore > > relieve the need for global vnode pool management, and thus global > > recovery of vnodes for reuse. > > > > One large benefit of this technique would be to allow the recovery > > of unreferenced vnodes from per FS "second chance" caches, like > > the FFS "ihash" facility, and therfore the recovery of perfectly > > valid memory pages that refere to a referenced per FS object. > > > > Currently, there is no recovery mechanism whereby the valid pages > > can be re-referenced for use once the vnode had been disassociated > > from the per-FS object, but not from the valid pages. > > > > When a reference which references these pages occurs, the data, > > though in core, cannot be reclaimed, and must be reread from > > disk. 1) Create a directory /sys/u2fs. 2) Build the necessary scaffolding, VT_U2FS, vop scripts, etc. and do the VT_TFS thing. 3) Submit updates to the /sys/u2fs directory in parcels as big as you want. 4) If your analysis is accurate, and you correctly design and implement the changes then most applications will show a significant performance improvement. 5) Get Matt Dillon, Joe Greco, and Karl to "beat the snot" out your new improved ufs and get them to make testimonials. 6) Then work on converting the VT_TFS, VT_U2FS special case the general case. Regards, Mike Hancock