From owner-freebsd-smp Mon Jun 28 21:26:34 1999 Delivered-To: freebsd-smp@freebsd.org Received: from apollo.backplane.com (apollo.backplane.com [209.157.86.2]) by hub.freebsd.org (Postfix) with ESMTP id 9B2F0151AE for ; Mon, 28 Jun 1999 21:26:31 -0700 (PDT) (envelope-from dillon@apollo.backplane.com) Received: (from dillon@localhost) by apollo.backplane.com (8.9.3/8.9.1) id VAA26171; Mon, 28 Jun 1999 21:26:28 -0700 (PDT) (envelope-from dillon) Date: Mon, 28 Jun 1999 21:26:28 -0700 (PDT) From: Matthew Dillon Message-Id: <199906290426.VAA26171@apollo.backplane.com> To: Terry Lambert Cc: freebsd-smp@FreeBSD.ORG Subject: Re: high-efficiency SMP locks - submission for review References: <199906290116.SAA08367@usr05.primenet.com> Sender: owner-freebsd-smp@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.org I think we are ultimately going to stick to the recursive-shared/ recursive-exclusive model for most of our buffer and VFS/BIO locking. This isn't set in stone, but it turns out that if we can turn the exclusive locks used for I/O ops into shared locks, we can get rid of nearly all the access blocking conditions. With exclusive locks relegated to non-blocking critical-path code (e.g. setting up for a write I/O, but not held during the actual write I/O), most of the parallelization and interlock problems magically go away which I think is really cool. There would then be no need for a more sophisticated (and more complex) intention locks, no need to manage locking chains for deadlock detection, and so forth. I think intention locks can still be used in places where the structural complexity warrants it... like vnode operations, for example. The only part of a vnode that the VM system really cares about is the vnode's file size, so that would be one intention lock. inode updates would be another intention lock, synchronization would be another, and create/destroy would be a another. -Matt To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-smp" in the body of the message