| 1 | /* SPDX-License-Identifier: GPL-2.0 */ | 
|---|
| 2 | #ifndef _LINUX_TIMER_H | 
|---|
| 3 | #define _LINUX_TIMER_H | 
|---|
| 4 |  | 
|---|
| 5 | #include <linux/list.h> | 
|---|
| 6 | #include <linux/ktime.h> | 
|---|
| 7 | #include <linux/stddef.h> | 
|---|
| 8 | #include <linux/debugobjects.h> | 
|---|
| 9 | #include <linux/stringify.h> | 
|---|
| 10 | #include <linux/timer_types.h> | 
|---|
| 11 |  | 
|---|
| 12 | #ifdef CONFIG_LOCKDEP | 
|---|
| 13 | /* | 
|---|
| 14 | * NB: because we have to copy the lockdep_map, setting the lockdep_map key | 
|---|
| 15 | * (second argument) here is required, otherwise it could be initialised to | 
|---|
| 16 | * the copy of the lockdep_map later! We use the pointer to and the string | 
|---|
| 17 | * "<file>:<line>" as the key resp. the name of the lockdep_map. | 
|---|
| 18 | */ | 
|---|
| 19 | #define __TIMER_LOCKDEP_MAP_INITIALIZER(_kn)				\ | 
|---|
| 20 | .lockdep_map = STATIC_LOCKDEP_MAP_INIT(_kn, &_kn), | 
|---|
| 21 | #else | 
|---|
| 22 | #define __TIMER_LOCKDEP_MAP_INITIALIZER(_kn) | 
|---|
| 23 | #endif | 
|---|
| 24 |  | 
|---|
| 25 | /* | 
|---|
| 26 | * @TIMER_DEFERRABLE: A deferrable timer will work normally when the | 
|---|
| 27 | * system is busy, but will not cause a CPU to come out of idle just | 
|---|
| 28 | * to service it; instead, the timer will be serviced when the CPU | 
|---|
| 29 | * eventually wakes up with a subsequent non-deferrable timer. | 
|---|
| 30 | * | 
|---|
| 31 | * @TIMER_IRQSAFE: An irqsafe timer is executed with IRQ disabled and | 
|---|
| 32 | * it's safe to wait for the completion of the running instance from | 
|---|
| 33 | * IRQ handlers, for example, by calling timer_delete_sync(). | 
|---|
| 34 | * | 
|---|
| 35 | * Note: The irq disabled callback execution is a special case for | 
|---|
| 36 | * workqueue locking issues. It's not meant for executing random crap | 
|---|
| 37 | * with interrupts disabled. Abuse is monitored! | 
|---|
| 38 | * | 
|---|
| 39 | * @TIMER_PINNED: A pinned timer will always expire on the CPU on which the | 
|---|
| 40 | * timer was enqueued. When a particular CPU is required, add_timer_on() | 
|---|
| 41 | * has to be used. Enqueue via mod_timer() and add_timer() is always done | 
|---|
| 42 | * on the local CPU. | 
|---|
| 43 | */ | 
|---|
| 44 | #define TIMER_CPUMASK		0x0003FFFF | 
|---|
| 45 | #define TIMER_MIGRATING		0x00040000 | 
|---|
| 46 | #define TIMER_BASEMASK		(TIMER_CPUMASK | TIMER_MIGRATING) | 
|---|
| 47 | #define TIMER_DEFERRABLE	0x00080000 | 
|---|
| 48 | #define TIMER_PINNED		0x00100000 | 
|---|
| 49 | #define TIMER_IRQSAFE		0x00200000 | 
|---|
| 50 | #define TIMER_INIT_FLAGS	(TIMER_DEFERRABLE | TIMER_PINNED | TIMER_IRQSAFE) | 
|---|
| 51 | #define TIMER_ARRAYSHIFT	22 | 
|---|
| 52 | #define TIMER_ARRAYMASK		0xFFC00000 | 
|---|
| 53 |  | 
|---|
| 54 | #define TIMER_TRACE_FLAGMASK	(TIMER_MIGRATING | TIMER_DEFERRABLE | TIMER_PINNED | TIMER_IRQSAFE) | 
|---|
| 55 |  | 
|---|
| 56 | #define __TIMER_INITIALIZER(_function, _flags) {		\ | 
|---|
| 57 | .entry = { .next = TIMER_ENTRY_STATIC },	\ | 
|---|
| 58 | .function = (_function),			\ | 
|---|
| 59 | .flags = (_flags),				\ | 
|---|
| 60 | __TIMER_LOCKDEP_MAP_INITIALIZER(FILE_LINE)	\ | 
|---|
| 61 | } | 
|---|
| 62 |  | 
|---|
| 63 | #define DEFINE_TIMER(_name, _function)				\ | 
|---|
| 64 | struct timer_list _name =				\ | 
|---|
| 65 | __TIMER_INITIALIZER(_function, 0) | 
|---|
| 66 |  | 
|---|
| 67 | /* | 
|---|
| 68 | * LOCKDEP and DEBUG timer interfaces. | 
|---|
| 69 | */ | 
|---|
| 70 | void timer_init_key(struct timer_list *timer, | 
|---|
| 71 | void (*func)(struct timer_list *), unsigned int flags, | 
|---|
| 72 | const char *name, struct lock_class_key *key); | 
|---|
| 73 |  | 
|---|
| 74 | #ifdef CONFIG_DEBUG_OBJECTS_TIMERS | 
|---|
| 75 | extern void timer_init_key_on_stack(struct timer_list *timer, | 
|---|
| 76 | void (*func)(struct timer_list *), | 
|---|
| 77 | unsigned int flags, const char *name, | 
|---|
| 78 | struct lock_class_key *key); | 
|---|
| 79 | #else | 
|---|
| 80 | static inline void timer_init_key_on_stack(struct timer_list *timer, | 
|---|
| 81 | void (*func)(struct timer_list *), | 
|---|
| 82 | unsigned int flags, | 
|---|
| 83 | const char *name, | 
|---|
| 84 | struct lock_class_key *key) | 
|---|
| 85 | { | 
|---|
| 86 | timer_init_key(timer, func, flags, name, key); | 
|---|
| 87 | } | 
|---|
| 88 | #endif | 
|---|
| 89 |  | 
|---|
| 90 | #ifdef CONFIG_LOCKDEP | 
|---|
| 91 | #define __timer_init(_timer, _fn, _flags)				\ | 
|---|
| 92 | do {								\ | 
|---|
| 93 | static struct lock_class_key __key;			\ | 
|---|
| 94 | timer_init_key((_timer), (_fn), (_flags), #_timer, &__key);\ | 
|---|
| 95 | } while (0) | 
|---|
| 96 |  | 
|---|
| 97 | #define __timer_init_on_stack(_timer, _fn, _flags)			\ | 
|---|
| 98 | do {								\ | 
|---|
| 99 | static struct lock_class_key __key;			\ | 
|---|
| 100 | timer_init_key_on_stack((_timer), (_fn), (_flags),	\ | 
|---|
| 101 | #_timer, &__key);		 \ | 
|---|
| 102 | } while (0) | 
|---|
| 103 | #else | 
|---|
| 104 | #define __timer_init(_timer, _fn, _flags)				\ | 
|---|
| 105 | timer_init_key((_timer), (_fn), (_flags), NULL, NULL) | 
|---|
| 106 | #define __timer_init_on_stack(_timer, _fn, _flags)			\ | 
|---|
| 107 | timer_init_key_on_stack((_timer), (_fn), (_flags), NULL, NULL) | 
|---|
| 108 | #endif | 
|---|
| 109 |  | 
|---|
| 110 | /** | 
|---|
| 111 | * timer_setup - prepare a timer for first use | 
|---|
| 112 | * @timer: the timer in question | 
|---|
| 113 | * @callback: the function to call when timer expires | 
|---|
| 114 | * @flags: any TIMER_* flags | 
|---|
| 115 | * | 
|---|
| 116 | * Regular timer initialization should use either DEFINE_TIMER() above, | 
|---|
| 117 | * or timer_setup(). For timers on the stack, timer_setup_on_stack() must | 
|---|
| 118 | * be used and must be balanced with a call to timer_destroy_on_stack(). | 
|---|
| 119 | */ | 
|---|
| 120 | #define timer_setup(timer, callback, flags)			\ | 
|---|
| 121 | __timer_init((timer), (callback), (flags)) | 
|---|
| 122 |  | 
|---|
| 123 | #define timer_setup_on_stack(timer, callback, flags)		\ | 
|---|
| 124 | __timer_init_on_stack((timer), (callback), (flags)) | 
|---|
| 125 |  | 
|---|
| 126 | #ifdef CONFIG_DEBUG_OBJECTS_TIMERS | 
|---|
| 127 | extern void timer_destroy_on_stack(struct timer_list *timer); | 
|---|
| 128 | #else | 
|---|
| 129 | static inline void timer_destroy_on_stack(struct timer_list *timer) { } | 
|---|
| 130 | #endif | 
|---|
| 131 |  | 
|---|
| 132 | #define timer_container_of(var, callback_timer, timer_fieldname)	\ | 
|---|
| 133 | container_of(callback_timer, typeof(*var), timer_fieldname) | 
|---|
| 134 |  | 
|---|
| 135 | /** | 
|---|
| 136 | * timer_pending - is a timer pending? | 
|---|
| 137 | * @timer: the timer in question | 
|---|
| 138 | * | 
|---|
| 139 | * timer_pending will tell whether a given timer is currently pending, | 
|---|
| 140 | * or not. Callers must ensure serialization wrt. other operations done | 
|---|
| 141 | * to this timer, eg. interrupt contexts, or other CPUs on SMP. | 
|---|
| 142 | * | 
|---|
| 143 | * Returns: 1 if the timer is pending, 0 if not. | 
|---|
| 144 | */ | 
|---|
| 145 | static inline int timer_pending(const struct timer_list * timer) | 
|---|
| 146 | { | 
|---|
| 147 | return !hlist_unhashed_lockless(h: &timer->entry); | 
|---|
| 148 | } | 
|---|
| 149 |  | 
|---|
| 150 | extern void add_timer_on(struct timer_list *timer, int cpu); | 
|---|
| 151 | extern int mod_timer(struct timer_list *timer, unsigned long expires); | 
|---|
| 152 | extern int mod_timer_pending(struct timer_list *timer, unsigned long expires); | 
|---|
| 153 | extern int timer_reduce(struct timer_list *timer, unsigned long expires); | 
|---|
| 154 |  | 
|---|
| 155 | /* | 
|---|
| 156 | * The jiffies value which is added to now, when there is no timer | 
|---|
| 157 | * in the timer wheel: | 
|---|
| 158 | */ | 
|---|
| 159 | #define TIMER_NEXT_MAX_DELTA	((1UL << 30) - 1) | 
|---|
| 160 |  | 
|---|
| 161 | extern void add_timer(struct timer_list *timer); | 
|---|
| 162 | extern void add_timer_local(struct timer_list *timer); | 
|---|
| 163 | extern void add_timer_global(struct timer_list *timer); | 
|---|
| 164 |  | 
|---|
| 165 | extern int timer_delete_sync_try(struct timer_list *timer); | 
|---|
| 166 | extern int timer_delete_sync(struct timer_list *timer); | 
|---|
| 167 | extern int timer_delete(struct timer_list *timer); | 
|---|
| 168 | extern int timer_shutdown_sync(struct timer_list *timer); | 
|---|
| 169 | extern int timer_shutdown(struct timer_list *timer); | 
|---|
| 170 |  | 
|---|
| 171 | extern void timers_init(void); | 
|---|
| 172 | struct hrtimer; | 
|---|
| 173 | extern enum hrtimer_restart it_real_fn(struct hrtimer *); | 
|---|
| 174 |  | 
|---|
| 175 | unsigned long __round_jiffies_relative(unsigned long j, int cpu); | 
|---|
| 176 | unsigned long round_jiffies(unsigned long j); | 
|---|
| 177 | unsigned long round_jiffies_relative(unsigned long j); | 
|---|
| 178 |  | 
|---|
| 179 | unsigned long __round_jiffies_up_relative(unsigned long j, int cpu); | 
|---|
| 180 | unsigned long round_jiffies_up(unsigned long j); | 
|---|
| 181 | unsigned long round_jiffies_up_relative(unsigned long j); | 
|---|
| 182 |  | 
|---|
| 183 | #ifdef CONFIG_HOTPLUG_CPU | 
|---|
| 184 | int timers_prepare_cpu(unsigned int cpu); | 
|---|
| 185 | int timers_dead_cpu(unsigned int cpu); | 
|---|
| 186 | #else | 
|---|
| 187 | #define timers_prepare_cpu	NULL | 
|---|
| 188 | #define timers_dead_cpu		NULL | 
|---|
| 189 | #endif | 
|---|
| 190 |  | 
|---|
| 191 | #endif | 
|---|
| 192 |  | 
|---|