Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 43C87C74A5B for ; Tue, 21 Mar 2023 04:18:55 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229483AbjCUESw (ORCPT ); Tue, 21 Mar 2023 00:18:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229484AbjCUESt (ORCPT ); Tue, 21 Mar 2023 00:18:49 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 947B73C38 for ; Mon, 20 Mar 2023 21:18:47 -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 ams.source.kernel.org (Postfix) with ESMTPS id 2E623B80D5C for ; Tue, 21 Mar 2023 04:18:46 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9C9CBC433EF; Tue, 21 Mar 2023 04:18:44 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1679372324; bh=pbEGl7dD5fxCPHdZv4f//Rwhjn5M+g6SoFos47Cd0PM=; h=Date:From:To:Cc:Subject:Reply-To:References:In-Reply-To:From; b=YDlsKc03X/Okd7034UDCAimU41OiaqHgzXFtbEC2J7teIkl2SL9sTEiUbyMRABHUH rG94XYV33FmS4/9WD1/HQ7V63mTi4W1J07MOiPkba05gq2kfFFgCHD9xg9vxCdCfUz HvOuBjKASFNOjA1n6WhFsB1ReiuyI29/cytPOqGjKb8KqOFliGjoJq/Twg7jyBzdh/ cBHgTnLQkOSEZrWfM3pIB6cI/K9yvYdsgh9upXdzR7mGbfiA+7dSUaphwRE3lejO4r SlSWYCf3oQ5szAYxLXNXFWW4SeKsL0oMRQgrN78vQz237pOgoAH0Z69pg4uVRL76oL nARJ7JSN1awHw== Received: by paulmck-ThinkPad-P72.home (Postfix, from userid 1000) id 4565A1540395; Mon, 20 Mar 2023 21:18:44 -0700 (PDT) Date: Mon, 20 Mar 2023 21:18:44 -0700 From: "Paul E. McKenney" To: "Liu, Yujie" Cc: lkp , "linux-kernel@vger.kernel.org" , "oe-kbuild-all@lists.linux.dev" Subject: Re: [paulmck-rcu:dev.2023.03.17a 33/38] kernel/rcu/tasks.h:140:20: warning: 'tasks_rcu_exit_srcu' defined but not used Message-ID: <5b73fe0e-bacc-4aee-a632-3160e38e42db@paulmck-laptop> Reply-To: paulmck@kernel.org References: <202303191536.XzMSyzTl-lkp@intel.com> <9c716b77dd0743089a40f933ccdcbd57222e21f4.camel@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <9c716b77dd0743089a40f933ccdcbd57222e21f4.camel@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 21, 2023 at 02:49:08AM +0000, Liu, Yujie wrote: > Hi Paul, > > On Sun, 2023-03-19 at 17:33 -0700, Paul E. McKenney wrote: > > On Sun, Mar 19, 2023 at 03:05:43PM +0800, kernel test robot wrote: > > > tree:?? https://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git?dev.2023.03.17a > > > head:?? 19d218a4b125a4dce12eb88097a9c55f7126ce8c > > > commit: 61eea4556e8cf92d4c9b483110a679d2652aa451 [33/38] srcu: Move work-scheduling fields from srcu_struct to srcu_usage > > > config: x86_64-kexec (https://download.01.org/0day-ci/archive/20230319/202303191536.XzMSyzTl-lkp@intel.com/config) > > > compiler: gcc-11 (Debian 11.3.0-8) 11.3.0 > > > reproduce (this is a W=1 build): > > > ??????? # https://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git/commit/?id=61eea4556e8cf92d4c9b483110a679d2652aa451 > > > ??????? git remote add paulmck-rcu https://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-rcu.git > > > ??????? git fetch --no-tags paulmck-rcu dev.2023.03.17a > > > ??????? git checkout 61eea4556e8cf92d4c9b483110a679d2652aa451 > > > ??????? # save the config file > > > ??????? mkdir build_dir && cp config build_dir/.config > > > ??????? make W=1 O=build_dir ARCH=x86_64 olddefconfig > > > ??????? make W=1 O=build_dir ARCH=x86_64 SHELL=/bin/bash kernel/ > > > > > > If you fix the issue, kindly add following tag where applicable > > > > Reported-by: kernel test robot > > > > Link: https://lore.kernel.org/oe-kbuild-all/202303191536.XzMSyzTl-lkp@intel.com/ > > > > > > All warnings (new ones prefixed by >>): > > > > > > ?? In file included from include/linux/srcu.h:49, > > > ??????????????????? from include/linux/notifier.h:16, > > > ??????????????????? from arch/x86/include/asm/uprobes.h:13, > > > ??????????????????? from include/linux/uprobes.h:49, > > > ??????????????????? from include/linux/mm_types.h:16, > > > ??????????????????? from include/linux/sched/signal.h:13, > > > ??????????????????? from kernel/rcu/update.c:26: > > > > > kernel/rcu/tasks.h:140:20: warning: 'tasks_rcu_exit_srcu' defined but not used [-Wunused-variable] > > > ???? 140 | DEFINE_STATIC_SRCU(tasks_rcu_exit_srcu); > > > ???????? |??????????????????? ^~~~~~~~~~~~~~~~~~~ > > > ?? include/linux/srcutree.h:184:38: note: in definition of macro '__DEFINE_SRCU' > > > ???? 184 |???????? is_static struct srcu_struct name =???????????????????????????????????????????????????? \ > > > ???????? |????????????????????????????????????? ^~~~ > > > ?? kernel/rcu/tasks.h:140:1: note: in expansion of macro 'DEFINE_STATIC_SRCU' > > > ???? 140 | DEFINE_STATIC_SRCU(tasks_rcu_exit_srcu); > > > ???????? | ^~~~~~~~~~~~~~~~~~ > > > > Good catch, thank you! > > > > Does the patch shown below fix this? > > We've tested the patch and the build warning is fixed by it. Thanks. Thank you! May I apply your Tested-by? Thanx, Paul > -- > Best Regards, > Yujie > > > ????????????????????????????????????????????????????????Thanx, Paul > > > > ------------------------------------------------------------------------ > > > > commit a9b8406e51603238941dbc6fa1437f8915254ebb > > Author: Paul E. McKenney > > Date:?? Sun Mar 19 17:29:20 2023 -0700 > > > > ??? rcu-tasks: Fix warning for unused tasks_rcu_exit_srcu > > ??? > > ??? The tasks_rcu_exit_srcu variable is used only by kernels built > > ??? with CONFIG_TASKS_RCU=y, but is defined for all kernesl with > > ??? CONFIG_TASKS_RCU_GENERIC=y.? Therefore, in kernels built with > > ??? CONFIG_TASKS_RCU_GENERIC=y but CONFIG_TASKS_RCU=n, this gives > > ??? a "defined but not used" warning. > > ??? > > ??? This commit therefore moves this variable under CONFIG_TASKS_RCU > > ??? > > ??? Link: https://lore.kernel.org/oe-kbuild-all/202303191536.XzMSyzTl-lkp@intel.com/ > > ??? Reported-by: kernel test robot > > ??? Signed-off-by: Paul E. McKenney > > > > diff --git a/kernel/rcu/tasks.h b/kernel/rcu/tasks.h > > index baf7ec178155..85a874d4166b 100644 > > --- a/kernel/rcu/tasks.h > > +++ b/kernel/rcu/tasks.h > > @@ -136,10 +136,10 @@ static struct rcu_tasks rt_name =?????????????????????????????????????????????????\ > > ????????.kname = #rt_name,??????????????????????????????????????????????????????????????\ > > ?} > > ? > > +#ifdef CONFIG_TASKS_RCU > > ?/* Track exiting tasks in order to allow them to be waited for. */ > > ?DEFINE_STATIC_SRCU(tasks_rcu_exit_srcu); > > ? > > -#ifdef CONFIG_TASKS_RCU > > ?/* Report delay in synchronize_srcu() completion in rcu_tasks_postscan(). */ > > ?static void tasks_rcu_exit_srcu_stall(struct timer_list *unused); > > ?static DEFINE_TIMER(tasks_rcu_exit_srcu_stall_timer, tasks_rcu_exit_srcu_stall); > > >