From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754650Ab2CFPhs (ORCPT ); Tue, 6 Mar 2012 10:37:48 -0500 Received: from mail.solarflare.com ([216.237.3.220]:33885 "EHLO ocex02.SolarFlarecom.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1752862Ab2CFPhq (ORCPT ); Tue, 6 Mar 2012 10:37:46 -0500 Message-ID: <1331048257.2333.4.camel@bwh-desktop> Subject: Re: [PATCH v4] lpc32xx: Added ethernet driver: smp_wmb() From: Ben Hutchings To: Russell King - ARM Linux CC: Roland Stigge , , , , , , , , , , , , , Date: Tue, 6 Mar 2012 15:37:37 +0000 In-Reply-To: <20120306141745.GA15201@n2100.arm.linux.org.uk> References: <1330983641-32622-1-git-send-email-stigge@antcom.de> <1330987524.2538.61.camel@bwh-desktop> <4F55EA6D.3070602@antcom.de> <1331042608.2347.1.camel@bwh-desktop> <20120306141745.GA15201@n2100.arm.linux.org.uk> Organization: Solarflare Communications Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.3 (3.2.3-1.fc16) Content-Transfer-Encoding: 7bit MIME-Version: 1.0 X-Originating-IP: [10.17.20.137] X-TM-AS-Product-Ver: SMEX-10.0.0.1412-6.800.1017-18756.003 X-TM-AS-Result: No--15.459900-0.000000-31 X-TM-AS-User-Approved-Sender: Yes X-TM-AS-User-Blocked-Sender: No Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2012-03-06 at 14:17 +0000, Russell King - ARM Linux wrote: > On Tue, Mar 06, 2012 at 02:03:28PM +0000, Ben Hutchings wrote: > > On Tue, 2012-03-06 at 11:43 +0100, Roland Stigge wrote: > > > On 03/05/2012 11:45 PM, Ben Hutchings wrote: > > > >> + /* Clear and enable interrupts */ > > > >> + writel(0xFFFF, LPC_ENET_INTCLEAR(pldat->net_base)); > > > >> + lpc_eth_enable_int(pldat->net_base); > > > >> + > > > >> + /* Get the next TX buffer output index */ > > > >> + pldat->num_used_tx_buffs = 0; > > > >> + pldat->last_tx_idx = > > > >> + readl(LPC_ENET_TXCONSUMEINDEX(pldat->net_base)); > > > > > > > > Doesn't this need to be done *before* enabling interrupts? Also, I > > > > think you need an smp_wmb() so that the interrupt handler is guaranteed > > > > to see all these writes. > > > > > > Do you mean _one_ smp_wmb() directly after lpc_eth_enable_int() (which > > > I'm moving behind the above code? > > > > The sequence should be > > > > pldat->state = values...; > > smp_wmb(); > > enable_interrupts(); > > Is this correct? > > "SMP BARRIER PAIRING" and "EXAMPLES OF MEMORY BARRIER SEQUENCES" in > Documentation/memory-barriers.txt suggest that there should be some kind > of pairing with smp_wmb() to ensure correctness. The thread we're synchronising with (the interrupt handler) starts *after* the smp_wmb(). Therefore there is no need for a second barrier. Ben. -- Ben Hutchings, Staff Engineer, Solarflare Not speaking for my employer; that's the marketing department's job. They asked us to note that Solarflare product names are trademarked.