From owner-freebsd-hackers Wed Aug 19 17:20:12 1998 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id RAA07092 for freebsd-hackers-outgoing; Wed, 19 Aug 1998 17:20:12 -0700 (PDT) (envelope-from owner-freebsd-hackers@FreeBSD.ORG) Received: from smtp01.primenet.com (smtp01.primenet.com [206.165.6.131]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id RAA06989 for ; Wed, 19 Aug 1998 17:20:06 -0700 (PDT) (envelope-from tlambert@usr05.primenet.com) Received: (from daemon@localhost) by smtp01.primenet.com (8.8.8/8.8.8) id RAA29157; Wed, 19 Aug 1998 17:19:27 -0700 (MST) Received: from usr05.primenet.com(206.165.6.205) via SMTP by smtp01.primenet.com, id smtpd029125; Wed Aug 19 17:19:20 1998 Received: (from tlambert@localhost) by usr05.primenet.com (8.8.5/8.8.5) id RAA29165; Wed, 19 Aug 1998 17:19:17 -0700 (MST) From: Terry Lambert Message-Id: <199808200019.RAA29165@usr05.primenet.com> Subject: Re: sfork()? To: rminnich@Sarnoff.COM (Ron G. Minnich) Date: Thu, 20 Aug 1998 00:19:17 +0000 (GMT) Cc: hackers@FreeBSD.ORG In-Reply-To: from "Ron G. Minnich" at Aug 19, 98 12:57:22 pm X-Mailer: ELM [version 2.4 PL25] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG > > yes, evil evil evil man pages. :) > > and, actually John Dyson told me about rfork, i thought it was "fixed" > > though. > > OK, now I am lost. I just looked at -current kernel source and see that > freebsd rfork does not split the stack. What's funny is my old ca. 1994 > rfork for freebsd does split the stack. In fact I now wonder if my design > was not somewhat nicer, since it does split the stack and requires no > user-land assembly code. I'm still running 16 nodes with that old OS and > old rfork and I'm going to not have fun upgrading them with -current > rfork ... > > now what? How did you split the stack? Did you put it in thread local storage? Did you limit the size it could grow to? Either would be bad... The code Loqui posted has a problem: there are no guard pages on the stack. The correct approach is probably to mmap() anonymous pages from /dev/zero instead to ensure that there are guard pages, and to install a SIGSEGV handler and leave a large enough gap that you can auto-grow the stack in the trap handler using a "pager" thread (or doing it in the handler, which I dislike). The problem with a split stack that is not based on heap memory allocation and/or non-anonymous mappings and/or a copied rather than shared page table is kernel threads. When I instance objects which I want to hand over to another thread, I should not have to copy the object between threads. The need to copy the object (via CreateFreeThreadedMarshaller(WIN32)) between threads in NT and Windows 95 was one of the biggest design blunders in Microsoft history, IMO. John's design avoids this, but has the unfortunate problem that the stack management is left up to user space. If I understand the shared page map correctly, mapping pages into one thread should map them into all threads; this should be sufficient for sbrk() and growable stacks (instead of the default 8k stacks pthreads tries to stick you with). The key here is what happens in an rfork() child when memory is mapped into the parent address space; if it does not immediately become available in the child address space, then you have repeated Microsoft's blunder. Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message