From mboxrd@z Thu Jan 1 00:00:00 1970 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 0624CCDB474 for ; Wed, 18 Oct 2023 02:35:40 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229481AbjJRCfj (ORCPT ); Tue, 17 Oct 2023 22:35:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229451AbjJRCfi (ORCPT ); Tue, 17 Oct 2023 22:35:38 -0400 Received: from mgamail.intel.com (mgamail.intel.com [192.55.52.136]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 790F7FE for ; Tue, 17 Oct 2023 19:35:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1697596536; x=1729132536; h=date:from:to:cc:subject:message-id:mime-version; bh=ZBaG5eJktr12eyqgbkQHhGK4wOu3sEHcBNvAX9gBH/w=; b=ZW8FYtRkOGNY6QLJCpZhY7vDHvu/ezPMZB8slbeDOCtxRrOHk+yCfwXC NUAz6x1/6n0jcDbuVkyO+EwVHMl5Klv+GjWjLFsu7az63Ka0SPHjlHfk6 bmi3XwXJT92XwRDHW9/H5dbqlowVMu/hBjAtcyUz2Qyg6bj490cG0n7oG jO/0jV8pC2S41FXpitkQp7IPGhlexJrRHTEXk4ZBDyzNJrLEMDZBjDsJ7 8Y5oA7+ElCsutw5VMy5B60HQxyRN43Z+4zzxARLegVA8HZkQrWO+n43tC IKncng+FSEzFRQv1T5ql6XZBRYajXI4MHmPn+TxgYSG9jQUFrjISWcwdR g==; X-IronPort-AV: E=McAfee;i="6600,9927,10866"; a="365274692" X-IronPort-AV: E=Sophos;i="6.03,233,1694761200"; d="scan'208";a="365274692" Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga106.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Oct 2023 19:35:36 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10866"; a="929985605" X-IronPort-AV: E=Sophos;i="6.03,233,1694761200"; d="scan'208";a="929985605" Received: from lkp-server02.sh.intel.com (HELO f64821696465) ([10.239.97.151]) by orsmga005.jf.intel.com with ESMTP; 17 Oct 2023 19:35:34 -0700 Received: from kbuild by f64821696465 with local (Exim 4.96) (envelope-from ) id 1qswPD-000AOx-2m; Wed, 18 Oct 2023 02:35:31 +0000 Date: Wed, 18 Oct 2023 10:35:29 +0800 From: kernel test robot To: Masahiro Yamada Cc: oe-kbuild-all@lists.linux.dev, linux-kernel@vger.kernel.org Subject: kernel/context_tracking.c:126:39: sparse: sparse: incorrect type in initializer (different address spaces) Message-ID: <202310181030.98lBllJ5-lkp@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org tree: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master head: 06dc10eae55b5ceabfef287a7e5f16ceea204aa0 commit: 481461f5109919babbb393d6f68002936b8e2493 linux/export.h: make independent of CONFIG_MODULES date: 3 months ago config: x86_64-alldefconfig (https://download.01.org/0day-ci/archive/20231018/202310181030.98lBllJ5-lkp@intel.com/config) compiler: gcc-12 (Debian 12.2.0-14) 12.2.0 reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20231018/202310181030.98lBllJ5-lkp@intel.com/reproduce) If you fix the issue in a separate patch/commit (i.e. not just a new version of the same patch/commit), kindly add following tags | Reported-by: kernel test robot | Closes: https://lore.kernel.org/oe-kbuild-all/202310181030.98lBllJ5-lkp@intel.com/ sparse warnings: (new ones prefixed by >>) >> kernel/context_tracking.c:126:39: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got struct context_tracking * @@ kernel/context_tracking.c:126:39: sparse: expected void const [noderef] __percpu *__vpp_verify kernel/context_tracking.c:126:39: sparse: got struct context_tracking * kernel/context_tracking.c:165:39: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got struct context_tracking * @@ kernel/context_tracking.c:165:39: sparse: expected void const [noderef] __percpu *__vpp_verify kernel/context_tracking.c:165:39: sparse: got struct context_tracking * kernel/context_tracking.c:206:39: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got struct context_tracking * @@ kernel/context_tracking.c:206:39: sparse: expected void const [noderef] __percpu *__vpp_verify kernel/context_tracking.c:206:39: sparse: got struct context_tracking * kernel/context_tracking.c:261:39: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got struct context_tracking * @@ kernel/context_tracking.c:261:39: sparse: expected void const [noderef] __percpu *__vpp_verify kernel/context_tracking.c:261:39: sparse: got struct context_tracking * -- >> arch/x86/kernel/cpu/bugs.c:64:9: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got unsigned long long * @@ arch/x86/kernel/cpu/bugs.c:64:9: sparse: expected void const [noderef] __percpu *__vpp_verify arch/x86/kernel/cpu/bugs.c:64:9: sparse: got unsigned long long * arch/x86/kernel/cpu/bugs.c:74:13: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got unsigned long long * @@ arch/x86/kernel/cpu/bugs.c:74:13: sparse: expected void const [noderef] __percpu *__vpp_verify arch/x86/kernel/cpu/bugs.c:74:13: sparse: got unsigned long long * arch/x86/kernel/cpu/bugs.c:77:9: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got unsigned long long * @@ arch/x86/kernel/cpu/bugs.c:77:9: sparse: expected void const [noderef] __percpu *__vpp_verify arch/x86/kernel/cpu/bugs.c:77:9: sparse: got unsigned long long * arch/x86/kernel/cpu/bugs.c:89:16: sparse: sparse: incorrect type in initializer (different address spaces) @@ expected void const [noderef] __percpu *__vpp_verify @@ got unsigned long long * @@ arch/x86/kernel/cpu/bugs.c:89:16: sparse: expected void const [noderef] __percpu *__vpp_verify arch/x86/kernel/cpu/bugs.c:89:16: sparse: got unsigned long long * vim +126 kernel/context_tracking.c 172114552701b8 Frederic Weisbecker 2022-06-08 115 172114552701b8 Frederic Weisbecker 2022-06-08 116 /* 172114552701b8 Frederic Weisbecker 2022-06-08 117 * Enter an RCU extended quiescent state, which can be either the 172114552701b8 Frederic Weisbecker 2022-06-08 118 * idle loop or adaptive-tickless usermode execution. 172114552701b8 Frederic Weisbecker 2022-06-08 119 * 172114552701b8 Frederic Weisbecker 2022-06-08 120 * We crowbar the ->dynticks_nmi_nesting field to zero to allow for 172114552701b8 Frederic Weisbecker 2022-06-08 121 * the possibility of usermode upcalls having messed up our count 172114552701b8 Frederic Weisbecker 2022-06-08 122 * of interrupt nesting level during the prior busy period. 172114552701b8 Frederic Weisbecker 2022-06-08 123 */ 171476775d32a4 Frederic Weisbecker 2022-06-08 124 static void noinstr ct_kernel_exit(bool user, int offset) 172114552701b8 Frederic Weisbecker 2022-06-08 125 { 172114552701b8 Frederic Weisbecker 2022-06-08 @126 struct context_tracking *ct = this_cpu_ptr(&context_tracking); 172114552701b8 Frederic Weisbecker 2022-06-08 127 172114552701b8 Frederic Weisbecker 2022-06-08 128 WARN_ON_ONCE(ct_dynticks_nmi_nesting() != DYNTICK_IRQ_NONIDLE); 172114552701b8 Frederic Weisbecker 2022-06-08 129 WRITE_ONCE(ct->dynticks_nmi_nesting, 0); 172114552701b8 Frederic Weisbecker 2022-06-08 130 WARN_ON_ONCE(IS_ENABLED(CONFIG_RCU_EQS_DEBUG) && 172114552701b8 Frederic Weisbecker 2022-06-08 131 ct_dynticks_nesting() == 0); 172114552701b8 Frederic Weisbecker 2022-06-08 132 if (ct_dynticks_nesting() != 1) { 172114552701b8 Frederic Weisbecker 2022-06-08 133 // RCU will still be watching, so just do accounting and leave. 172114552701b8 Frederic Weisbecker 2022-06-08 134 ct->dynticks_nesting--; 172114552701b8 Frederic Weisbecker 2022-06-08 135 return; 172114552701b8 Frederic Weisbecker 2022-06-08 136 } 172114552701b8 Frederic Weisbecker 2022-06-08 137 172114552701b8 Frederic Weisbecker 2022-06-08 138 instrumentation_begin(); 172114552701b8 Frederic Weisbecker 2022-06-08 139 lockdep_assert_irqs_disabled(); 172114552701b8 Frederic Weisbecker 2022-06-08 140 trace_rcu_dyntick(TPS("Start"), ct_dynticks_nesting(), 0, ct_dynticks()); 172114552701b8 Frederic Weisbecker 2022-06-08 141 WARN_ON_ONCE(IS_ENABLED(CONFIG_RCU_EQS_DEBUG) && !user && !is_idle_task(current)); 172114552701b8 Frederic Weisbecker 2022-06-08 142 rcu_preempt_deferred_qs(current); 172114552701b8 Frederic Weisbecker 2022-06-08 143 171476775d32a4 Frederic Weisbecker 2022-06-08 144 // instrumentation for the noinstr ct_kernel_exit_state() 171476775d32a4 Frederic Weisbecker 2022-06-08 145 instrument_atomic_write(&ct->state, sizeof(ct->state)); 172114552701b8 Frederic Weisbecker 2022-06-08 146 172114552701b8 Frederic Weisbecker 2022-06-08 147 instrumentation_end(); 172114552701b8 Frederic Weisbecker 2022-06-08 148 WRITE_ONCE(ct->dynticks_nesting, 0); /* Avoid irq-access tearing. */ 172114552701b8 Frederic Weisbecker 2022-06-08 149 // RCU is watching here ... 171476775d32a4 Frederic Weisbecker 2022-06-08 150 ct_kernel_exit_state(offset); 172114552701b8 Frederic Weisbecker 2022-06-08 151 // ... but is no longer watching here. 172114552701b8 Frederic Weisbecker 2022-06-08 152 rcu_dynticks_task_enter(); 172114552701b8 Frederic Weisbecker 2022-06-08 153 } 172114552701b8 Frederic Weisbecker 2022-06-08 154 :::::: The code at line 126 was first introduced by commit :::::: 172114552701b85d5c3b1a089a73ee85d0d7786b rcu/context-tracking: Move RCU-dynticks internal functions to context_tracking :::::: TO: Frederic Weisbecker :::::: CC: Paul E. McKenney -- 0-DAY CI Kernel Test Service https://github.com/intel/lkp-tests/wiki