Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp933639pxb; Thu, 26 Aug 2021 19:22:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwdOSMVAD3QhZdN+0//501HBRkX5rp4gkrOsY+qILyFkmmUTln3eN9125sOtEwXyKLwir0n X-Received: by 2002:a05:6e02:174a:: with SMTP id y10mr5053200ill.121.1630030951236; Thu, 26 Aug 2021 19:22:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630030951; cv=none; d=google.com; s=arc-20160816; b=EyA5vy8jnUHD/kwopuWKEB1WwIgTr/3tmwAvDlinMXCJTHfs/euhJS7RR1K4pNfDxe qXryBdEg4wZmpHBTQNpLKpmJJ94EWFjfN59M7QHgJmYo9fQP+QYHUKG6Z8SQNjp6KXqT uEaUnoLp2/Esy1pCjFDzDSXihZ4DEeKoaZNdFMqBE8KHP0cNwpZv4Cc8EgeTjs9tkhie kE6geg0Qpwoj1Hv6XIA4d4MgNjngzFkSFb7YZ4LHQiH5OG5QVe597ZJ0T/ADKUyG6Idq 6MNkGHUZN1krP3/oiKOt9GCsaRMVryRsllhhakR/3NGsqR/o9yfO9uJGMq4kYyIlfsmr DvDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=rSOjbuRdk1TZ49NvwDti2zU1kHapru68ruaxv+B72xg=; b=g+z6KZ06kxbrFE1cjbb/TeKzR3Z6/ZJAViD3JgKcINYbAGvSsPetDVou/pGC8/NjO+ WYiJBqhhmUyxDkHY3u2U23vkgUnFzs3Nn2Vtj8R+xeDUNAa+3HCbxfyIjbrwKBhT+OWW xhZq0vZj22LyO4DOXpuO31MKVpu4jCCEpwWvm3ewvk+Wft67/ItRqe6F6I2HU4MPR41z EfyDQkF/7kpJvvCytRl26dp6WdqWFz+JVT2nw+Aa4D+sze3OmnGeUMqDniLJ7tIsbiTq 9GBWMdv53zfXlYErUtGDCrlx7Mv9DH6c/49lOujjQP2mLhML5LhF5iIZYvlcCckNBDia h6BQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=FMZbGbXH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n11si5247392ilt.25.2021.08.26.19.22.19; Thu, 26 Aug 2021 19:22:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=FMZbGbXH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244004AbhH0CW2 (ORCPT + 99 others); Thu, 26 Aug 2021 22:22:28 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:21750 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243961AbhH0CW1 (ORCPT ); Thu, 26 Aug 2021 22:22:27 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1630030898; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc; bh=rSOjbuRdk1TZ49NvwDti2zU1kHapru68ruaxv+B72xg=; b=FMZbGbXHRL/rBJFMlRdgzKoKzXlymSgBAqcPXH6wmUcRXfX3eaMgbti++vTbChzY40EGhr T/4nw+CA5eTD+l3AEeWO9kdjEdjiM3Otw+i77jS69voTqUqAOM9t8rio9UFGgviDmdAPFo nx1jHiyG2syooj8tTHDqOBLIeyMpHsM= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-353-skf5Qfs7Pg-EqMt6lcsStg-1; Thu, 26 Aug 2021 22:21:35 -0400 X-MC-Unique: skf5Qfs7Pg-EqMt6lcsStg-1 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 8A1CC8015C7; Fri, 27 Aug 2021 02:21:33 +0000 (UTC) Received: from llong.com (unknown [10.22.32.131]) by smtp.corp.redhat.com (Postfix) with ESMTP id 57B245D9DC; Fri, 27 Aug 2021 02:21:28 +0000 (UTC) From: Waiman Long To: "Paul E. McKenney" , Josh Triplett , Steven Rostedt , Mathieu Desnoyers , Lai Jiangshan , Joel Fernandes Cc: rcu@vger.kernel.org, linux-kernel@vger.kernel.org, Waiman Long Subject: [PATCH] rcu: Avoid unneeded function call in rcu_read_unlock() Date: Thu, 26 Aug 2021 22:21:22 -0400 Message-Id: <20210827022122.15816-1-longman@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Since commit aa40c138cc8f3 ("rcu: Report QS for outermost PREEMPT=n rcu_read_unlock() for strict GPs"). A real function call rcu_read_unlock_strict() is added to the inlined rcu_read_unlock(). The rcu_read_unlock_strict() call is only needed if the performance sagging CONFIG_RCU_STRICT_GRACE_PERIOD option is set. This config option isn't set for most production kernels while the function call overhead remains. To provide a slight performance improvement, the CONFIG_RCU_STRICT_GRACE_PERIOD config check is moved from rcu_read_unlock_strict() to __rcu_read_unlock() so that the function call can be compiled out in most cases. Besides, the GPL exported rcu_read_unlock_strict() also impact the the compilation of non-GPL kernel modules as rcu_read_unlock() is a frequently used kernel API. Signed-off-by: Waiman Long --- include/linux/rcupdate.h | 3 ++- kernel/rcu/tree_plugin.h | 3 +-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h index d9680b798b21..945594770d57 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h @@ -71,7 +71,8 @@ static inline void __rcu_read_lock(void) static inline void __rcu_read_unlock(void) { preempt_enable(); - rcu_read_unlock_strict(); + if (IS_ENABLED(CONFIG_RCU_STRICT_GRACE_PERIOD)) + rcu_read_unlock_strict(); } static inline int rcu_preempt_depth(void) diff --git a/kernel/rcu/tree_plugin.h b/kernel/rcu/tree_plugin.h index de1dc3bb7f70..7fa518bef15d 100644 --- a/kernel/rcu/tree_plugin.h +++ b/kernel/rcu/tree_plugin.h @@ -844,8 +844,7 @@ void rcu_read_unlock_strict(void) { struct rcu_data *rdp; - if (!IS_ENABLED(CONFIG_RCU_STRICT_GRACE_PERIOD) || - irqs_disabled() || preempt_count() || !rcu_state.gp_kthread) + if (irqs_disabled() || preempt_count() || !rcu_state.gp_kthread) return; rdp = this_cpu_ptr(&rcu_data); rcu_report_qs_rdp(rdp); -- 2.18.1