lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <202512111251.xMUT4l7V-lkp@intel.com>
Date: Thu, 11 Dec 2025 12:57:24 +0800
From: kernel test robot <lkp@...el.com>
To: Nam Cao <namcao@...utronix.de>
Cc: oe-kbuild-all@...ts.linux.dev, linux-kernel@...r.kernel.org,
	Ingo Molnar <mingo@...nel.org>,
	Thomas Gleixner <tglx@...utronix.de>
Subject: kernel/time/sched_clock.c:219:13: sparse: sparse: dereference of
 noderef expression

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   d358e5254674b70f34c847715ca509e46eb81e6f
commit: 04257da0c99c9d4ff7c5bb93046482e1f7d34938 hrtimers: Make callback function pointer private
date:   8 months ago
config: arc-randconfig-r122-20251211 (https://download.01.org/0day-ci/archive/20251211/202512111251.xMUT4l7V-lkp@intel.com/config)
compiler: arc-linux-gcc (GCC) 8.5.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20251211/202512111251.xMUT4l7V-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 <lkp@...el.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202512111251.xMUT4l7V-lkp@intel.com/

sparse warnings: (new ones prefixed by >>)
>> kernel/time/sched_clock.c:219:13: sparse: sparse: dereference of noderef expression

vim +219 kernel/time/sched_clock.c

112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  176  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  177  void __init
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  178  sched_clock_register(u64 (*read)(void), int bits, unsigned long rate)
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  179  {
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  180  	u64 res, wrap, new_mask, new_epoch, cyc, ns;
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  181  	u32 new_mult, new_shift;
2707745533d6d38 kernel/time/sched_clock.c     Paul Cercueil     2020-01-07  182  	unsigned long r, flags;
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  183  	char r_unit;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  184  	struct clock_read_data rd;
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  185  
c115739da801ea1 arch/arm/kernel/sched_clock.c Rob Herring       2013-02-08  186  	if (cd.rate > rate)
c115739da801ea1 arch/arm/kernel/sched_clock.c Rob Herring       2013-02-08  187  		return;
c115739da801ea1 arch/arm/kernel/sched_clock.c Rob Herring       2013-02-08  188  
2707745533d6d38 kernel/time/sched_clock.c     Paul Cercueil     2020-01-07  189  	/* Cannot register a sched_clock with interrupts on */
2707745533d6d38 kernel/time/sched_clock.c     Paul Cercueil     2020-01-07  190  	local_irq_save(flags);
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  191  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  192  	/* Calculate the mult/shift to convert counter ticks to ns. */
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  193  	clocks_calc_mult_shift(&new_mult, &new_shift, rate, NSEC_PER_SEC, 3600);
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  194  
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  195  	new_mask = CLOCKSOURCE_MASK(bits);
8710e914027e4f6 kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  196  	cd.rate = rate;
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  197  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  198  	/* Calculate how many nanosecs until we risk wrapping */
fb82fe2fe858874 kernel/time/sched_clock.c     John Stultz       2015-03-11  199  	wrap = clocks_calc_max_nsecs(new_mult, new_shift, 0, new_mask, NULL);
8710e914027e4f6 kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  200  	cd.wrap_kt = ns_to_ktime(wrap);
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  201  
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  202  	rd = cd.read_data[0];
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  203  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  204  	/* Update epoch for new counter and update 'epoch_ns' from old counter*/
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  205  	new_epoch = read();
13dbeb384d2d3aa kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  206  	cyc = cd.actual_read_sched_clock();
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  207  	ns = rd.epoch_ns + cyc_to_ns((cyc - rd.epoch_cyc) & rd.sched_clock_mask, rd.mult, rd.shift);
13dbeb384d2d3aa kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  208  	cd.actual_read_sched_clock = read;
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  209  
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  210  	rd.read_sched_clock	= read;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  211  	rd.sched_clock_mask	= new_mask;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  212  	rd.mult			= new_mult;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  213  	rd.shift		= new_shift;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  214  	rd.epoch_cyc		= new_epoch;
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  215  	rd.epoch_ns		= ns;
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  216  
1809bfa44e1019e kernel/time/sched_clock.c     Daniel Thompson   2015-03-26  217  	update_clock_read_data(&rd);
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  218  
1b8955bc5ac5750 kernel/time/sched_clock.c     David Engraf      2017-02-17 @219  	if (sched_clock_timer.function != NULL) {
1b8955bc5ac5750 kernel/time/sched_clock.c     David Engraf      2017-02-17  220  		/* update timeout for clock wrap */
2c8bd58812ee3db kernel/time/sched_clock.c     Ahmed S. Darwish  2020-03-09  221  		hrtimer_start(&sched_clock_timer, cd.wrap_kt,
2c8bd58812ee3db kernel/time/sched_clock.c     Ahmed S. Darwish  2020-03-09  222  			      HRTIMER_MODE_REL_HARD);
1b8955bc5ac5750 kernel/time/sched_clock.c     David Engraf      2017-02-17  223  	}
1b8955bc5ac5750 kernel/time/sched_clock.c     David Engraf      2017-02-17  224  
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  225  	r = rate;
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  226  	if (r >= 4000000) {
92067440f1311df kernel/time/sched_clock.c     Maciej W. Rozycki 2022-04-24  227  		r = DIV_ROUND_CLOSEST(r, 1000000);
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  228  		r_unit = 'M';
f4b62e1e1137507 kernel/time/sched_clock.c     Maciej W. Rozycki 2022-04-24  229  	} else if (r >= 4000) {
92067440f1311df kernel/time/sched_clock.c     Maciej W. Rozycki 2022-04-24  230  		r = DIV_ROUND_CLOSEST(r, 1000);
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  231  		r_unit = 'k';
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  232  	} else {
2f0778afac79bd8 arch/arm/kernel/sched_clock.c Marc Zyngier      2011-12-15  233  		r_unit = ' ';
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  234  	}
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  235  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  236  	/* Calculate the ns resolution of this counter */
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  237  	res = cyc_to_ns(1ULL, new_mult, new_shift);
5ae8aabeaec3fe6 kernel/time/sched_clock.c     Stephen Boyd      2014-02-17  238  
a08ca5d1089da03 kernel/time/sched_clock.c     Stephen Boyd      2013-07-18  239  	pr_info("sched_clock: %u bits at %lu%cHz, resolution %lluns, wraps every %lluns\n",
a08ca5d1089da03 kernel/time/sched_clock.c     Stephen Boyd      2013-07-18  240  		bits, r, r_unit, res, wrap);
112f38a4a31668e arch/arm/kernel/sched_clock.c Russell King      2010-12-15  241  
32fea568aec5b73 kernel/time/sched_clock.c     Ingo Molnar       2015-03-27  242  	/* Enable IRQ time accounting if we have a fast enough sched_clock() */
a42c362980430be arch/arm/kernel/sched_clock.c Russell King      2012-09-09  243  	if (irqtime > 0 || (irqtime == -1 && rate >= 1000000))
a42c362980430be arch/arm/kernel/sched_clock.c Russell King      2012-09-09  244  		enable_sched_clock_irqtime();
a42c362980430be arch/arm/kernel/sched_clock.c Russell King      2012-09-09  245  
2707745533d6d38 kernel/time/sched_clock.c     Paul Cercueil     2020-01-07  246  	local_irq_restore(flags);
2707745533d6d38 kernel/time/sched_clock.c     Paul Cercueil     2020-01-07  247  
d75f773c86a2b8b kernel/time/sched_clock.c     Sakari Ailus      2019-03-25  248  	pr_debug("Registered %pS as sched_clock source\n", read);
2f0778afac79bd8 arch/arm/kernel/sched_clock.c Marc Zyngier      2011-12-15  249  }
2f0778afac79bd8 arch/arm/kernel/sched_clock.c Marc Zyngier      2011-12-15  250  

:::::: The code at line 219 was first introduced by commit
:::::: 1b8955bc5ac575009835e371ae55e7f3af2197a9 timers, sched_clock: Update timeout for clock wrap

:::::: TO: David Engraf <david.engraf@...go.com>
:::::: CC: John Stultz <john.stultz@...aro.org>

-- 
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ