cregit-Linux how code gets into the kernel

Release 4.7 include/linux/timer.h

Directory: include/linux
#ifndef _LINUX_TIMER_H

#define _LINUX_TIMER_H

#include <linux/list.h>
#include <linux/ktime.h>
#include <linux/stddef.h>
#include <linux/debugobjects.h>
#include <linux/stringify.h>

struct tvec_base;


struct timer_list {
	/*
         * All fields that change during normal runtime grouped to the
         * same cacheline
         */
	
struct hlist_node	entry;
	
unsigned long		expires;
	
void			(*function)(unsigned long);
	
unsigned long		data;
	
u32			flags;
	
int			slack;

#ifdef CONFIG_TIMER_STATS
	
int			start_pid;
	
void			*start_site;
	
char			start_comm[16];
#endif
#ifdef CONFIG_LOCKDEP
	
struct lockdep_map	lockdep_map;
#endif
};

#ifdef CONFIG_LOCKDEP
/*
 * NB: because we have to copy the lockdep_map, setting the lockdep_map key
 * (second argument) here is required, otherwise it could be initialised to
 * the copy of the lockdep_map later! We use the pointer to and the string
 * "<file>:<line>" as the key resp. the name of the lockdep_map.
 */

#define __TIMER_LOCKDEP_MAP_INITIALIZER(_kn)				\
	.lockdep_map = STATIC_LOCKDEP_MAP_INIT(_kn, &_kn),
#else

#define __TIMER_LOCKDEP_MAP_INITIALIZER(_kn)
#endif

/*
 * A deferrable timer will work normally when the system is busy, but
 * will not cause a CPU to come out of idle just to service it; instead,
 * the timer will be serviced when the CPU eventually wakes up with a
 * subsequent non-deferrable timer.
 *
 * An irqsafe timer is executed with IRQ disabled and it's safe to wait for
 * the completion of the running instance from IRQ handlers, for example,
 * by calling del_timer_sync().
 *
 * Note: The irq disabled callback execution is a special case for
 * workqueue locking issues. It's not meant for executing random crap
 * with interrupts disabled. Abuse is monitored!
 */

#define TIMER_CPUMASK		0x0007FFFF

#define TIMER_MIGRATING		0x00080000

#define TIMER_BASEMASK		(TIMER_CPUMASK | TIMER_MIGRATING)

#define TIMER_DEFERRABLE	0x00100000

#define TIMER_IRQSAFE		0x00200000


#define __TIMER_INITIALIZER(_function, _expires, _data, _flags) { \
                .entry = { .next = TIMER_ENTRY_STATIC },        \
                .function = (_function),                        \
                .expires = (_expires),                          \
                .data = (_data),                                \
                .flags = (_flags),                              \
                .slack = -1,                                    \
                __TIMER_LOCKDEP_MAP_INITIALIZER(                \
                        __FILE__ ":" __stringify(__LINE__))     \
        }


#define TIMER_INITIALIZER(_function, _expires, _data)		\
	__TIMER_INITIALIZER((_function), (_expires), (_data), 0)


#define TIMER_DEFERRED_INITIALIZER(_function, _expires, _data)	\
	__TIMER_INITIALIZER((_function), (_expires), (_data), TIMER_DEFERRABLE)


#define DEFINE_TIMER(_name, _function, _expires, _data)		\
	struct timer_list _name =                               \
                TIMER_INITIALIZER(_function, _expires, _data)

void init_timer_key(struct timer_list *timer, unsigned int flags,
		    const char *name, struct lock_class_key *key);

#ifdef CONFIG_DEBUG_OBJECTS_TIMERS
extern void init_timer_on_stack_key(struct timer_list *timer,
				    unsigned int flags, const char *name,
				    struct lock_class_key *key);
extern void destroy_timer_on_stack(struct timer_list *timer);
#else

static inline void destroy_timer_on_stack(struct timer_list *timer) { }

Contributors

PersonTokensPropCommitsCommitProp
tejun heotejun heo11100.00%1100.00%
Total11100.00%1100.00%


static inline void init_timer_on_stack_key(struct timer_list *timer, unsigned int flags, const char *name, struct lock_class_key *key) { init_timer_key(timer, flags, name, key); }

Contributors

PersonTokensPropCommitsCommitProp
tejun heotejun heo37100.00%2100.00%
Total37100.00%2100.00%

#endif #ifdef CONFIG_LOCKDEP #define __init_timer(_timer, _flags) \ do { \ static struct lock_class_key __key; \ init_timer_key((_timer), (_flags), #_timer, &__key); \ } while (0) #define __init_timer_on_stack(_timer, _flags) \ do { \ static struct lock_class_key __key; \ init_timer_on_stack_key((_timer), (_flags), #_timer, &__key); \ } while (0) #else #define __init_timer(_timer, _flags) \ init_timer_key((_timer), (_flags), NULL, NULL) #define __init_timer_on_stack(_timer, _flags) \ init_timer_on_stack_key((_timer), (_flags), NULL, NULL) #endif #define init_timer(timer) \ __init_timer((timer), 0) #define init_timer_deferrable(timer) \ __init_timer((timer), TIMER_DEFERRABLE) #define init_timer_on_stack(timer) \ __init_timer_on_stack((timer), 0) #define __setup_timer(_timer, _fn, _data, _flags) \ do { \ __init_timer((_timer), (_flags)); \ (_timer)->function = (_fn); \ (_timer)->data = (_data); \ } while (0) #define __setup_timer_on_stack(_timer, _fn, _data, _flags) \ do { \ __init_timer_on_stack((_timer), (_flags)); \ (_timer)->function = (_fn); \ (_timer)->data = (_data); \ } while (0) #define setup_timer(timer, fn, data) \ __setup_timer((timer), (fn), (data), 0) #define setup_deferrable_timer(timer, fn, data) \ __setup_timer((timer), (fn), (data), TIMER_DEFERRABLE) #define setup_timer_on_stack(timer, fn, data) \ __setup_timer_on_stack((timer), (fn), (data), 0) #define setup_deferrable_timer_on_stack(timer, fn, data) \ __setup_timer_on_stack((timer), (fn), (data), TIMER_DEFERRABLE) /** * timer_pending - is a timer pending? * @timer: the timer in question * * timer_pending will tell whether a given timer is currently pending, * or not. Callers must ensure serialization wrt. other operations done * to this timer, eg. interrupt contexts, or other CPUs on SMP. * * return value: 1 if the timer is pending, 0 if not. */
static inline int timer_pending(const struct timer_list * timer) { return timer->entry.pprev != NULL; }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar1986.36%133.33%
oleg nesterovoleg nesterov29.09%133.33%
thomas gleixnerthomas gleixner14.55%133.33%
Total22100.00%3100.00%

extern void add_timer_on(struct timer_list *timer, int cpu); extern int del_timer(struct timer_list * timer); extern int mod_timer(struct timer_list *timer, unsigned long expires); extern int mod_timer_pending(struct timer_list *timer, unsigned long expires); extern int mod_timer_pinned(struct timer_list *timer, unsigned long expires); extern void set_timer_slack(struct timer_list *time, int slack_hz); #define TIMER_NOT_PINNED 0 #define TIMER_PINNED 1 /* * The jiffies value which is added to now, when there is no timer * in the timer wheel: */ #define NEXT_TIMER_MAX_DELTA ((1UL << 30) - 1) /* * Timer-statistics info: */ #ifdef CONFIG_TIMER_STATS extern int timer_stats_active; extern void init_timer_stats(void); extern void timer_stats_update_stats(void *timer, pid_t pid, void *startf, void *timerf, char *comm, u32 flags); extern void __timer_stats_timer_set_start_info(struct timer_list *timer, void *addr);
static inline void timer_stats_timer_set_start_info(struct timer_list *timer) { if (likely(!timer_stats_active)) return; __timer_stats_timer_set_start_info(timer, __builtin_return_address(0)); }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar2270.97%150.00%
heiko carstensheiko carstens929.03%150.00%
Total31100.00%2100.00%


static inline void timer_stats_timer_clear_start_info(struct timer_list *timer) { timer->start_site = NULL; }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar18100.00%1100.00%
Total18100.00%1100.00%

#else
static inline void init_timer_stats(void) { }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar8100.00%1100.00%
Total8100.00%1100.00%


static inline void timer_stats_timer_set_start_info(struct timer_list *timer) { }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar11100.00%1100.00%
Total11100.00%1100.00%


static inline void timer_stats_timer_clear_start_info(struct timer_list *timer) { }

Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar11100.00%1100.00%
Total11100.00%1100.00%

#endif extern void add_timer(struct timer_list *timer); extern int try_to_del_timer_sync(struct timer_list *timer); #ifdef CONFIG_SMP extern int del_timer_sync(struct timer_list *timer); #else # define del_timer_sync(t) del_timer(t) #endif #define del_singleshot_timer_sync(t) del_timer_sync(t) extern void init_timers(void); extern void run_local_timers(void); struct hrtimer; extern enum hrtimer_restart it_real_fn(struct hrtimer *); #if defined(CONFIG_SMP) && defined(CONFIG_NO_HZ_COMMON) #include <linux/sysctl.h> extern unsigned int sysctl_timer_migration; int timer_migration_handler(struct ctl_table *table, int write, void __user *buffer, size_t *lenp, loff_t *ppos); #endif unsigned long __round_jiffies(unsigned long j, int cpu); unsigned long __round_jiffies_relative(unsigned long j, int cpu); unsigned long round_jiffies(unsigned long j); unsigned long round_jiffies_relative(unsigned long j); unsigned long __round_jiffies_up(unsigned long j, int cpu); unsigned long __round_jiffies_up_relative(unsigned long j, int cpu); unsigned long round_jiffies_up(unsigned long j); unsigned long round_jiffies_up_relative(unsigned long j); #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
ingo molnaringo molnar22725.19%59.62%
tejun heotejun heo15917.65%47.69%
johannes bergjohannes berg11212.43%11.92%
thomas gleixnerthomas gleixner829.10%815.38%
pre-gitpre-git667.33%1121.15%
arjan van de venarjan van de ven586.44%23.85%
andrew mortonandrew morton444.88%611.54%
alan sternalan stern424.66%11.92%
arun bharadwajarun bharadwaj222.44%11.92%
jesse barnesjesse barnes171.89%11.92%
phil carmodyphil carmody161.78%11.92%
oleg nesterovoleg nesterov151.66%23.85%
heiko carstensheiko carstens131.44%11.92%
lucas stachlucas stach121.33%11.92%
roman zippelroman zippel50.55%11.92%
venkatesh pallipadivenkatesh pallipadi30.33%23.85%
richard kennedyrichard kennedy30.33%11.92%
yong zhangyong zhang30.33%11.92%
robert p. j. dayrobert p. j. day10.11%11.92%
pavel machekpavel machek10.11%11.92%
Total901100.00%52100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}