Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp2293114pxp; Mon, 21 Mar 2022 16:06:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxakw0+x9L6jkLdwfAUQI1miM86rvrnCRtx3/na3I3CKO34N3JSqe522c0q7eejZ2Vbp/i9 X-Received: by 2002:a17:903:240c:b0:153:c8df:7207 with SMTP id e12-20020a170903240c00b00153c8df7207mr15039258plo.44.1647903974052; Mon, 21 Mar 2022 16:06:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1647903974; cv=none; d=google.com; s=arc-20160816; b=GClc5PgdM+4JtlYNGPuc7M0srzmlRUPzJgWBFpH4sd49vDdsptYFVSVhVIOtN2uFhj 1CZmQgoRSOH3PcnBZ40VRxUuqsuFQEQ+/I7TvHhfUlx8PpskjuAetpBOWDzp+IKLkq35 xZeqjEC9/xg7WxZEFfo1GBW1bHU8ULJ9urBxX7CcIXk0teYpUOEpUfDanMDhgio8CX0Z clMbCKu8bMeywxRaUIhbFJ3pnA4f6Dk+fqBjQgEb7Wt+jmMlrR/h1dJYxl6Hy3S5iyHw EYNFzRv52oFz/PBksyBZJgRr2cm+SxaQvJdymK6s/NXFCnNd0Qgwb4139FjhqOwtGMHH jVpg== 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 :dkim-signature; bh=92c0eBIk5OA+sVV+hJNgVl0bWX9jSejNYbozyLQt9GQ=; b=SH259/3XicucnpUCEQnfWbePAfYJWbljZ5YSW3Z15TK6nyFjxveluQ/Gc+XL4L513t wBc4O7ciSkJH3LRbNYEV2K2cuGy48Du3zFlEv8Mn/AbSsC7hjkhgadwykPnWsU+jlOy/ q5t9JMTE/LpzT8uVzVTU5Zxc6nCWCWiPZ17QLX1U1B4oYicetNtNDSj2ng5cmTAG8Mqm Yc9h3LDvAKl7m5eo+kXPNd2SajfxwQX2qcq1+XbkBXPXz5hPlICDRR3KEAZMgxfxYavT c/VQgQsCRQVxxvIf7oceAg4Lmf7SFO1NDAIgq6U/TXo2CkZbIme0pFYjt82duCtOk7Zt iv4g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=G3kPBrGJ; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id d5-20020a654245000000b00382a08b1cfbsi2243599pgq.615.2022.03.21.16.06.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 21 Mar 2022 16:06:14 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=G3kPBrGJ; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id D0C574177DC; Mon, 21 Mar 2022 15:04:38 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242964AbiCUNeD (ORCPT + 99 others); Mon, 21 Mar 2022 09:34:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49536 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347864AbiCUNeC (ORCPT ); Mon, 21 Mar 2022 09:34:02 -0400 Received: from sin.source.kernel.org (sin.source.kernel.org [145.40.73.55]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6A6B215CB6D for ; Mon, 21 Mar 2022 06:32:37 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sin.source.kernel.org (Postfix) with ESMTPS id C6319CE185A for ; Mon, 21 Mar 2022 13:32:35 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 1487FC340ED; Mon, 21 Mar 2022 13:32:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1647869554; bh=H6Ht/pv4kwqFiq9YzeQKyb/2EXOgEV7ZKz2xNTgxD5o=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=G3kPBrGJARBwvDezf1szBY1638CDLUrn0ReWbH3FvxHRwRpBptLfvQZjo/i0h13rf CJmTNZKtCb9Ujat/EY9bwzCZMUc8uEGaWKq/vTR2HbAbypmm830TSTRvCoYzg/XKMO GX0GodMkoI0jj7aKQ47DfVkh3VdBJw1jPZzMR3qFfG4mNXiQAlk1sT9VBfYNSWLKAc dV2mEmlNk6OX6tibr3hbxkniIDxklF4NFsp0LPb71T3Cwb/PM+HazktsYiHgutJSbO 2QSZMYuspjKzP628lpF7ft25wxhZOEic2raOZiO9V1c802/5QaLzW7I/oW4EKeaVnu u3RJLd8GuVBug== Date: Mon, 21 Mar 2022 13:32:27 +0000 From: Will Deacon To: Peter Zijlstra Cc: Frederic Weisbecker , LKML , Phil Auld , Alex Belits , Nicolas Saenz Julienne , Xiongfeng Wang , Neeraj Upadhyay , Thomas Gleixner , Yu Liao , Boqun Feng , "Paul E . McKenney" , Marcelo Tosatti , Paul Gortmaker , Uladzislau Rezki , Joel Fernandes , Mark Rutland Subject: Re: [PATCH 16/19] context_tracking: Convert state to atomic_t Message-ID: <20220321133226.GA10803@willie-the-truck> References: <20220302154810.42308-1-frederic@kernel.org> <20220302154810.42308-17-frederic@kernel.org> <20220312225409.GH28057@worktop.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220312225409.GH28057@worktop.programming.kicks-ass.net> User-Agent: Mutt/1.10.1 (2018-07-13) X-Spam-Status: No, score=-3.5 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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, Mar 12, 2022 at 11:54:09PM +0100, Peter Zijlstra wrote: > On Wed, Mar 02, 2022 at 04:48:07PM +0100, Frederic Weisbecker wrote: > > +static __always_inline int __ct_state(void) > > +{ > > + return atomic_read(this_cpu_ptr(&context_tracking.state)); > > +} > > One arguably horrible thing to do would be to write it like: > > return __this_cpu_read(context_tracking.state.counter); > > IIRC that will actually DTRT since atomic_read() is basically defined to > be READ_ONCE() and this_cpu_read() implies the same. > > Only PowerPC and s390 implement arch_atomic_read() in asm, but I don't > think they have a particularly good reason to. The only other weird case > is Alpha, where READ_ONCE() implies smp_mb() because Alpha. I'm not sure > we care about that case, hmm? If we don't care about the dependency ordering, then __READ_ONCE() is the chappy to use if the types don't get in the way too much. Will