Received: by 10.223.164.202 with SMTP id h10csp970316wrb; Fri, 17 Nov 2017 11:39:32 -0800 (PST) X-Google-Smtp-Source: AGs4zMYTWgIUdoqLAxx4yx2d9UTbDQuwsA+T4FjliyDDbZLGvVsmF4VCJe8rnT0eVclRRvRUizOs X-Received: by 10.99.117.7 with SMTP id q7mr6112314pgc.96.1510947572049; Fri, 17 Nov 2017 11:39:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1510947572; cv=none; d=google.com; s=arc-20160816; b=s/lGPHwGttMziL7YzWGW0JDgCYyo/Jwem9UYf3f30zuKYIw7Ptdqpt+5M6zlopAS4h jVJRFMP+Py0CWp6Je3M6ZiEr/6UVwboTlLRXQ3a5CVhpoQFLxptGdskMFyUbR6UVqNwY XXQLO1rG1a+vidPe7Nu2DZ46yxWLEjG8gPpYhNfLSsTkmY/OAcitOwPRKZ31nVJ/S+vT r8JCek4x+hYa1GHAgqIbT4esYxo9tDrGmckb8Z67uHXvBZjntxP7mdt94YLo+qemw/y9 S6pdVgLuHBJquazVGm2Y14BgWBhelNtRaoZZB3hzUg42QGCj6ZLRRwmXc7w8mQMLDEEn 7teg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=2CRKKba1jWj1WvjYw5jjyLFkBmGfmOL3VW8IyJHWu1A=; b=e693HTQe4OSz9jU/Xhs0gRb8aiMBK1FUt3hGuNoYfiA6f5KuTRMby4E35UlOn0RJ3h 84v0kUBhl1NeRZEesZHHrfH9ux2UkYX6ZAb6/wPKqSPbmlGA5wNOKxwlOwRC0/Lvriyc rEY3YpG/oEF2eRMTrZrW9SG5d+822W06o+wBZT7SCZyumELG1uOP5qz48QvfTEqAleHS N6IvMrT/ax9uptqHVv8xCWNl0873WUythojuN7WEXUIIrC7rBovaRG6UlUIDEXoS+EAN errsebTIf/77ycPDBJYL2SxMG5n/BarBQUf/LoWKBdcsTXCALYt/ao3GjNHm0WEVGP7E QHog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BuR6lPnm; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t77si3591382pfa.185.2017.11.17.11.39.19; Fri, 17 Nov 2017 11:39:31 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BuR6lPnm; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965578AbdKQPkm (ORCPT + 93 others); Fri, 17 Nov 2017 10:40:42 -0500 Received: from mail-pf0-f193.google.com ([209.85.192.193]:39113 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965045AbdKQPkg (ORCPT ); Fri, 17 Nov 2017 10:40:36 -0500 Received: by mail-pf0-f193.google.com with SMTP id l24so2194646pfj.6 for ; Fri, 17 Nov 2017 07:40:36 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=2CRKKba1jWj1WvjYw5jjyLFkBmGfmOL3VW8IyJHWu1A=; b=BuR6lPnm+VDtOek/D+mHxG4hS6YtsRud+XostwJ7f25vyEnj7cAEYnsU8McMrCfBYv +eRUWF5SUR2SZSmKTElmFUBvGV1zVlGNJBfqJnvFjZ8/diF2Cyhk89VfJcXM1cYnI2DY 4118Oz0JU3y2B0G+MqvYq1hoYhrgOG0rfbfJ8LZD5SDSU2TSow2fa6wBAiEbHiVihgf+ PxAvtxUJHIlSspgXgK8qf0JK5KwpubC6IK5MgREeufYr1BAKfhNb+s4JQMTBfzDv5HPI OcbvfbYzSIhWvOJMSX/MDn6u0LNCbGE3C48iSMloFpfJA1DfHH43gFM93iBpr8XZit46 IyuA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=2CRKKba1jWj1WvjYw5jjyLFkBmGfmOL3VW8IyJHWu1A=; b=Zfo3WDaVF8ZJ5bJGtP3PUpIAiMvXmj7pSNKS8zJqoe6lykAof40QoM5F7qTW/Cx2/R 31CyLReqrIEYxv4hwgSH+q5W9Q4MswpskQmOlwjQB82Pa1w3TCULMyMq8wwvXVmd5UOj VLnYgKmXkXPTrWBwyig+/SVGSmvHI89Z4DKG7X5qAgjhWDM1RkoUGqUTz/Y2do+RT6uy lLSEiVkieyTtaBvTtNY4FIb017jBnu0P7Ks8EX5I/NNBMfU057vAtTPuIhPDGYQZuGit +bQgrFHuypr8l0bOD1nuvZJWtsBDGDCj9m/G+37wSVXF0aaniy+pf5kF5Rd98tAVJKh4 QOTw== X-Gm-Message-State: AJaThX4cwFT5MbNOjiCf+qV6bq9hlMLgDeTafcB1bkrJCFCN4z8DqaDa xVUPeaRO3mwQSK3yg3F9iBuldmGA X-Received: by 10.84.200.39 with SMTP id s36mr5646941pld.9.1510933235753; Fri, 17 Nov 2017 07:40:35 -0800 (PST) Received: from localhost.localdomain ([103.76.155.2]) by smtp.gmail.com with ESMTPSA id l13sm7911982pfj.73.2017.11.17.07.40.31 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 17 Nov 2017 07:40:34 -0800 (PST) From: Rakib Mullick To: linux-kernel@vger.kernel.org, mingo@kernel.org Cc: "Paul E. McKenney" , Josh Triplett , Steven Rostedt , Mathieu Desnoyers , Lai Jiangshan Subject: [PATCH] RCU: Remove have_rcu_nocb_mask from tree_plugin.h Date: Fri, 17 Nov 2017 21:40:15 +0600 Message-Id: <20171117154015.19525-1-rakib.mullick@gmail.com> X-Mailer: git-send-email 2.9.3 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently have_rcu_nocb_mask is used to avoid double allocation of rcu_nocb_mask during boot up. Due to different representation of cpumask_var_t on different kernel config CPUMASK=y(or n) it was okay. But now we have a helper cpumask_available(), which can be utilized to check whether rcu_nocb_mask has been allocated or not without using a variable. Removing the variable also reduces vmlinux size. Unpatched version: text data bss dec hex filename 13050393 7852470 14543408 35446271 21cddff vmlinux Patched version: text data bss dec hex filename 13050390 7852438 14543408 35446236 21cdddc vmlinux Signed-off-by: Rakib Mullick Cc: "Paul E. McKenney" Cc: Josh Triplett Cc: Steven Rostedt Cc: Mathieu Desnoyers Cc: Lai Jiangshan --- Patch applied on top of linus's tree (commit cf9b0772f2e41). kernel/rcu/tree_plugin.h | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/kernel/rcu/tree_plugin.h b/kernel/rcu/tree_plugin.h index db85ca3..13a8e08 100644 --- a/kernel/rcu/tree_plugin.h +++ b/kernel/rcu/tree_plugin.h @@ -61,7 +61,6 @@ DEFINE_PER_CPU(char, rcu_cpu_has_work); #ifdef CONFIG_RCU_NOCB_CPU static cpumask_var_t rcu_nocb_mask; /* CPUs to have callbacks offloaded. */ -static bool have_rcu_nocb_mask; /* Was rcu_nocb_mask allocated? */ static bool __read_mostly rcu_nocb_poll; /* Offload kthread are to poll. */ #endif /* #ifdef CONFIG_RCU_NOCB_CPU */ @@ -1752,7 +1751,6 @@ static void increment_cpu_stall_ticks(void) static int __init rcu_nocb_setup(char *str) { alloc_bootmem_cpumask_var(&rcu_nocb_mask); - have_rcu_nocb_mask = true; cpulist_parse(str, rcu_nocb_mask); return 1; } @@ -1801,7 +1799,7 @@ static void rcu_init_one_nocb(struct rcu_node *rnp) /* Is the specified CPU a no-CBs CPU? */ bool rcu_is_nocb_cpu(int cpu) { - if (have_rcu_nocb_mask) + if (cpumask_available(rcu_nocb_mask)) return cpumask_test_cpu(cpu, rcu_nocb_mask); return false; } @@ -2295,14 +2293,13 @@ void __init rcu_init_nohz(void) need_rcu_nocb_mask = true; #endif /* #if defined(CONFIG_NO_HZ_FULL) */ - if (!have_rcu_nocb_mask && need_rcu_nocb_mask) { + if (!cpumask_available(rcu_nocb_mask) && need_rcu_nocb_mask) { if (!zalloc_cpumask_var(&rcu_nocb_mask, GFP_KERNEL)) { pr_info("rcu_nocb_mask allocation failed, callback offloading disabled.\n"); return; } - have_rcu_nocb_mask = true; } - if (!have_rcu_nocb_mask) + if (!cpumask_available(rcu_nocb_mask)) return; #if defined(CONFIG_NO_HZ_FULL) @@ -2428,7 +2425,7 @@ static void __init rcu_organize_nocb_kthreads(struct rcu_state *rsp) struct rcu_data *rdp_leader = NULL; /* Suppress misguided gcc warn. */ struct rcu_data *rdp_prev = NULL; - if (!have_rcu_nocb_mask) + if (!cpumask_available(rcu_nocb_mask)) return; if (ls == -1) { ls = int_sqrt(nr_cpu_ids); -- 2.9.3 From 1584611202643476338@xxx Mon Nov 20 18:36:45 +0000 2017 X-GM-THRID: 1584611202643476338 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread