From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from gate.crashing.org (gate.crashing.org [63.228.1.57]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client did not present a certificate) by ozlabs.org (Postfix) with ESMTPS id D7B19DE173 for ; Fri, 23 May 2008 00:25:21 +1000 (EST) Subject: Re: [PATCH] [POWERPC] Improve (in|out)_beXX() asm code From: Benjamin Herrenschmidt To: David Miller In-Reply-To: <20080520.155326.195407196.davem@davemloft.net> References: <4833524C.3040207@freescale.com> <20080520.153947.84346222.davem@davemloft.net> <4833542E.3040608@freescale.com> <20080520.155326.195407196.davem@davemloft.net> Content-Type: text/plain Date: Fri, 23 May 2008 00:24:43 -0400 Message-Id: <1211516683.8297.271.camel@pasglop> Mime-Version: 1.0 Cc: scottwood@freescale.com, linuxppc-dev@ozlabs.org, tpiepho@freescale.com, alan@lxorguk.ukuu.org.uk, linux-kernel@vger.kernel.org Reply-To: benh@kernel.crashing.org List-Id: Linux on PowerPC Developers Mail List List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , On Tue, 2008-05-20 at 15:53 -0700, David Miller wrote: > From: Scott Wood > Date: Tue, 20 May 2008 17:43:58 -0500 > > > David Miller wrote: > > > The __volatile__ in the asm construct disallows movement of the > > > inline asm relative to statements surrounding it. > > > > > > The only reason barrier() in kernel.h needs a memory clobber is > > > because of a bug in ancient versions of gcc. In fact, I think > > > that memory clobber might even be removable. > > > > Current versions of GCC seem quite happy to move non-asm memory accesses > > around a volatile asm without a memory clobber; see the test Trent posted. > > Indeed, and even the GCC manual is clear about this. So what is the scope of that problem ? IE. Take an x86 version of that test, writing to memory, doing a writel to some MMIO, then another memory write, can those be re-ordered with the current x86 version of writel ? static inline void writel(unsigned int b, volatile void __iomem *addr) { *(volatile unsigned int __force *)addr = b; } This is becoming a serious issue... Ben.