From owner-freebsd-current Thu Apr 3 16:00:12 1997 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id QAA27866 for current-outgoing; Thu, 3 Apr 1997 16:00:12 -0800 (PST) Received: from phaeton.artisoft.com (phaeton.Artisoft.COM [198.17.250.50]) by freefall.freebsd.org (8.8.5/8.8.5) with SMTP id QAA27858 for ; Thu, 3 Apr 1997 16:00:06 -0800 (PST) Received: (from terry@localhost) by phaeton.artisoft.com (8.6.11/8.6.9) id QAA17773 for current@freebsd.org; Thu, 3 Apr 1997 16:43:22 -0700 From: Terry Lambert Message-Id: <199704032343.QAA17773@phaeton.artisoft.com> Subject: DISCUSS: vnode references as open instances To: current@freebsd.org Date: Thu, 3 Apr 1997 16:43:21 -0700 (MST) X-Mailer: ELM [version 2.4 PL24] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-current@freebsd.org X-Loop: FreeBSD.org Precedence: bulk I am looking for discussion, pro and con. ----------------------------------------------------------------------------- I believe that vnode references should be treated as counting semaphores. Currently, reference holders are net required to count references in all cases. The purpose of this change would be to significantly clean up the vnode reference interactions to provide a meaningful seperation between vnode maintenance and vnode reclamation, with the eventual intention of removing the need for vclean() and the duplication of code in each per FS VOP_LOCK implementation. This change would affect the directory name lookup cache code (for which a vnode reference in a cache would be very much the same as an open instance for a vnode reference by a system open file table reference), as well as several other subsystems. 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. This would be similar in scope to the SVR4 vnode management scheme, as described in "The Magic Garden Explained" and the _Bach_ book. 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. ----------------------------------------------------------------------------- Regards, Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers.