From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933337AbcA0Oyb (ORCPT ); Wed, 27 Jan 2016 09:54:31 -0500 Received: from bombadil.infradead.org ([198.137.202.9]:59292 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932393AbcA0Oy3 (ORCPT ); Wed, 27 Jan 2016 09:54:29 -0500 Date: Wed, 27 Jan 2016 15:54:21 +0100 From: Peter Zijlstra To: Will Deacon Cc: "Maciej W. Rozycki" , David Daney , =?iso-8859-1?Q?M=E5ns_Rullg=E5rd?= , Ralf Baechle , linux-kernel@vger.kernel.org, Paul McKenney , torvalds@linux-foundation.org, boqun.feng@gmail.com Subject: Re: [RFC][PATCH] mips: Fix arch_spin_unlock() Message-ID: <20160127145421.GT6357@twins.programming.kicks-ass.net> References: <20151112123123.GZ17308@twins.programming.kicks-ass.net> <5644D08D.4080206@caviumnetworks.com> <5644D7B5.6020009@caviumnetworks.com> <20160127114348.GF2390@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160127114348.GF2390@arm.com> User-Agent: Mutt/1.5.21 (2012-12-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jan 27, 2016 at 11:43:48AM +0000, Will Deacon wrote: > Do you know whether a SYNC 18 (RELEASE) followed in program order by a > SYNC 17 (ACQUIRE) creates a full barrier (i.e. something like SYNC 16)? > > If not, you may need to implement smp_mb__after_unlock_lock for RCU > to ensure globally transitive unlock->lock ordering should you decide > to relax your locking barriers. You know that is a tricky question. Maybe its easier if you give the 3 cpu litmus test that goes with it. Maciej, the tricky point is what, if any, effect the SYNC_RELEASE+SYNC_ACQUIRE pair has on an unrelated CPU. Please review the TRANSITIVITY section in Documentation/memory-barriers.txt and replace with the RELEASE+ACQUIRE pair. We've all (Will, Paul and me) had much 'fun' trying to decipher the MIPS64r6 manual but failed to reach a conclusion on this.