From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-pa0-f47.google.com (mail-pa0-f47.google.com [209.85.220.47]) by kanga.kvack.org (Postfix) with ESMTP id 9631B6B0031 for ; Wed, 20 Nov 2013 07:50:32 -0500 (EST) Received: by mail-pa0-f47.google.com with SMTP id kq14so5311055pab.6 for ; Wed, 20 Nov 2013 04:50:32 -0800 (PST) Received: from psmtp.com ([74.125.245.183]) by mx.google.com with SMTP id ot3si3859434pac.50.2013.11.20.04.50.30 for ; Wed, 20 Nov 2013 04:50:31 -0800 (PST) Received: from /spool/local by e38.co.us.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Wed, 20 Nov 2013 05:50:29 -0700 Received: from b03cxnp08027.gho.boulder.ibm.com (b03cxnp08027.gho.boulder.ibm.com [9.17.130.19]) by d03dlp01.boulder.ibm.com (Postfix) with ESMTP id 7AA2F1FF001B for ; Wed, 20 Nov 2013 05:50:09 -0700 (MST) Received: from d03av06.boulder.ibm.com (d03av06.boulder.ibm.com [9.17.195.245]) by b03cxnp08027.gho.boulder.ibm.com (8.13.8/8.13.8/NCO v10.0) with ESMTP id rAKAmeke26804378 for ; Wed, 20 Nov 2013 11:48:40 +0100 Received: from d03av06.boulder.ibm.com (loopback [127.0.0.1]) by d03av06.boulder.ibm.com (8.14.4/8.13.1/NCO v10.0 AVout) with ESMTP id rAKCrJWt030293 for ; Wed, 20 Nov 2013 05:53:21 -0700 Date: Wed, 20 Nov 2013 04:50:23 -0800 From: "Paul E. McKenney" Subject: Re: [PATCH v6 0/5] MCS Lock: MCS lock code cleanup and optimizations Message-ID: <20131120125023.GC4138@linux.vnet.ibm.com> Reply-To: paulmck@linux.vnet.ibm.com References: <1384911446.11046.450.camel@schen9-DESK> <20131120101957.GA19352@mudshark.cambridge.arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20131120101957.GA19352@mudshark.cambridge.arm.com> Sender: owner-linux-mm@kvack.org List-ID: To: Will Deacon Cc: Tim Chen , Ingo Molnar , Andrew Morton , Thomas Gleixner , "linux-kernel@vger.kernel.org" , linux-mm , "linux-arch@vger.kernel.org" , Linus Torvalds , Waiman Long , Andrea Arcangeli , Alex Shi , Andi Kleen , Michel Lespinasse , Davidlohr Bueso , Matthew R Wilcox , Dave Hansen , Peter Zijlstra , Rik van Riel , Peter Hurley , Raghavendra K T , George Spelvin , "H. Peter Anvin" , Arnd Bergmann , Aswin Chandramouleeswaran , Scott J Norton , "Figo.zhang" On Wed, Nov 20, 2013 at 10:19:57AM +0000, Will Deacon wrote: > Hi Tim, > > On Wed, Nov 20, 2013 at 01:37:26AM +0000, Tim Chen wrote: > > In this patch series, we separated out the MCS lock code which was > > previously embedded in the mutex.c. This allows for easier reuse of > > MCS lock in other places like rwsem and qrwlock. We also did some micro > > optimizations and barrier cleanup. > > > > The original code has potential leaks between critical sections, which > > was not a problem when MCS was embedded within the mutex but needs > > to be corrected when allowing the MCS lock to be used by itself for > > other locking purposes. > > > > Proper barriers are now embedded with the usage of smp_load_acquire() in > > mcs_spin_lock() and smp_store_release() in mcs_spin_unlock. See > > http://marc.info/?l=linux-arch&m=138386254111507 for info on the > > new smp_load_acquire() and smp_store_release() functions. > > > > This patches were previously part of the rwsem optimization patch series > > but now we spearate them out. > > > > We have also added hooks to allow for architecture specific > > implementation of the mcs_spin_lock and mcs_spin_unlock functions. > > > > Will, do you want to take a crack at adding implementation for ARM > > with wfe instruction? > > Sure, I'll have a go this week. Thanks for keeping that as a consideration! > > As an aside: what are you using to test this code, so that I can make sure I > don't break it? +1 to that! In fact, it would be nice to have the test code in-tree, especially if it can test a wide variety of locks. (/me needs to look at what test code for locks might already be in tree, for that matter...) Thanx, Paul -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org