From owner-cvs-all Sun Nov 17 7:56:47 2002 Delivered-To: cvs-all@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 1BC0D37B401; Sun, 17 Nov 2002 07:56:45 -0800 (PST) Received: from mail.pcnet.com (mail.pcnet.com [204.213.232.4]) by mx1.FreeBSD.org (Postfix) with ESMTP id 7268343E4A; Sun, 17 Nov 2002 07:56:44 -0800 (PST) (envelope-from eischen@pcnet1.pcnet.com) Received: from localhost (eischen@localhost) by mail.pcnet.com (8.12.3/8.12.1) with ESMTP id gAHFuhmf024263; Sun, 17 Nov 2002 10:56:43 -0500 (EST) Date: Sun, 17 Nov 2002 10:56:43 -0500 (EST) From: Daniel Eischen To: Doug Rabson Cc: Alfred Perlstein , Marcel Moolenaar , cvs-committers@FreeBSD.org, cvs-all@FreeBSD.org Subject: Re: cvs commit: src/lib/libc_r/arch/ia64 _atomic_lock.S In-Reply-To: <200211171401.02376.dfr@nlsystems.com> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-cvs-all@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG On Sun, 17 Nov 2002, Doug Rabson wrote: > On Sunday 17 November 2002 1:13 pm, Alfred Perlstein wrote: > > * Doug Rabson [021117 02:25] wrote: > > > On Saturday 16 November 2002 7:58 pm, Marcel Moolenaar wrote: > > > > On Sat, Nov 16, 2002 at 02:13:19PM -0500, Daniel Eischen wrote: > > > > > On Sat, 16 Nov 2002, Marcel Moolenaar wrote: > > > > > > If you want me to send patches, let me know. I'm trying to > > > > > > figure out what to do now that the *context functions have > > > > > > been turned into syscalls. It complicates things... > > > > > > > > > > I'm working on converting libc_r to use *context() so don't > > > > > worry about doing it yourself. > > > > > > > > Cool! > > > > > > > > I hope to have the *context syscalls next week. I've decided to > > > > not attack the problem head on, because we don't have time to > > > > fix the infrastructure for it (we need to unwind to recreate the > > > > context). Instead, I hope to hack-up a workable solution from an > > > > ABI breaking change. The ABI breaker allows us to have > > > > lightweight syscalls, which we permanently want. So, doing that > > > > now is very attractive. The intend is to implement the *context > > > > syscalls as lightweight syscalls in a very hackish way. This > > > > serves as an experiment as well as solving an immediate problem. > > > > Let's hope it works out... > > > > > > So you intend to recognise the context calls in the syscall wrapper > > > and special-case them? This would work but it would also work for > > > heavyweight syscalls. I'm still worried about how you are going to > > > flush the user's register stack safely from kernel mode. > > > > I'm probably being dense, but doesn't the ABI specify behaviour > > such that one may not use stack space past the frame pointer > > (equivelant of ebp on i386) so this should be doable, right? > > > > Basically, as long as the frame pointer is moved before the > > space is used it's safe, right? > > This is a bit different - I'm talking about the ia64's register stack, > as distinct from its normal stack. When switching from one thread to > another, you must flush any dirty registers into the old thread's > register stack backing memory. Doing this from kernel mode can be > tricky since the pages of backing memory might not be valid yet. Just curious, how do you intend to work this into things for which the specs allow one stack? pthread_attr_setstackaddr, pthread_attr_setstacksize, makecontext, etc. Do the stacks grow in different directions so that you could use one chunk of memory with one stack starting at the top and the other at the bottom, so they would grow towards each other (perhaps with a guard page in between)? -- Dan Eischen To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe cvs-all" in the body of the message