diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-10-30 03:20:56 -0400 |
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-10-30 03:20:56 -0400 |
| commit | 53279f36dccffc26ff536003fd6bb97cc21c3b82 (patch) | |
| tree | 9d16e497c0e4158c7c054c479bd0e9ff0388d7bb /include/linux/interval_tree.h | |
| parent | a6e8c0a25377e27958b11b20e1927885ae7c9857 (diff) | |
| parent | 8f0d8163b50e01f398b14bcd4dc039ac5ab18d64 (diff) | |
Merge tag 'v3.7-rc3' into next to sync up with recent USB and MFD changes
Diffstat (limited to 'include/linux/interval_tree.h')
| -rw-r--r-- | include/linux/interval_tree.h | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/include/linux/interval_tree.h b/include/linux/interval_tree.h new file mode 100644 index 000000000000..724556aa3c95 --- /dev/null +++ b/include/linux/interval_tree.h | |||
| @@ -0,0 +1,27 @@ | |||
| 1 | #ifndef _LINUX_INTERVAL_TREE_H | ||
| 2 | #define _LINUX_INTERVAL_TREE_H | ||
| 3 | |||
| 4 | #include <linux/rbtree.h> | ||
| 5 | |||
| 6 | struct interval_tree_node { | ||
| 7 | struct rb_node rb; | ||
| 8 | unsigned long start; /* Start of interval */ | ||
| 9 | unsigned long last; /* Last location _in_ interval */ | ||
| 10 | unsigned long __subtree_last; | ||
| 11 | }; | ||
| 12 | |||
| 13 | extern void | ||
| 14 | interval_tree_insert(struct interval_tree_node *node, struct rb_root *root); | ||
| 15 | |||
| 16 | extern void | ||
| 17 | interval_tree_remove(struct interval_tree_node *node, struct rb_root *root); | ||
| 18 | |||
| 19 | extern struct interval_tree_node * | ||
| 20 | interval_tree_iter_first(struct rb_root *root, | ||
| 21 | unsigned long start, unsigned long last); | ||
| 22 | |||
| 23 | extern struct interval_tree_node * | ||
| 24 | interval_tree_iter_next(struct interval_tree_node *node, | ||
| 25 | unsigned long start, unsigned long last); | ||
| 26 | |||
| 27 | #endif /* _LINUX_INTERVAL_TREE_H */ | ||
