Lines Matching +full:no +full:- +full:tick +full:- +full:in +full:- +full:suspend
1 // SPDX-License-Identifier: GPL-2.0
3 * This file contains the base functions to manage periodic tick
6 * Copyright(C) 2005-2006, Thomas Gleixner <tglx@linutronix.de>
7 * Copyright(C) 2005-2007, Red Hat, Inc., Ingo Molnar
8 * Copyright(C) 2006-2007, Timesys Corp., Thomas Gleixner
24 #include "tick-internal.h"
27 * Tick devices
31 * Tick next event: keeps track of the tick time. It's updated by the
32 * CPU which handles the tick and protected by jiffies_lock. There is
33 * no requirement to write hold the jiffies seqcount for it.
46 * 2) Hand off the duty in the NOHZ idle case by setting the value to
58 static int tick_do_timer_boot_cpu __read_mostly = -1;
70 * tick_is_oneshot_available - check for a oneshot capable event device
76 if (!dev || !(dev->features & CLOCK_EVT_FEAT_ONESHOT))
78 if (!(dev->features & CLOCK_EVT_FEAT_C3STOP))
84 * Periodic tick
92 /* Keep track of the next tick event */
111 ktime_t next = dev->next_event;
117 * update_process_times() -> run_local_timers() ->
120 if (IS_ENABLED(CONFIG_TICK_ONESHOT) && dev->event_handler != tick_handle_periodic)
135 * Have to be careful here. If we're in oneshot mode,
136 * before we call tick_periodic() in a loop, we need
138 * Otherwise we could get trapped in an infinite
149 * Setup the device for a periodic tick
159 if ((dev->features & CLOCK_EVT_FEAT_PERIODIC) &&
182 * Setup the tick device
194 if (!td->evtdev) {
196 * If no cpu took the do_timer update, assign it to
204 * The boot CPU may be nohz_full, in which case the
211 } else if (tick_do_timer_boot_cpu != -1 && !tick_nohz_full_cpu(cpu)) {
212 tick_do_timer_boot_cpu = -1;
214 * The boot CPU will stay in periodic (NOHZ disabled)
220 * check in tick_periodic() but this race is harmless.
227 * Startup in periodic mode first.
229 td->mode = TICKDEV_MODE_PERIODIC;
231 handler = td->evtdev->event_handler;
232 next_event = td->evtdev->next_event;
233 td->evtdev->event_handler = clockevents_handle_noop;
236 td->evtdev = newdev;
242 if (!cpumask_equal(newdev->cpumask, cpumask))
243 irq_set_affinity(newdev->irq, cpumask);
248 * This allows us to handle this x86 misfeature in a generic
255 if (td->mode == TICKDEV_MODE_PERIODIC)
266 clockevents_exchange_device(td->evtdev, newdev);
268 if (newdev->features & CLOCK_EVT_FEAT_ONESHOT)
275 if (!cpumask_test_cpu(cpu, newdev->cpumask))
277 if (cpumask_equal(newdev->cpumask, cpumask_of(cpu)))
280 if (newdev->irq >= 0 && !irq_can_set_affinity(newdev->irq))
283 if (curdev && cpumask_equal(curdev->cpumask, cpumask_of(cpu)))
292 if (!(newdev->features & CLOCK_EVT_FEAT_ONESHOT)) {
293 if (curdev && (curdev->features & CLOCK_EVT_FEAT_ONESHOT))
301 * rating than a non-CPU local device
304 newdev->rating > curdev->rating ||
305 !cpumask_equal(curdev->cpumask, newdev->cpumask);
333 curdev = td->evtdev;
338 if (!try_module_get(newdev->owner))
352 if (newdev->features & CLOCK_EVT_FEAT_ONESHOT)
364 * tick_broadcast_oneshot_control - Enter/exit broadcast oneshot mode
368 * Returns 0 on success, -EBUSY if the cpu is used to broadcast wakeups.
378 if (!(td->evtdev->features & CLOCK_EVT_FEAT_C3STOP))
391 * Stop the tick and transfer the timekeeping job away from a dying cpu.
397 * safely hand over its duty. Also all online CPUs are in stop
398 * machine, guaranteed not to be idle, therefore there is no
423 struct clock_event_device *dev = td->evtdev;
425 td->mode = TICKDEV_MODE_PERIODIC;
433 dev->event_handler = clockevents_handle_noop;
434 td->evtdev = NULL;
440 * tick_suspend_local - Suspend the local tick device
444 * No locks required. Nothing can change the per cpu device.
450 clockevents_shutdown(td->evtdev);
454 * tick_resume_local - Resume the local tick device
458 * No locks required. Nothing can change the per cpu device.
465 clockevents_tick_resume(td->evtdev);
467 if (td->mode == TICKDEV_MODE_PERIODIC)
468 tick_setup_periodic(td->evtdev, 0);
482 * tick_suspend - Suspend the tick and the broadcast device
488 * No locks required. Nothing can change the per cpu device.
497 * tick_resume - Resume the tick and the broadcast device
502 * No locks required. Nothing can change the per cpu device.
515 * tick_freeze - Suspend the local tick and (possibly) timekeeping.
518 * suspend timekeeping. Otherwise suspend the local tick.
542 * tick_unfreeze - Resume the local tick and (possibly) timekeeping.
545 * timekeeping. Otherwise resume the local tick.
565 tick_freeze_depth--;
572 * tick_init - initialize the tick control