From owner-freebsd-arch@FreeBSD.ORG Wed Mar 26 12:58:13 2003 Return-Path: Delivered-To: freebsd-arch@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 8E2B537B404 for ; Wed, 26 Mar 2003 12:58:13 -0800 (PST) Received: from mail.pcnet.com (mail.pcnet.com [204.213.232.4]) by mx1.FreeBSD.org (Postfix) with ESMTP id B0EFF43F75 for ; Wed, 26 Mar 2003 12:58:12 -0800 (PST) (envelope-from eischen@pcnet1.pcnet.com) Received: from pcnet1.pcnet.com (localhost [127.0.0.1]) by mail.pcnet.com (8.12.8/8.12.1) with ESMTP id h2QKw4Bg023185; Wed, 26 Mar 2003 15:58:04 -0500 (EST) Received: from localhost (eischen@localhost)h2QKw3Ck023180; Wed, 26 Mar 2003 15:58:03 -0500 (EST) Date: Wed, 26 Mar 2003 15:58:03 -0500 (EST) From: Daniel Eischen To: Julian Elischer In-Reply-To: Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII X-Spam-Status: No, hits=-25.6 required=5.0 tests=AWL,EMAIL_ATTRIBUTION,IN_REP_TO,QUOTED_EMAIL_TEXT, QUOTE_TWICE_1,REPLY_WITH_QUOTES,USER_AGENT_PINE autolearn=ham version=2.50 X-Spam-Level: X-Spam-Checker-Version: SpamAssassin 2.50 (1.173-2003-02-20-exp) cc: kse@elischer.org cc: arch@freebsd.org Subject: Re: 1:1 Threading implementation. X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 26 Mar 2003 20:58:15 -0000 On Wed, 26 Mar 2003, Julian Elischer wrote: > > On Wed, 26 Mar 2003, Jeff Roberson wrote: > > > > > > i.e. on creation of a new process, shced_newproc() is called > > > and a KSE is added in there is the scheduler in question wants to use > > > KSEs. If it doesn't, no KSE would be added, but it's still possible that > > > > Yes, I think we need more sched hooks here as well. Having only > > sched_fork() makes things sort of gross. We'll have to hook this all up > > later. > > I'll try get it hooked up "sooner rather than later". > I think you can make 1:1 threads in the current system by doing: > > kse_create(mbox, NEWGROUP); where the mbox points to the function you > want to run and a new stack. The function just runs as normal, not > knowing that it is atually a UTS thread. Since it never yields to > another thread (by KSE terms) it never does any upcalls an voila.. 1:1 > threads. (I am sugesting that we don't need a new syscall to do this, > or, at most a new entrypoint which ends up calling much of the same > code.) Right. And if you translate this into the M:N library, you just create your threads with PTHREAD_SCOPE_SYSTEM. One of my unvoiced thoughts was that we could add a flag or two to the KSE mailbox so that a scope system thread doesn't need a separate stack. Once one of these KSEs (thread actually) blocks in the kernel, it stays there, BUT, it can still awake from kse_thr_interrupt, kse_release, etc, just that instead of an upcall it just returns normally from those calls. In this way, scope system threads can be very low overhead and not need to enter the UTS scheduler, yet they can still coexist with scope process threads. > Ok but htis breaks things for M:N threads as in M:N threads, teh mask > would be stored "per process" (or at most per group) and the mask is the > "logical OR" of all the masks for the threads in the group/process. > Having a mask per thread and not having one for the bigger unit > means that the masks for the threads must be updated regularly > (maybe at every kernel entry) to be the OR of the masks for ALL THE USER > THREADS, which means that the UTS must do this explicitly. > I'm not thrilled by all the extra work this is going to make for M:N > threads. (Well at least this is my preliminary reading of it.) No, please don't make the UTS deal with this, if that's the case. > > > > First off, it is many months away from being even beta quality. I think > > the UTS is far more complicated than you may realize. There are all sorts > > of synchronization issues that it was able to avoid before since only one > > thread could run at any time and there essentially was no preemption. It > > now also has to deal with effecient scheduling decisions in a M:N model > > that it didn't have to worry about before. > > I'm not sure that teh issues there are as bad as you think. I don't think it is as bad as that either. The complexity is on par with that of libc_r. > > > > Then if you look at the number of system calls and shenanigans a UTS must > > do to make proper scheduling decisions it doesn't look like such an > > advantage. I feel that the overhead of all the layers comes close to the > > savings from doing some of it without entering the kernel. > > So far it's not doing that much.. Yeah, I don't understand the above statement either. It's lower overhead than libc_r. The only system calls it should be making is to kse_release() when it has no more work to do (no runnable threads) or possibly to kse_thr_wakeup() if it has to dispatch signals to threads blocked in the kernel. Time comes from the mailbox so we don't even need to get the time of day. The interfaces were designed so that we _wouldn't_ have much syscall overhead. -- Dan Eischen