diff options
author | John Stultz <john.stultz@linaro.org> | 2011-01-03 18:59:43 -0800 |
---|---|---|
committer | John Stultz <john.stultz@linaro.org> | 2011-04-26 14:01:42 -0700 |
commit | 88d19cf37952a7e1e38b2bf87a00f0e857e63180 (patch) | |
tree | fdd409b1588005bb71b3cd0bf5fbe55a3dd68643 /include/linux/timerqueue.h | |
parent | 304529b1b6f8612ccbb4582e997051b48b94f4a4 (diff) | |
download | lwn-88d19cf37952a7e1e38b2bf87a00f0e857e63180.tar.gz lwn-88d19cf37952a7e1e38b2bf87a00f0e857e63180.zip |
timers: Add rb_init_node() to allow for stack allocated rb nodes
In cases where a timerqueue_node or some structure that utilizes
a timerqueue_node is allocated on the stack, gcc would give warnings
caused by the timerqueue_init()'s calling RB_CLEAR_NODE, which
self-references the nodes uninitialized data.
The solution is to create an rb_init_node() function that zeros
the rb_node structure out and then calls RB_CLEAR_NODE(), and
then call the new init function from timerqueue_init().
CC: Thomas Gleixner <tglx@linutronix.de>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: John Stultz <john.stultz@linaro.org>
Diffstat (limited to 'include/linux/timerqueue.h')
-rw-r--r-- | include/linux/timerqueue.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/include/linux/timerqueue.h b/include/linux/timerqueue.h index a520fd70a59f..5088727478fd 100644 --- a/include/linux/timerqueue.h +++ b/include/linux/timerqueue.h @@ -39,7 +39,7 @@ struct timerqueue_node *timerqueue_getnext(struct timerqueue_head *head) static inline void timerqueue_init(struct timerqueue_node *node) { - RB_CLEAR_NODE(&node->node); + rb_init_node(&node->node); } static inline void timerqueue_init_head(struct timerqueue_head *head) |