cregit-Linux how code gets into the kernel

Release 4.7 include/linux/tick.h

Directory: include/linux
/*
 * 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 gleixnerthomas gleixner8100.00%2100.00%
Total8100.00%2100.00%


static inline void tick_suspend_local(void) { }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar450.00%133.33%
thomas gleixnerthomas gleixner337.50%133.33%
rafael j. wysockirafael j. wysocki112.50%133.33%
Total8100.00%3100.00%


static inline void tick_resume_local(void) { }

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner450.00%250.00%
ingo molnaringo molnar337.50%125.00%
rafael j. wysockirafael j. wysocki112.50%125.00%
Total8100.00%4100.00%


static inline void tick_handover_do_timer(void) { }

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner787.50%150.00%
rafael j. wysockirafael j. wysocki112.50%150.00%
Total8100.00%2100.00%


static inline void tick_cleanup_dead_cpu(int cpu) { }

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner666.67%266.67%
rafael j. wysockirafael j. wysocki333.33%133.33%
Total9100.00%3100.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 gleixnerthomas gleixner787.50%150.00%
rafael j. wysockirafael j. wysocki112.50%150.00%
Total8100.00%2100.00%


static inline void tick_unfreeze(void) { }

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner675.00%150.00%
rafael j. wysockirafael 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 gleixnerthomas gleixner675.00%133.33%
frederic weisbeckerfrederic 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. murthypreeti 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 gleixnerthomas 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 gleixnerthomas 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 gleixnerthomas gleixner14100.00%1100.00%
Total14100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner14100.00%1100.00%
Total14100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas 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 gleixnerthomas 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 gleixnerthomas 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 int tick_nohz_tick_stopped(void); extern void tick_nohz_idle_enter(void); extern void tick_nohz_idle_exit(void); extern void tick_nohz_irq_exit(void); extern ktime_t tick_nohz_get_sleep_length(void); 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); #else /* !CONFIG_NO_HZ_COMMON */ #define tick_nohz_enabled (0)
static inline int tick_nohz_tick_stopped(void) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker12100.00%1100.00%
Total12100.00%1100.00%


static inline void tick_nohz_idle_enter(void) { }

Contributors

PersonTokensPropCommitsCommitProp
thomas gleixnerthomas gleixner562.50%133.33%
frederic weisbeckerfrederic weisbecker337.50%266.67%
Total8100.00%3100.00%


static inline void tick_nohz_idle_exit(void) { }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker8100.00%1100.00%
Total8100.00%1100.00%


static inline ktime_t tick_nohz_get_sleep_length(void) { ktime_t len = { .tv64 = NSEC_PER_SEC/HZ }; return len; }

Contributors

PersonTokensPropCommitsCommitProp
len brownlen brown24100.00%1100.00%
Total24100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
venkatesh pallipadivenkatesh 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 venarjan van de ven18100.00%1100.00%
Total18100.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; extern cpumask_var_t housekeeping_mask;
static inline bool tick_nohz_full_enabled(void) { if (!context_tracking_is_enabled()) return false; return tick_nohz_full_running; }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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 metcalfchris metcalf26100.00%1100.00%
Total26100.00%1100.00%


static inline int housekeeping_any_cpu(void) { return cpumask_any_and(housekeeping_mask, cpu_online_mask); }

Contributors

PersonTokensPropCommitsCommitProp
vatika harlalkavatika harlalka17100.00%1100.00%
Total17100.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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic weisbecker28100.00%1100.00%
Total28100.00%1100.00%

extern void tick_nohz_full_kick_cpu(int cpu); extern void __tick_nohz_task_switch(void); #else
static inline int housekeeping_any_cpu(void) { return smp_processor_id(); }

Contributors

PersonTokensPropCommitsCommitProp
vatika harlalkavatika harlalka13100.00%1100.00%
Total13100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker12100.00%1100.00%
Total12100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker13100.00%3100.00%
Total13100.00%3100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
chris metcalfchris metcalf11100.00%1100.00%
Total11100.00%1100.00%


static inline void tick_dep_set(enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker10100.00%1100.00%
Total10100.00%1100.00%


static inline void tick_dep_clear(enum tick_dep_bits bit) { }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker10100.00%1100.00%
Total10100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker13100.00%1100.00%
Total13100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic 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
frederic weisbeckerfrederic weisbecker15100.00%1100.00%
Total15100.00%1100.00%


static inline void tick_nohz_full_kick_cpu(int cpu) { }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker9100.00%1100.00%
Total9100.00%1100.00%


static inline void __tick_nohz_task_switch(void) { }

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker8100.00%3100.00%
Total8100.00%3100.00%

#endif
static inline const struct cpumask *housekeeping_cpumask(void) { #ifdef CONFIG_NO_HZ_FULL if (tick_nohz_full_enabled()) return housekeeping_mask; #endif return cpu_possible_mask; }

Contributors

PersonTokensPropCommitsCommitProp
chris metcalfchris metcalf28100.00%1100.00%
Total28100.00%1100.00%


static inline bool is_housekeeping_cpu(int cpu) { #ifdef CONFIG_NO_HZ_FULL if (tick_nohz_full_enabled()) return cpumask_test_cpu(cpu, housekeeping_mask); #endif return true; }

Contributors

PersonTokensPropCommitsCommitProp
paul e. mckenneypaul e. mckenney31100.00%1100.00%
Total31100.00%1100.00%


static inline void housekeeping_affine(struct task_struct *t) { #ifdef CONFIG_NO_HZ_FULL if (tick_nohz_full_enabled()) set_cpus_allowed_ptr(t, housekeeping_mask); #endif }

Contributors

PersonTokensPropCommitsCommitProp
paul e. mckenneypaul e. mckenney29100.00%1100.00%
Total29100.00%1100.00%


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

Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker17100.00%2100.00%
Total17100.00%2100.00%

#endif

Overall Contributors

PersonTokensPropCommitsCommitProp
frederic weisbeckerfrederic weisbecker64750.31%2041.67%
thomas gleixnerthomas gleixner28121.85%1225.00%
paul e. mckenneypaul e. mckenney675.21%12.08%
chris metcalfchris metcalf655.05%24.17%
rafael j. wysockirafael j. wysocki393.03%12.08%
preeti u. murthypreeti u. murthy322.49%12.08%
venkatesh pallipadivenkatesh pallipadi302.33%24.17%
vatika harlalkavatika harlalka302.33%12.08%
len brownlen brown302.33%12.08%
arjan van de venarjan van de ven302.33%12.08%
ingo molnaringo molnar151.17%12.08%
martin schwidefskymartin schwidefsky100.78%24.17%
jean delvarejean delvare70.54%12.08%
youquan songyouquan song20.16%12.08%
kees cookkees cook10.08%12.08%
Total1286100.00%48100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}