From owner-freebsd-alpha@FreeBSD.ORG Thu Aug 7 07:41:40 2003 Return-Path: Delivered-To: freebsd-alpha@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 963EA37B401; Thu, 7 Aug 2003 07:41:40 -0700 (PDT) Received: from mail.pcnet.com (mail.pcnet.com [204.213.232.4]) by mx1.FreeBSD.org (Postfix) with ESMTP id E901D43FB1; Thu, 7 Aug 2003 07:41:39 -0700 (PDT) (envelope-from eischen@vigrid.com) Received: from mail.pcnet.com (mail.pcnet.com [204.213.232.4]) by mail.pcnet.com (8.12.8/8.12.1) with ESMTP id h77EfYuN012573; Thu, 7 Aug 2003 10:41:34 -0400 (EDT) Date: Thu, 7 Aug 2003 10:41:34 -0400 (EDT) From: Daniel Eischen X-Sender: eischen@pcnet5.pcnet.com To: Andrew Gallatin In-Reply-To: <16178.25370.731486.809755@grasshopper.cs.duke.edu> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII cc: deischen@freebsd.org cc: alpha@freebsd.org Subject: Re: Atomic swap X-BeenThere: freebsd-alpha@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list Reply-To: deischen@freebsd.org List-Id: Porting FreeBSD to the Alpha List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 07 Aug 2003 14:41:41 -0000 On Thu, 7 Aug 2003, Andrew Gallatin wrote: > > Daniel Eischen writes: > > [ I'm not subscribed to alpha@; please keep me on the CC ] > > > > I need an atomic swap function for libpthread. Here's my hack > > of an implementation: > > > > /* > > * Atomic swap: > > * Atomic (tmp = *dst, *dst = val), then *res = tmp > > * > > * void atomic_swap_long(long *dst, long val, long *res); > > */ > > static __inline > > void atomic_swap_long(volatile long *dst, long val, long *res) > > { > > u_int64_t result; > > > > __asm __volatile ( > > "1:\tldq_l %0,%1\n\t" > > "stq_c %2,%1\n\t" > > "beq %2,2f\n\t" /* Why is this beq instead of bne 1b? */ > > "br 3f\n" > > "2:\tbr 1b\n" > > "3:\n" > > : "=&r" (result) > > : "m" (*dst), "r" (val) > > : "memory"); > > > > *res = result; > > } > > > > As annotated above, there seems to be one more branch than > > necessary. > > Its actually an optimization. Alphas predict that backward branches > will always be taken (think loops). If you were to branch directly > back to 1:, then if the store succeeds (which it nearly always > should), then the cpu would have been betting on taking the branch, > and that would slow things down. OK. > > > Can someone look this over for me? I really don't quite > > know what I'm doing when it comes to inline assembly. > > I think it looks OK, but I'm also terrible at inline asm. Yeah, me too. It took me quite a few tries to hit upon something that seemed to work. -- Dan Eischen