cregit-Linux how code gets into the kernel

Release 4.17 include/linux/tick.h

Directory: include/linux
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Tick related global functions
 */
#ifndef _LINUX_TICK_H

#define _LINUX_TICK_H

#include <linux/clockchips.h>
#include <linux/irqflags.h>
#include <linux/percpu.h>
#include <linux/context_tracking_state.h>
#include <linux/cpumask.h>
#include <linux/sched.h>

#ifdef CONFIG_GENERIC_CLOCKEVENTS
extern void __init tick_init(void);
/* Should be core only, but ARM BL switcher requires it */
extern void tick_suspend_local(void);
/* Should be core only, but XEN resume magic and ARM BL switcher require it */
extern void tick_resume_local(void);
extern void tick_handover_do_timer(void);
extern void tick_cleanup_dead_cpu(int cpu);
#else /* CONFIG_GENERIC_CLOCKEVENTS */

static inline void tick_init(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner8100.00%2100.00%
Total8100.00%2100.00%


static inline void tick_suspend_local(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Ingo Molnar450.00%133.33%
Thomas Gleixner337.50%133.33%
Rafael J. Wysocki112.50%133.33%
Total8100.00%3100.00%


static inline void tick_resume_local(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner450.00%133.33%
Ingo Molnar337.50%133.33%
Rafael J. Wysocki112.50%133.33%
Total8100.00%3100.00%


static inline void tick_handover_do_timer(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner787.50%150.00%
Rafael J. Wysocki112.50%150.00%
Total8100.00%2100.00%


static inline void tick_cleanup_dead_cpu(int cpu) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner666.67%150.00%
Rafael J. Wysocki333.33%150.00%
Total9100.00%2100.00%

#endif /* !CONFIG_GENERIC_CLOCKEVENTS */ #if defined(CONFIG_GENERIC_CLOCKEVENTS) && defined(CONFIG_SUSPEND) extern void tick_freeze(void); extern void tick_unfreeze(void); #else
static inline void tick_freeze(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner787.50%150.00%
Rafael J. Wysocki112.50%150.00%
Total8100.00%2100.00%


static inline void tick_unfreeze(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner675.00%150.00%
Rafael J. Wysocki225.00%150.00%
Total8100.00%2100.00%

#endif #ifdef CONFIG_TICK_ONESHOT extern void tick_irq_enter(void); # ifndef arch_needs_cpu # define arch_needs_cpu() (0) # endif # else
static inline void tick_irq_enter(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner675.00%133.33%
Frédéric Weisbecker225.00%266.67%
Total8100.00%3100.00%

#endif #if defined(CONFIG_GENERIC_CLOCKEVENTS_BROADCAST) && defined(CONFIG_TICK_ONESHOT) extern void hotplug_cpu__broadcast_tick_pull(int dead_cpu); #else
static inline void hotplug_cpu__broadcast_tick_pull(int dead_cpu) { }

Contributors

PersonTokensPropCommitsCommitProp
Preeti U. Murthy9100.00%1100.00%
Total9100.00%1100.00%

#endif enum tick_broadcast_mode { TICK_BROADCAST_OFF, TICK_BROADCAST_ON, TICK_BROADCAST_FORCE, }; enum tick_broadcast_state { TICK_BROADCAST_EXIT, TICK_BROADCAST_ENTER, }; #ifdef CONFIG_GENERIC_CLOCKEVENTS_BROADCAST extern void tick_broadcast_control(enum tick_broadcast_mode mode); #else
static inline void tick_broadcast_control(enum tick_broadcast_mode mode) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner10100.00%1100.00%
Total10100.00%1100.00%

#endif /* BROADCAST */ #ifdef CONFIG_GENERIC_CLOCKEVENTS extern int tick_broadcast_oneshot_control(enum tick_broadcast_state state); #else
static inline int tick_broadcast_oneshot_control(enum tick_broadcast_state state) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner14100.00%1100.00%
Total14100.00%1100.00%

#endif
static inline void tick_broadcast_enable(void) { tick_broadcast_control(TICK_BROADCAST_ON); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner14100.00%1100.00%
Total14100.00%1100.00%


static inline void tick_broadcast_disable(void) { tick_broadcast_control(TICK_BROADCAST_OFF); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner14100.00%1100.00%
Total14100.00%1100.00%


static inline void tick_broadcast_force(void) { tick_broadcast_control(TICK_BROADCAST_FORCE); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner14100.00%1100.00%
Total14100.00%1100.00%


static inline int tick_broadcast_enter(void) { return tick_broadcast_oneshot_control(TICK_BROADCAST_ENTER); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_broadcast_exit(void) { tick_broadcast_oneshot_control(TICK_BROADCAST_EXIT); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner14100.00%1100.00%
Total14100.00%1100.00%

enum tick_dep_bits { TICK_DEP_BIT_POSIX_TIMER = 0, TICK_DEP_BIT_PERF_EVENTS = 1, TICK_DEP_BIT_SCHED = 2, TICK_DEP_BIT_CLOCK_UNSTABLE = 3 }; #define TICK_DEP_MASK_NONE 0 #define TICK_DEP_MASK_POSIX_TIMER (1 << TICK_DEP_BIT_POSIX_TIMER) #define TICK_DEP_MASK_PERF_EVENTS (1 << TICK_DEP_BIT_PERF_EVENTS) #define TICK_DEP_MASK_SCHED (1 << TICK_DEP_BIT_SCHED) #define TICK_DEP_MASK_CLOCK_UNSTABLE (1 << TICK_DEP_BIT_CLOCK_UNSTABLE) #ifdef CONFIG_NO_HZ_COMMON extern bool tick_nohz_enabled; extern bool tick_nohz_tick_stopped(void); extern bool tick_nohz_tick_stopped_cpu(int cpu); extern void tick_nohz_idle_stop_tick(void); extern void tick_nohz_idle_retain_tick(void); extern void tick_nohz_idle_restart_tick(void); extern void tick_nohz_idle_enter(void); extern void tick_nohz_idle_exit(void); extern void tick_nohz_irq_exit(void); extern bool tick_nohz_idle_got_tick(void); extern ktime_t tick_nohz_get_sleep_length(ktime_t *delta_next); extern unsigned long tick_nohz_get_idle_calls(void); extern unsigned long tick_nohz_get_idle_calls_cpu(int cpu); extern u64 get_cpu_idle_time_us(int cpu, u64 *last_update_time); extern u64 get_cpu_iowait_time_us(int cpu, u64 *last_update_time);
static inline void tick_nohz_idle_stop_tick_protected(void) { local_irq_disable(); tick_nohz_idle_stop_tick(); local_irq_enable(); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki18100.00%1100.00%
Total18100.00%1100.00%

#else /* !CONFIG_NO_HZ_COMMON */ #define tick_nohz_enabled (0)
static inline int tick_nohz_tick_stopped(void) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker12100.00%1100.00%
Total12100.00%1100.00%


static inline int tick_nohz_tick_stopped_cpu(int cpu) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker13100.00%1100.00%
Total13100.00%1100.00%


static inline void tick_nohz_idle_stop_tick(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki8100.00%1100.00%
Total8100.00%1100.00%


static inline void tick_nohz_idle_retain_tick(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki8100.00%1100.00%
Total8100.00%1100.00%


static inline void tick_nohz_idle_restart_tick(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki8100.00%1100.00%
Total8100.00%1100.00%


static inline void tick_nohz_idle_enter(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner562.50%133.33%
Frédéric Weisbecker337.50%266.67%
Total8100.00%3100.00%


static inline void tick_nohz_idle_exit(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker8100.00%1100.00%
Total8100.00%1100.00%


static inline bool tick_nohz_idle_got_tick(void) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki12100.00%1100.00%
Total12100.00%1100.00%


static inline ktime_t tick_nohz_get_sleep_length(ktime_t *delta_next) { *delta_next = TICK_NSEC; return *delta_next; }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki1050.00%133.33%
Len Brown945.00%133.33%
Thomas Gleixner15.00%133.33%
Total20100.00%3100.00%


static inline u64 get_cpu_idle_time_us(int cpu, u64 *unused) { return -1; }

Contributors

PersonTokensPropCommitsCommitProp
Venkatesh Pallipadi18100.00%2100.00%
Total18100.00%2100.00%


static inline u64 get_cpu_iowait_time_us(int cpu, u64 *unused) { return -1; }

Contributors

PersonTokensPropCommitsCommitProp
Arjan van de Ven18100.00%1100.00%
Total18100.00%1100.00%


static inline void tick_nohz_idle_stop_tick_protected(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki8100.00%1100.00%
Total8100.00%1100.00%

#endif /* !CONFIG_NO_HZ_COMMON */ #ifdef CONFIG_NO_HZ_FULL extern bool tick_nohz_full_running; extern cpumask_var_t tick_nohz_full_mask;
static inline bool tick_nohz_full_enabled(void) { if (!context_tracking_is_enabled()) return false; return tick_nohz_full_running; }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker21100.00%3100.00%
Total21100.00%3100.00%


static inline bool tick_nohz_full_cpu(int cpu) { if (!tick_nohz_full_enabled()) return false; return cpumask_test_cpu(cpu, tick_nohz_full_mask); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker27100.00%3100.00%
Total27100.00%3100.00%


static inline void tick_nohz_full_add_cpus_to(struct cpumask *mask) { if (tick_nohz_full_enabled()) cpumask_or(mask, mask, tick_nohz_full_mask); }

Contributors

PersonTokensPropCommitsCommitProp
Chris Metcalf26100.00%1100.00%
Total26100.00%1100.00%

extern void tick_nohz_dep_set(enum tick_dep_bits bit); extern void tick_nohz_dep_clear(enum tick_dep_bits bit); extern void tick_nohz_dep_set_cpu(int cpu, enum tick_dep_bits bit); extern void tick_nohz_dep_clear_cpu(int cpu, enum tick_dep_bits bit); extern void tick_nohz_dep_set_task(struct task_struct *tsk, enum tick_dep_bits bit); extern void tick_nohz_dep_clear_task(struct task_struct *tsk, enum tick_dep_bits bit); extern void tick_nohz_dep_set_signal(struct signal_struct *signal, enum tick_dep_bits bit); extern void tick_nohz_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit); /* * The below are tick_nohz_[set,clear]_dep() wrappers that optimize off-cases * on top of static keys. */
static inline void tick_dep_set(enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_set(bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker21100.00%1100.00%
Total21100.00%1100.00%


static inline void tick_dep_clear(enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_clear(bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker21100.00%1100.00%
Total21100.00%1100.00%


static inline void tick_dep_set_cpu(int cpu, enum tick_dep_bits bit) { if (tick_nohz_full_cpu(cpu)) tick_nohz_dep_set_cpu(cpu, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%


static inline void tick_dep_clear_cpu(int cpu, enum tick_dep_bits bit) { if (tick_nohz_full_cpu(cpu)) tick_nohz_dep_clear_cpu(cpu, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%


static inline void tick_dep_set_task(struct task_struct *tsk, enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_set_task(tsk, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%


static inline void tick_dep_clear_task(struct task_struct *tsk, enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_clear_task(tsk, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%


static inline void tick_dep_set_signal(struct signal_struct *signal, enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_set_signal(signal, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%


static inline void tick_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit) { if (tick_nohz_full_enabled()) tick_nohz_dep_clear_signal(signal, bit); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker28100.00%1100.00%
Total28100.00%1100.00%

extern void tick_nohz_full_kick_cpu(int cpu); extern void __tick_nohz_task_switch(void); extern void __init tick_nohz_full_setup(cpumask_var_t cpumask); #else
static inline bool tick_nohz_full_enabled(void) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker12100.00%1100.00%
Total12100.00%1100.00%


static inline bool tick_nohz_full_cpu(int cpu) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker13100.00%3100.00%
Total13100.00%3100.00%


static inline void tick_nohz_full_add_cpus_to(struct cpumask *mask) { }

Contributors

PersonTokensPropCommitsCommitProp
Chris Metcalf11100.00%1100.00%
Total11100.00%1100.00%


static inline void tick_dep_set(enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker10100.00%1100.00%
Total10100.00%1100.00%


static inline void tick_dep_clear(enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker10100.00%1100.00%
Total10100.00%1100.00%


static inline void tick_dep_set_cpu(int cpu, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker13100.00%1100.00%
Total13100.00%1100.00%


static inline void tick_dep_clear_cpu(int cpu, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker13100.00%1100.00%
Total13100.00%1100.00%


static inline void tick_dep_set_task(struct task_struct *tsk, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_dep_clear_task(struct task_struct *tsk, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_dep_set_signal(struct signal_struct *signal, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_dep_clear_signal(struct signal_struct *signal, enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_nohz_full_kick_cpu(int cpu) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker9100.00%1100.00%
Total9100.00%1100.00%


static inline void __tick_nohz_task_switch(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker8100.00%3100.00%
Total8100.00%3100.00%


static inline void tick_nohz_full_setup(cpumask_var_t cpumask) { }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker9100.00%1100.00%
Total9100.00%1100.00%

#endif
static inline void tick_nohz_task_switch(void) { if (tick_nohz_full_enabled()) __tick_nohz_task_switch(); }

Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker17100.00%2100.00%
Total17100.00%2100.00%

#endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Frédéric Weisbecker68652.41%2339.66%
Thomas Gleixner28221.54%1322.41%
Rafael J. Wysocki15011.46%712.07%
Chris Metcalf372.83%11.72%
Preeti U. Murthy322.44%11.72%
Venkatesh Pallipadi302.29%23.45%
Arjan van de Ven302.29%11.72%
Ingo Molnar151.15%11.72%
Len Brown141.07%11.72%
Martin Schwidefsky100.76%23.45%
Joel Fernandes90.69%11.72%
Jean Delvare70.53%11.72%
Paul E. McKenney30.23%11.72%
Youquan Song20.15%11.72%
Greg Kroah-Hartman10.08%11.72%
Kees Cook10.08%11.72%
Total1309100.00%58100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.