Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp566136iob; Wed, 18 May 2022 08:10:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxTybzQCQpFexlJiBZooUvpUde5Na9jrgTKZ5UDw9qW50YSlTOPi1MV4WsHfetQSlBEg0Lc X-Received: by 2002:a05:6a00:1991:b0:50e:697:53f9 with SMTP id d17-20020a056a00199100b0050e069753f9mr104874pfl.22.1652886614540; Wed, 18 May 2022 08:10:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652886614; cv=none; d=google.com; s=arc-20160816; b=C+YnTIGsuqxfI5X2/lnlo1Gmlw+gzyEg0v3AfAXAfvJnZFVL2MitqBz9ac2RXiSHcQ GF5jW+398/DcnEW6WuP2DXoM/ny3+DhWmwvEr8wFvjqqTAQGxWmFFmC/7qj/7AI4znlD obV3u3xOQAvk1OEBDQERTg3X4PEkof8+5RL1mkGwoAY9bEI4QDMIWq3/p/w/PyR4yd+C qeRiSr42cin/UDyZgmsU2nrF6s+0mC2TPS8USTa4mMlyhiCs1zm7wFCm80WJsg7AkXlq OhrzkIHyHNU2BhTOzj2jWgtimkXrZDB7ZIECm7dkls7X2H8oqyiYZYKbmQX2XO2Q9Ucg AKBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=Ukc2eEVxINdFk6sBtkXwQfcMciTtqRPU+uyJSGbjVBI=; b=mpnHC+R1qnt/nrsqJE8KcRAH6jAwzdTQbSjt+5L3YUJrgvpiVMYd8ciZ4g/3r/9mRW qptdD86BmrjUyBH9+Qv9lIiiqW3RA0JHrr7QRmohYuf5jaIJm0/3NxCuEGDst07MqOqk MDGtNJp3aDS1m/M8/5bN4G1dJ2sspvvwxIKtByFexCJGOTPNkoBqKsYtwi5QzvgahFZF 5bmtBS5K5dBP3JA07uELmEaE/FHeDXvFmxo5po7HtmtRMqT3U8LigoLFuXxdI2U6rih0 2XYwW0l1x7Oe9g15EGb5ab1Yy0wFgakbqNYYko+rqBxnZlCILR4yBGFWKgGZOZMecG+t uq6Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=u9aDk5Hh; 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 f7-20020a056a0022c700b0050a707536ecsi3709125pfj.299.2022.05.18.08.10.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 18 May 2022 08:10: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=u9aDk5Hh; 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 2180B1DFD97; Wed, 18 May 2022 08:10:12 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239162AbiERPKG (ORCPT + 99 others); Wed, 18 May 2022 11:10:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39188 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239087AbiERPKE (ORCPT ); Wed, 18 May 2022 11:10:04 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C33D91DFD89 for ; Wed, 18 May 2022 08:10:02 -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 dfw.source.kernel.org (Postfix) with ESMTPS id 5642A61958 for ; Wed, 18 May 2022 15:10:02 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 31B80C385A9; Wed, 18 May 2022 15:09:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1652886601; bh=SIvbxlSGGzkgi9tVz1CdkOJ99ZWAfRB8ApyV15kUEX4=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=u9aDk5HhIQ3k47ScSvMLrgb6tbQ8Hoqhs5CpqaQoAz0V4nc/sU//r1N0F8wF2Zna7 FkURu8/kROwW5SGQ+y0WudFSMKiCMf3iQ5WjTKiZQjrFq40wHsaObsZ/XZg7wYFwRd 8Sy39KgSwbBvZ9PHHox+qDtgfxROf3tFZdf4fBqG70mmMj2jbB0IIGiRgJLQnfcA0m r3RvGM/cKdAff0SESwBN2Lgs7BDq8pQhFlc4IsXFDcQHaXeQlQAttAJfnSe1+7qPjc UiKb6GmlQjNpH2AKiqNYNo1Uuqq82Vrq6dYpu/R5xbcCYreq6kh9hiPgxKwZDBp+Y2 hczqQ/QYUGitA== Message-ID: <372364b33b8d4b93908c3822e18f7d295de2ede9.camel@kernel.org> Subject: Re: [PATCH 20/21] context_tracking: Convert state to atomic_t From: nicolas saenz julienne To: Frederic Weisbecker , LKML Cc: Peter Zijlstra , Phil Auld , Alex Belits , Xiongfeng Wang , Neeraj Upadhyay , Thomas Gleixner , Yu Liao , Boqun Feng , "Paul E . McKenney" , Marcelo Tosatti , Paul Gortmaker , Uladzislau Rezki , Joel Fernandes Date: Wed, 18 May 2022 17:09:55 +0200 In-Reply-To: <20220503100051.2799723-21-frederic@kernel.org> References: <20220503100051.2799723-1-frederic@kernel.org> <20220503100051.2799723-21-frederic@kernel.org> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable User-Agent: Evolution 3.44.1 (3.44.1-1.fc36) MIME-Version: 1.0 X-Spam-Status: No, score=-2.6 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 Tue, 2022-05-03 at 12:00 +0200, Frederic Weisbecker wrote: [...] > +/** > + * ct_state() - return the current context tracking state if known > + * > + * Returns the current cpu's context tracking state if context tracking > + * is enabled. If context tracking is disabled, returns > + * CONTEXT_DISABLED. This should be used primarily for debugging. > + */ > +static __always_inline int ct_state(void) > +{ > + int ret; > + > + if (!context_tracking_enabled()) > + return CONTEXT_DISABLED; > + > + preempt_disable(); > + ret =3D __ct_state(); > + preempt_enable(); > + > + return ret; > +} > + I can't see any use for this function with preemption enabled. You can't tr= ust the data due to CPU migration and it could be a source of bugs in the futur= e. Wouldn't it make more sense to move the burden into the callers? They all D= TRT, plus, this_cpu_ptr() will spew warnings if someone shows up and doesn't com= ply. Regards, --=20 Nicol=C3=A1s S=C3=A1enz