From owner-freebsd-current Fri Mar 24 15:32:12 2000 Delivered-To: freebsd-current@freebsd.org Received: from fw.wintelcom.net (ns1.wintelcom.net [209.1.153.20]) by hub.freebsd.org (Postfix) with ESMTP id 3072E37B772 for ; Fri, 24 Mar 2000 15:32:07 -0800 (PST) (envelope-from bright@fw.wintelcom.net) Received: (from bright@localhost) by fw.wintelcom.net (8.10.0/8.10.0) id e2ONtqO01296; Fri, 24 Mar 2000 15:55:52 -0800 (PST) Date: Fri, 24 Mar 2000 15:55:52 -0800 From: Alfred Perlstein To: Matthew Dillon Cc: freebsd-current@FreeBSD.ORG Subject: Re: Preliminary SMP/BGL patch Message-ID: <20000324155552.V21029@fw.wintelcom.net> References: <200003241759.JAA14699@apollo.backplane.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Mailer: Mutt 1.0.1i In-Reply-To: <200003241759.JAA14699@apollo.backplane.com>; from dillon@apollo.backplane.com on Fri, Mar 24, 2000 at 09:59:16AM -0800 Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG * Matthew Dillon [000324 10:23] wrote: > A preliminary BGL patch is now on my site, relative to RELENG_4. > > http://www.backplane.com/FreeBSD4/ > > It is the smp-patch-03.diff item at the end of the first section. > > My test box successfully built the world. I know I'm probably missing > something, but so far I can't tell what it might be because nothing > is failing :-) > > This is considered very alpha and has been made available mainly to > endgender discussion. You know, things like "Matt, you've really gone > off the deep end this time! You cannot *DO* that to the syscall > interface!". Do it! do it! do it! :) > My primary assumption is that read access to fields in curproc plus any > structural references that are 'static'-like (e.g. like ucred) are legal > without having to hold the BGL. So getuid() can be made BGL safe > but getppid() cannot (nor can getpid() because compatibility mode also > returns the ppid). Obviously there are other fine-grained solutions. > > The biggest assumption in the patch is that doreti does not have to be > called for system calls. Being able to get rid of it for syscalls means > being able to do an end-run around doreti's extremely SMP-unsafe code. This sort of concerns me, but if I remeber correctly, unmasking spl will cause a soft intr if there are pending interupts, the only problem is that completely software initiated interupts wouldn't get processed, or would they? Can you explain how they are being scheduled/run if you remove doreti()? One alternative would be to call doreti() only in the syscalls with the MPunsafe flag set, although I'm probably missing something that makes doreti() totally unnessesary, it may be that clock interupts are covering your removal of doreti(). FYI, I was tempted to commit this with "Submitted by: dillon" and watch the fur fly, it is 5.0 after all. :) As things progress I think multi-subsystem locks expressing intent for structure manipulation would be a very cool idea, although I need to think about it more. thanks, -Alfred To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message