mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-06 05:06:29 +00:00
c163e40af9
clocksource_delta() has two variants. One with a check for negative motion,
which is only selected by x86. This is a historic leftover as this function
was previously used in the time getter hot paths.
Since 135225a363
timekeeping_cycles_to_ns() has unconditional protection
against this as a by-product of the protection against 64bit math overflow.
clocksource_delta() is only used in the clocksource watchdog and in
timekeeping_advance(). The extra conditional there is not hurting anyone.
Remove the config option and unconditionally prevent negative motion of the
readout.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: John Stultz <jstultz@google.com>
Link: https://lore.kernel.org/all/20241031120328.599430157@linutronix.de
49 lines
1.0 KiB
C
49 lines
1.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _TIMEKEEPING_INTERNAL_H
|
|
#define _TIMEKEEPING_INTERNAL_H
|
|
|
|
#include <linux/clocksource.h>
|
|
#include <linux/spinlock.h>
|
|
#include <linux/time.h>
|
|
|
|
/*
|
|
* timekeeping debug functions
|
|
*/
|
|
#ifdef CONFIG_DEBUG_FS
|
|
|
|
DECLARE_PER_CPU(unsigned long, timekeeping_mg_floor_swaps);
|
|
|
|
static inline void timekeeping_inc_mg_floor_swaps(void)
|
|
{
|
|
this_cpu_inc(timekeeping_mg_floor_swaps);
|
|
}
|
|
|
|
extern void tk_debug_account_sleep_time(const struct timespec64 *t);
|
|
|
|
#else
|
|
|
|
#define tk_debug_account_sleep_time(x)
|
|
|
|
static inline void timekeeping_inc_mg_floor_swaps(void)
|
|
{
|
|
}
|
|
|
|
#endif
|
|
|
|
static inline u64 clocksource_delta(u64 now, u64 last, u64 mask)
|
|
{
|
|
u64 ret = (now - last) & mask;
|
|
|
|
/*
|
|
* Prevent time going backwards by checking the MSB of mask in
|
|
* the result. If set, return 0.
|
|
*/
|
|
return ret & ~(mask >> 1) ? 0 : ret;
|
|
}
|
|
|
|
/* Semi public for serialization of non timekeeper VDSO updates. */
|
|
unsigned long timekeeper_lock_irqsave(void);
|
|
void timekeeper_unlock_irqrestore(unsigned long flags);
|
|
|
|
#endif /* _TIMEKEEPING_INTERNAL_H */
|