Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp578075rwb; Fri, 23 Sep 2022 00:47:29 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5LL1rKo09M/GaH6phK5wYZUayjuYMU6OWxvxKlCIU2MrRFu95Kuk2Yx7aejBe9ZE4jpsM2 X-Received: by 2002:a17:907:9718:b0:77b:45b6:b047 with SMTP id jg24-20020a170907971800b0077b45b6b047mr5817959ejc.479.1663919248900; Fri, 23 Sep 2022 00:47:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663919248; cv=none; d=google.com; s=arc-20160816; b=k64Vd7kHj2W3cC2nM9lLJqKERUiDmenDpMuSQcUvTH68QdhYHpN3YICQVuKT6HZZn6 3GO/O/hDisSscLTeU517CqW0HNhb2qFfJH8DzAafkqLQ8QzytsYCr5c+t18eHgNNFGGX GDZ/NXUDmqcSKqEUeuMUK3GQHSGTzPN9md9cb/TtZva0BxXrdYfoRf/Idh5vubRRiEfR UWQ3s7MvnTv8ORyZldS03tCNzdj4uQdDmP56Mshg9aj63OfgwmjgB9v1B9h/2qww6RYn iDnHqSsF1ZBBcl5QIg59MqkEb1Lno0eBM/K1HNG8s/GCQLTO1+xoRxad9k6xJNw/06gI SGfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:references:to:from:subject:cc :message-id:date:content-transfer-encoding:mime-version :dkim-signature; bh=LZZ+DFcc0llvJVRrXIipCqbT3nWDNjH2GYv6SFsu7to=; b=ZbVs8P98jpOxoE8fR1s0th3GAQj5hn+oIvMhAOPIVbH8K4bJzS1A7eKak1I8c0M22B ZX14SezKJvrmqwS5b3dkZmkwlg0FmGr75ygfYlVXAMl+jZKAMZlqGbMvLwRPMbScWyr/ 7TeDC72BpzMPvZk9ZCphNBWN1IdzecyXQTptdBy5SIGOki4mm6sKAmKDAFxqqVYIkyBA mt5E2bZxAI1D7X0InXEcwkQ9FwcEX0KbCnb/DqMZ1GvuwJEqejpFqalSh++H1ZxU0qgm Uc7eHeXRQIHbBWY3ntqyknnoZ08w6VmVK5FAGyJzcvyYQNQFimUIOfYrUbuqdS1wbb73 o39A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=kRbvrL9A; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r9-20020a1709063d6900b0077f4a46a179si5357408ejf.454.2022.09.23.00.47.02; Fri, 23 Sep 2022 00:47:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=kRbvrL9A; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229892AbiIWHIW (ORCPT + 99 others); Fri, 23 Sep 2022 03:08:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44638 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229568AbiIWHIU (ORCPT ); Fri, 23 Sep 2022 03:08:20 -0400 Received: from mail-pj1-x1029.google.com (mail-pj1-x1029.google.com [IPv6:2607:f8b0:4864:20::1029]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1F867121643 for ; Fri, 23 Sep 2022 00:08:20 -0700 (PDT) Received: by mail-pj1-x1029.google.com with SMTP id a5-20020a17090aa50500b002008eeb040eso7129624pjq.1 for ; Fri, 23 Sep 2022 00:08:20 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=in-reply-to:references:to:from:subject:cc:message-id:date :content-transfer-encoding:mime-version:from:to:cc:subject:date; bh=LZZ+DFcc0llvJVRrXIipCqbT3nWDNjH2GYv6SFsu7to=; b=kRbvrL9AJnktY9aS5QS918bp2JUVCwAi+7X6OH2jM2hXMFmXBIPyKV+WqClPPxqFUD 6leBHKdZxnDRq6Hjx3gwIv5bRruNBEmkbiekRtwEHod8Ri21iYQcBePcWaLI223L5RQl xT4ARIiRWLq4pHZdFf2Q8Nx6E+wf9HQcCE1j2szYrHoxbNxKnVpFEybfkrnL6G1wq3EA wLXI57uLu7uTE3M+FxJs2nviFYHymI8wP//GiSOuiLN9fwvbwDvf4sRqv7LTpPswtMUV mDUr+IKEq+Hfpt00BsvQw3D/ScocwtLjZIg6YWYCF7y5+eoVnr1Msww8SBc+Xp35Inlh P7KQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:references:to:from:subject:cc:message-id:date :content-transfer-encoding:mime-version:x-gm-message-state:from:to :cc:subject:date; bh=LZZ+DFcc0llvJVRrXIipCqbT3nWDNjH2GYv6SFsu7to=; b=GJWzh5UC/V8t4ujCVmD+zaAZhuKF1NlXghhwbzk4h4VnrYNTEJ7SK8nCsIuuaNwIEZ pM8oBPox3wVVpk+c16xe4T8vXC25O/i/mz+wkpaJZnztTBs83FzvKVOxZ0A1Lgp8vxvf XpmdMtiWKb2qluF23MyJDHA2Qa2TdNwd4COz3JSq2Zc0Ce1Tu9DhoSwh6tIDDxE2FGNf ZjLMjLW+bwap/+xkK+eVr3ITgzPNia03DrrnrShALLCZP/BBB1fIXIqejZf5UG18BN5v +yVTcbQqokd4bUUQKh3HIYWmea5Va/lLb07tW87UWYb5rhcRXAMEMjBcCdamqDZ1Up6t RKyQ== X-Gm-Message-State: ACrzQf3gOhfIaoGgLjNNcFHBuMl8Zed1Uby9lQHC0vlsvH2iDoz9OIhk 7vEgK/TD3L6NAYI6RF0K5ig= X-Received: by 2002:a17:90b:4a82:b0:200:a89e:6f1f with SMTP id lp2-20020a17090b4a8200b00200a89e6f1fmr19165256pjb.13.1663916899651; Fri, 23 Sep 2022 00:08:19 -0700 (PDT) Received: from localhost (27-32-155-116.static.tpgi.com.au. [27.32.155.116]) by smtp.gmail.com with ESMTPSA id k7-20020a170902ce0700b0016c574aa0fdsm5262530plg.76.2022.09.23.00.08.16 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 23 Sep 2022 00:08:18 -0700 (PDT) Mime-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset=UTF-8 Date: Fri, 23 Sep 2022 17:08:13 +1000 Message-Id: Cc: , , "Segher Boessenkool" Subject: Re: [PATCH] powerpc/irq: Modernise inline assembly in irq_soft_mask_{set,return} From: "Nicholas Piggin" To: "Christophe Leroy" , "Michael Ellerman" X-Mailer: aerc 0.11.0 References: <178f30ff62c0317061f019b3dbbc079073f104c3.1663656058.git.christophe.leroy@csgroup.eu> In-Reply-To: <178f30ff62c0317061f019b3dbbc079073f104c3.1663656058.git.christophe.leroy@csgroup.eu> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue Sep 20, 2022 at 4:41 PM AEST, Christophe Leroy wrote: > local_paca is declared as global register asm("r13"), it is therefore > garantied to always ever be r13. > > It is therefore not required to opencode r13 in the assembly, use > a reference to local_paca->irq_soft_mask instead. > > This also allows removing the 'memory' clobber in irq_soft_mask_set() > as GCC now knows what is being modified in memory. The code matches the changelog AFAIKS. But I don't know where it is guaranteed it will always be r13 in GCC and Clang. I still don't know where in the specification or documentation suggests this. There was some assertion it would always be r13, but that can't be a *general* rule. e.g., the following code: struct foo { #ifdef BIGDISP int array[1024*1024]; #endif char bar; }; register struct foo *foo asm("r13"); static void setval(char val) { asm("stb%X0 %1,%0" : "=3Dm" (foo->bar) : "r" (val)); } int main(void) { setval(10); } With -O0 this generates stb 9,0(10) for me for GCC 12, and with -O2 -DBIGDISP it generates stb 10,0(9). So that makes me nervious. GCC does not have some kind of correctness guarantee here, so it must not have this in its regression tests etc., and who knows about clang. If it is true for some particular subset of cases that we can guarantee, e.g., using -O2 and irq_soft_mask offset within range of stb offset and we can point to specification such that both GCC and Clang will follow it, then okay. Otherwise I still think it's more trouble than it is worth. Thanks, Nick > > Using %X modifier will give GCC a bit more flexibility on the code > generation. > > Signed-off-by: Christophe Leroy > --- > arch/powerpc/include/asm/hw_irq.h | 12 ++---------- > 1 file changed, 2 insertions(+), 10 deletions(-) > > diff --git a/arch/powerpc/include/asm/hw_irq.h b/arch/powerpc/include/asm= /hw_irq.h > index e8de249339d8..dbe037ff4474 100644 > --- a/arch/powerpc/include/asm/hw_irq.h > +++ b/arch/powerpc/include/asm/hw_irq.h > @@ -115,10 +115,7 @@ static inline notrace unsigned long irq_soft_mask_re= turn(void) > { > unsigned long flags; > =20 > - asm volatile( > - "lbz %0,%1(13)" > - : "=3Dr" (flags) > - : "i" (offsetof(struct paca_struct, irq_soft_mask))); > + asm volatile("lbz%X1 %0,%1" : "=3Dr" (flags) : "m" (local_paca->irq_sof= t_mask)); > =20 > return flags; > } > @@ -147,12 +144,7 @@ static inline notrace void irq_soft_mask_set(unsigne= d long mask) > if (IS_ENABLED(CONFIG_PPC_IRQ_SOFT_MASK_DEBUG)) > WARN_ON(mask && !(mask & IRQS_DISABLED)); > =20 > - asm volatile( > - "stb %0,%1(13)" > - : > - : "r" (mask), > - "i" (offsetof(struct paca_struct, irq_soft_mask)) > - : "memory"); > + asm volatile("stb%X0 %1,%0" : "=3Dm" (local_paca->irq_soft_mask) : "r" = (mask)); > } > =20 > static inline notrace unsigned long irq_soft_mask_set_return(unsigned lo= ng mask) > --=20 > 2.37.1