// SPDX-License-Identifier: GPL-2.0 /* * Timer tick function for architectures that lack generic clockevents, * consolidated here from m68k/ia64/parisc/arm. */ #include <linux/irq.h> #include <linux/profile.h> #include <linux/timekeeper_internal.h> #include "tick-internal.h" /** * legacy_timer_tick() - advances the timekeeping infrastructure * @ticks: number of ticks, that have elapsed since the last call. * * This is used by platforms that have not been converted to * generic clockevents. * * If 'ticks' is zero, the CPU is not handling timekeeping, so * only perform process accounting and profiling. * * Must be called with interrupts disabled. */ void legacy_timer_tick(unsigned long ticks) { if (ticks) { raw_spin_lock(&jiffies_lock); write_seqcount_begin(&jiffies_seq); do_timer(ticks); write_seqcount_end(&jiffies_seq); raw_spin_unlock(&jiffies_lock); update_wall_time(); } update_process_times(user_mode(get_irq_regs())); profile_tick(CPU_PROFILING); }