Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964925AbbBDMGa (ORCPT ); Wed, 4 Feb 2015 07:06:30 -0500 Received: from casper.infradead.org ([85.118.1.10]:42402 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752997AbbBDMG3 (ORCPT ); Wed, 4 Feb 2015 07:06:29 -0500 Date: Wed, 4 Feb 2015 13:06:21 +0100 From: Peter Zijlstra To: Tim Chen Cc: Jason Low , Davidlohr Bueso , Ingo Molnar , "Paul E. McKenney" , Michel Lespinasse , linux-kernel@vger.kernel.org Subject: Re: [PATCH 4/5] locking/rwsem: Avoid deceiving lock spinners Message-ID: <20150204120621.GH23123@twins.programming.kicks-ass.net> References: <1422609267-15102-1-git-send-email-dave@stgolabs.net> <1422609267-15102-5-git-send-email-dave@stgolabs.net> <1422669098.9530.33.camel@schen9-desk2.jf.intel.com> <1422671289.28351.1.camel@stgolabs.net> <1422983812.9530.43.camel@schen9-desk2.jf.intel.com> <1422986041.2368.3.camel@j-VirtualBox> <1422992616.9530.78.camel@schen9-desk2.jf.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1422992616.9530.78.camel@schen9-desk2.jf.intel.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 Content-Length: 1246 Lines: 28 On Tue, Feb 03, 2015 at 11:43:36AM -0800, Tim Chen wrote: > That's true. We cannot have the lock grabbed by a new write > contender as any new writer contender of the lock will be > queued by the OSQ logic. Only the > thread doing the optimistic spin is attempting write lock. > In other word, switching of write owner of the rwsem to a new > owner cannot happen. Either write owner stay as the original one, or > we don't have a write owner. So using test of write owner > switching as an indicator of congestion is incorrect. > > If my reasoning above is sound, then the check > > + if (READ_ONCE(sem->owner)) > + return true; /* new owner, continue spinning */ > + > > is unnecessary and can be removed, as we cannot have a > new write owner of the rwsem, other than the thread > doing optimistic spinning. I have read the rest of the thread; but the one thing that I didn't see is trylocks, trylocks can always come in an steal things regardless of the OSQ stuff. -- 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/