From: Peter Zijlstra Date: Tue, 24 Feb 2026 16:35:37 +0000 (+0100) Subject: hrtimer: Avoid pointless reprogramming in __hrtimer_start_range_ns() X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=d19ff16c11db38f3ee179d72751fb9b340174330;p=thirdparty%2Fkernel%2Flinux.git hrtimer: Avoid pointless reprogramming in __hrtimer_start_range_ns() Much like hrtimer_reprogram(), skip programming if the cpu_base is running the hrtimer interrupt. Signed-off-by: Peter Zijlstra (Intel) Signed-off-by: Thomas Gleixner Signed-off-by: Peter Zijlstra (Intel) Reviewed-by: Juri Lelli Reviewed-by: Thomas Gleixner Link: https://patch.msgid.link/20260224163429.069535561@kernel.org --- diff --git a/kernel/time/hrtimer.c b/kernel/time/hrtimer.c index 860af7a584289..3088db419aa66 100644 --- a/kernel/time/hrtimer.c +++ b/kernel/time/hrtimer.c @@ -1269,6 +1269,14 @@ static int __hrtimer_start_range_ns(struct hrtimer *timer, ktime_t tim, } first = enqueue_hrtimer(timer, new_base, mode); + + /* + * If the hrtimer interrupt is running, then it will reevaluate the + * clock bases and reprogram the clock event device. + */ + if (new_base->cpu_base->in_hrtirq) + return false; + if (!force_local) { /* * If the current CPU base is online, then the timer is