Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1761224AbWLHWeI (ORCPT ); Fri, 8 Dec 2006 17:34:08 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1761226AbWLHWeI (ORCPT ); Fri, 8 Dec 2006 17:34:08 -0500 Received: from smtp101.mail.mud.yahoo.com ([209.191.85.211]:25254 "HELO smtp101.mail.mud.yahoo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1761224AbWLHWeF (ORCPT ); Fri, 8 Dec 2006 17:34:05 -0500 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=s1024; d=yahoo.com.au; h=Received:X-YMail-OSG:Message-ID:Date:From:User-Agent:X-Accept-Language:MIME-Version:To:CC:Subject:References:In-Reply-To:Content-Type:Content-Transfer-Encoding; b=ldBN5un5ZQy2p9YthG2szoIR3FB4REp5MUuNc4h9bIEy+dGT3l/a7K5AcBfU2D89MFpHgYUNfk0hOTL5AkYyqc0x4KU7NQbntqpAJxj8jL0FJ0jyfvEuK8gR7/ko6J+K9bkS9oINBOR8R9S8pBHuOD/X+S3BbPsjZUb1t5F11vY= ; X-YMail-OSG: X6atAB0VM1kHO_ofIF2g7VMo9eU1G61I33QzNqiFDDiaBZ.cw10MBFgwzMp3rMmiRbRSZz6RreUVEIfEkTGYW9RD25AsG3727xVLAMAltR0bUrvKnDlL_4_Su6MkU82TUbVUSWhMGuCdm3I- Message-ID: <4579E826.80406@yahoo.com.au> Date: Sat, 09 Dec 2006 09:33:10 +1100 From: Nick Piggin User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.7.12) Gecko/20051007 Debian/1.7.12-1 X-Accept-Language: en MIME-Version: 1.0 To: Russell King CC: Christoph Lameter , David Howells , torvalds@osdl.org, akpm@osdl.org, linux-arm-kernel@lists.arm.linux.org.uk, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org Subject: Re: [PATCH] WorkStruct: Implement generic UP cmpxchg() where an arch doesn't support it References: <20061206164314.19870.33519.stgit@warthog.cambridge.redhat.com> <20061206190025.GC9959@flint.arm.linux.org.uk> <20061206195820.GA15281@flint.arm.linux.org.uk> <4577DF5C.5070701@yahoo.com.au> <20061207150303.GB1255@flint.arm.linux.org.uk> <4578BD7C.4050703@yahoo.com.au> <20061208085634.GA25751@flint.arm.linux.org.uk> In-Reply-To: <20061208085634.GA25751@flint.arm.linux.org.uk> Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2401 Lines: 68 Russell King wrote: > On Fri, Dec 08, 2006 at 12:18:52PM +1100, Nick Piggin wrote: > >>Russell King wrote: >> >>>On Thu, Dec 07, 2006 at 08:31:08PM +1100, Nick Piggin wrote: >> >>>>>Implementing ll/sc based accessor macros allows both ll/sc _and_ cmpxchg >>>>>architectures to produce optimal code. >>>>> >>>>>Implementing an cmpxchg based accessor macro allows cmpxchg architectures >>>>>to produce optimal code and ll/sc non-optimal code. >>>>> >>>>>See my point? >>>> >>>>Wrong. Your ll/sc implementation with cmpxchg is buggy. The cmpxchg >>>>load_locked is not locked at all, >>> >>> >>>Intentional - cmpxchg architectures don't generally have a load locked. >> >>Exactly, so it is wrong -- you can't implement that behaviour with >>load + cmpxchg. > > > I disagree. I _have_ implemented the required behaviour. I really > don't understand your point saying that it is wrong. > > >>>>and there can be interleaving writes >>>>between the load and cmpxchg which do not cause the store_conditional >>>>to fail. >>> >>> >>>In which case the cmpxchg fails and we do the atomic operation again, >>>in exactly the same way that we do the operation again if the 'sc' >>>fails in the ll/sc case. >> >>Not if cmpxchg sees the same value, it won't fail, regardless of how >>many writes have hit that memory address. > > > Don't see anything wrong with that. If that was a problem, atomic > implementations using cmpxchg on x86 would be impossible. > > I think you're trying to implement ll/sc semantics on CPUs without > ll/sc which is exactly not what I'm trying to do. I'd argue that's > impossible. Yes, I did think that from reading your emails. It is not a problem as such, but it is important to be clear on semantics. > I'm trying to suggest a better implementation for atomic ops rather > than just bowing to this x86-centric "cmpxchg is the best, everyone > must implement it" mentality. Even if ARM is able to handle any arbitrary C code between the "load locked" and store conditional API, other architectures can not by definition. -- SUSE Labs, Novell Inc. Send instant messages to your online friends http://au.messenger.yahoo.com - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/