Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp1617731rwb; Fri, 23 Sep 2022 15:54:44 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5F6hP5A2QoEdomqOfkjGZY1qz3yyn9CwAF1PkwB6d7b8EgW6tFjaDaSaQanWCPeeicGxsa X-Received: by 2002:a05:6402:298d:b0:451:5fc5:d423 with SMTP id eq13-20020a056402298d00b004515fc5d423mr10765467edb.102.1663973684783; Fri, 23 Sep 2022 15:54:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663973684; cv=none; d=google.com; s=arc-20160816; b=wRUIeJAEmyXktq4ioCkC20/tD3GOikVowUpXLdIdZUN2BcR2cTl5mTmXUVRbrAnm1n /OEb5KRosPvBnujJ1VyxLLz8oyCxI/Wyv7goGYu3RHNcX85HJbUK3Em4P6Mf93oPDg9k Q3MGr18r0uhzlVsLl6MIX/xoALFEA/ta6+j10faeGIzJ2z4SzA65Etu43s63h6dlPNIE LQt6F1JB0ETsOoicm/VsebBkN6D1D8Ch0v1UUrTaIuvhCl/Cr6cF3OM4WaCagvWszcQf ntmcTzTdFS2rPhOc1nKuyNq8bobYKkKYtNzM+Cws2mLPeDeQ21MU6Bz+b0CCSXvM9uhu 6SJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=/BlH7MyCrYIvRwSjyNuiLWwi1b/DT4Rd2e6Cz2Obm48=; b=eK+lsmSt7SHilBZbHeg8RxVFjQvVZL/grSasqPHKzGsFHiZlkzydNbmsiU9SDpnYZX Iw4KOaLm/kcDi42CbrtvPQU+HC+c4vADkB4g6ffT07gB+tuNrMjVzGcP8kYrLuoP68uV Wrb53p471KKwNhhXtCzw4SYxZ5D8D6RKI2g6VlCwVQieT80k8+FRNBlQ+nSk415HrijN OhTIrGW34WZ5n1mY8q0myh22TBjB2jeWC0ah2MfQlJuorUvSrXf5quLiVaJEe5PMAhcx aScGTgb2HH51umeYVw4Od7zlf3LP8oWfjtwaRB4u8+5RfRUzEeqSu+RoytyKM0P+Lcss Yxiw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hg7-20020a1709072cc700b0078062e3408csi9503673ejc.99.2022.09.23.15.54.18; Fri, 23 Sep 2022 15:54:44 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231701AbiIWWUK (ORCPT + 99 others); Fri, 23 Sep 2022 18:20:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54092 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232018AbiIWWUE (ORCPT ); Fri, 23 Sep 2022 18:20:04 -0400 Received: from gate.crashing.org (gate.crashing.org [63.228.1.57]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 2FAAB9B841 for ; Fri, 23 Sep 2022 15:19:56 -0700 (PDT) Received: from gate.crashing.org (localhost.localdomain [127.0.0.1]) by gate.crashing.org (8.14.1/8.14.1) with ESMTP id 28NMFiAQ005463; Fri, 23 Sep 2022 17:15:44 -0500 Received: (from segher@localhost) by gate.crashing.org (8.14.1/8.14.1/Submit) id 28NMFhVm005462; Fri, 23 Sep 2022 17:15:43 -0500 X-Authentication-Warning: gate.crashing.org: segher set sender to segher@kernel.crashing.org using -f Date: Fri, 23 Sep 2022 17:15:43 -0500 From: Segher Boessenkool To: Nicholas Piggin Cc: Christophe Leroy , Michael Ellerman , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Subject: Re: [PATCH] powerpc/irq: Modernise inline assembly in irq_soft_mask_{set,return} Message-ID: <20220923221543.GN25951@gate.crashing.org> References: <178f30ff62c0317061f019b3dbbc079073f104c3.1663656058.git.christophe.leroy@csgroup.eu> <20220923121829.GL25951@gate.crashing.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.4.2.3i X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_PASS, 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 Sat, Sep 24, 2022 at 02:26:52AM +1000, Nicholas Piggin wrote: > I still don't see what clauses guarantees asm("%0" ::"r"(foo)) to give > 13. It doesn't say access via inline assembly is special, But it is. It is for all register variables, local and global. I agree this isn't documented clearly. For local register variables this is the *only* thing guaranteed; for global register vars there is more (it changes the ABI, there are safe/restore effects, that kind of thing). Never it is guaranteed that all accesses through this variable will use the register directly: this fundamentally cannot work on all archs, and also not at -O0. More in general it doesn't work if some basic optimisations are not done, be it because of a compiler deficiency, or a straight out bug, or maybe it is a conscious choice in some cases. > I think if it was obviously guaranteed then this might be marginally > better than explicit r13 in the asm > > asm volatile( > "stb %0,%2(%1)" > : > : "r" (mask), > "r" (local_paca), > "i" (offsetof(struct paca_struct, irq_soft_mask)) > : "memory"); (Please use "n" instead of "i". Doesn't matter here, but it does in many other places.) Segher