Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp38926imm; Thu, 30 Aug 2018 13:47:44 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaqZmKG5MKoePlhDjhow/Rejpt1b0T7Q1bZfnvTJNd5vl6nUTVSIZElZ9I9n5Gq0nAJJT7c X-Received: by 2002:a63:9751:: with SMTP id d17-v6mr11523730pgo.386.1535662064832; Thu, 30 Aug 2018 13:47:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535662064; cv=none; d=google.com; s=arc-20160816; b=v/HLQ9MPmFzHjesvk3d/tD9jDxa1lSdHqEIDcnSH4mZPnjW+QLOIDzR6ZABD1tyoX0 jRFRCEgWvtMDGuUQvJBZjsRznrl+YqgbvXzA71x2iyWGHk/qmt/WzDa6vdmdYroWy6IP jKtgelvEvvKGbG8uZ5CNd8u5WExtGZbyOmkMzLu5SgdTnS8uTTeex0jEvL+xYaCmdzyw fDxTYksGbZX61DUxyYVDLlhgwFmNyHpxm/BsFta0YpZ9zVkUSgJAxhb/AL7fVG9r59CB awrIyE61EXDXiejYhVJdfdeI2GcHB891BfH2h0x/Epj4zb66hraLs2OMBwzgFHL9gAMO nwHA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=Cjky/mM1tjSK/MV1yu9uHtt6HigDi4I+7M1zq65dyMg=; b=oYMQxf5MDyNKX13CaMHFK1paWHxf7zSH110u6TvelM5QZ8ihTb0xldX3odKXtO0Mlk k0+6xE05jePjEsETSQm8Tmhc+dafsB+Y/7hTRBenoqLFqGZlQ6ZqlS3UHOGiK0kAF91c XeIMd54ItRiWW7f2H4KB+sFZoNswj9DcxOBexDUcEzJj7+aCHYw9jmmvmCk/7ewZaeUX 2ysd1kc+HOCwdgKw+gdPwwUHU+wve9jFhbMd42TBxPy4xXALb66Fm6Ggka2A7Kk33G9r 774wzI0AXgrNpLGu73j4g77KYWlSqsMKG4edSJ4i38wRAMniaVUjcdzIbrNoWs69uxOz jC+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=CRAIUUrW; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v129-v6si8096027pfv.278.2018.08.30.13.47.29; Thu, 30 Aug 2018 13:47:44 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=CRAIUUrW; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727458AbeHaAtW (ORCPT + 99 others); Thu, 30 Aug 2018 20:49:22 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:33554 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725893AbeHaAtW (ORCPT ); Thu, 30 Aug 2018 20:49:22 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=In-Reply-To:Content-Type:MIME-Version :References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=Cjky/mM1tjSK/MV1yu9uHtt6HigDi4I+7M1zq65dyMg=; b=CRAIUUrWqXf+NZL/BkReCCWUQ jkClMthPDm9mrWlk/LUh/aYKf0xhGtiQlL940iS9VDtI7aymZffu/QolYEfild8n9mGxIjuxh9cZe Vu2GFwYSGZDPXjDmrw3/Y/WV+6K0Bws9zHPlMU5DwBj81rlsAM66/28Udhp83aFuaJTZBAleF+ZEI n+EXKi+fiOVxXkZH/MsVzC+mgQa+OLjFmzKfDuIPwIgqfUOkR+CO/m/6Ojgj0dmKyDSVvfok06iOR qC9KRz+sGrQn0uEmkvUjZf9hJcOtX2QPRQ/d7OqUMUOc2vXrQVuI2AC+GWtrEz3Xh4YjCin8uOz/3 pbzpmN6Lw==; Received: from j217100.upc-j.chello.nl ([24.132.217.100] helo=hirez.programming.kicks-ass.net) by bombadil.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1fvTob-0007Ym-Bn; Thu, 30 Aug 2018 20:45:17 +0000 Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id AF59820255987; Thu, 30 Aug 2018 22:45:15 +0200 (CEST) Date: Thu, 30 Aug 2018 22:45:15 +0200 From: Peter Zijlstra To: Vineet Gupta Cc: Will Deacon , Eugeniy Paltsev , "mingo@kernel.org" , "linux-kernel@vger.kernel.org" , "Alexey.Brodkin@synopsys.com" , "tglx@linutronix.de" , "linux-snps-arc@lists.infradead.org" , "yamada.masahiro@socionext.com" , "linux-arm-kernel@lists.infradead.org" , "linux-arch@vger.kernel.org" Subject: Re: Patch "asm-generic/bitops/lock.h: Rewrite using atomic_fetch_" causes kernel crash Message-ID: <20180830204515.GC24124@hirez.programming.kicks-ass.net> References: <1535567633.4465.23.camel@synopsys.com> <20180830094411.GX24124@hirez.programming.kicks-ass.net> <20180830095148.GB5942@arm.com> <1535629996.4465.44.camel@synopsys.com> <20180830141713.GN24082@hirez.programming.kicks-ass.net> <20180830142354.GB13005@arm.com> <20180830142920.GO24082@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.0 (2018-05-17) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Aug 30, 2018 at 08:31:59PM +0000, Vineet Gupta wrote: > On 08/30/2018 07:29 AM, Peter Zijlstra wrote: > > On Thu, Aug 30, 2018 at 03:23:55PM +0100, Will Deacon wrote: > > > >> Yes, that would be worth trying. However, I also just noticed that the > >> fetch-ops (which are now used to implement test_and_set_bit_lock()) seem > >> to be missing the backwards branch in the LL/SC case. Yet another diff > >> below. > >> > >> Will > >> > >> --->8 > >> > >> diff --git a/arch/arc/include/asm/atomic.h b/arch/arc/include/asm/atomic.h > >> index 4e0072730241..f06c5ed672b3 100644 > >> --- a/arch/arc/include/asm/atomic.h > >> +++ b/arch/arc/include/asm/atomic.h > >> @@ -84,7 +84,7 @@ static inline int atomic_fetch_##op(int i, atomic_t *v) \ > >> "1: llock %[orig], [%[ctr]] \n" \ > >> " " #asm_op " %[val], %[orig], %[i] \n" \ > >> " scond %[val], [%[ctr]] \n" \ > >> - " \n" \ > >> + " bnz 1b \n" \ > >> : [val] "=&r" (val), \ > >> [orig] "=&r" (orig) \ > >> : [ctr] "r" (&v->counter), \ > > ACK!! sorry about that, no idea how I messed that up. > > > > Also, once it all works, they should look at switching to _relaxed > > atomics for LL/SC. > > Indeed this is the mother of all issues, I tried and system is clearly hosed with > and works after. > What's amazing is the commit 4aef66c8ae9 which introduced it is from 2016 ;-) > Back then we had a retry branch with backoff stuff which I'd reverted for new > cores and the merge conflict somehow missed it. > > @PeterZ I'll create a patch with you as author ? do I need any formal sign offs, > acks etc ? Well, Will spotted it, give authorship to him, you have my ack per the above. > So after this there are 2 other things to be addresses / looked at still while we > are still here. > > 1. After 84c6591103db __clear_bit_lock() implementation will be broken (or atleast > not consistent with what we had after), do we need to reinstate it. > 2. Will's proposed change to remove the underlying issue, but the issue in #1 > remains ? No, like explained, for spinlock based atomics the issue _should_ not exist, and if you look at your atomic_set() implementation for that variant, you'll see it does the right thing by taking the lock. Basically atomic_set() for spinlock based atomics ends up being (void)atomic_xchg(). FWIW, also ACK on Will's patch to switch you over to asm-generic bitops entirely.