tick/sched: Combine WARN_ON_ONCE and print_once

When the WARN_ON_ONCE() triggers, the printk() of the additional
information related to the warning will not happen in print level
"warn". When reading dmesg with a restriction to level "warn", the
information published by the printk_once() will not show up there.

Transform WARN_ON_ONCE() and printk_once() into a WARN_ONCE().

Signed-off-by: Anna-Maria Behnsen <anna-maria@linutronix.de>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Frederic Weisbecker <frederic@kernel.org>
Link: https://lore.kernel.org/r/20240610103552.25252-1-anna-maria@linutronix.de
This commit is contained in:
Anna-Maria Behnsen 2024-06-10 12:35:52 +02:00 committed by Thomas Gleixner
parent 2b83be20ae
commit 59dbee7d4d

View File

@ -1026,10 +1026,10 @@ static void tick_nohz_stop_tick(struct tick_sched *ts, int cpu)
if (expires == KTIME_MAX || ts->next_tick == hrtimer_get_expires(&ts->sched_timer)) if (expires == KTIME_MAX || ts->next_tick == hrtimer_get_expires(&ts->sched_timer))
return; return;
WARN_ON_ONCE(1); WARN_ONCE(1, "basemono: %llu ts->next_tick: %llu dev->next_event: %llu "
printk_once("basemono: %llu ts->next_tick: %llu dev->next_event: %llu timer->active: %d timer->expires: %llu\n", "timer->active: %d timer->expires: %llu\n", basemono, ts->next_tick,
basemono, ts->next_tick, dev->next_event, dev->next_event, hrtimer_active(&ts->sched_timer),
hrtimer_active(&ts->sched_timer), hrtimer_get_expires(&ts->sched_timer)); hrtimer_get_expires(&ts->sched_timer));
} }
/* /*