diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2017-10-05 14:42:39 +0200 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2017-10-05 14:42:39 +0200 |
commit | 26eafeaab917dd228d292f362be1577c9b4b2e77 (patch) | |
tree | bd89e0ed1c11635d184c7b497aac6ddd967ebde8 /include/linux/timer.h | |
parent | 4c3711d7fb4763c63b2654f2d07cbe21ca5aadd4 (diff) | |
parent | d81fa669e3de7eb8a631d7d95dac5fbcb2bf9d4e (diff) | |
download | lwn-26eafeaab917dd228d292f362be1577c9b4b2e77.tar.gz lwn-26eafeaab917dd228d292f362be1577c9b4b2e77.zip |
Merge branch 'linus' into timers/core
Pick up upstream changes to get the prerequisites for the timer changes.
Diffstat (limited to 'include/linux/timer.h')
-rw-r--r-- | include/linux/timer.h | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/include/linux/timer.h b/include/linux/timer.h index e6789b8757d5..6383c528b148 100644 --- a/include/linux/timer.h +++ b/include/linux/timer.h @@ -168,6 +168,20 @@ static inline void init_timer_on_stack_key(struct timer_list *timer, #define setup_pinned_deferrable_timer_on_stack(timer, fn, data) \ __setup_timer_on_stack((timer), (fn), (data), TIMER_DEFERRABLE | TIMER_PINNED) +#define TIMER_DATA_TYPE unsigned long +#define TIMER_FUNC_TYPE void (*)(TIMER_DATA_TYPE) + +static inline void timer_setup(struct timer_list *timer, + void (*callback)(struct timer_list *), + unsigned int flags) +{ + __setup_timer(timer, (TIMER_FUNC_TYPE)callback, + (TIMER_DATA_TYPE)timer, flags); +} + +#define from_timer(var, callback_timer, timer_fieldname) \ + container_of(callback_timer, typeof(*var), timer_fieldname) + /** * timer_pending - is a timer pending? * @timer: the timer in question |