blob: 288c26f50732d7c2c9403765d7d8f3e79d20729b [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Michel Lespinassefff3fd82012-10-08 16:31:23 -07002#ifndef _LINUX_INTERVAL_TREE_H
3#define _LINUX_INTERVAL_TREE_H
4
5#include <linux/rbtree.h>
6
7struct interval_tree_node {
8 struct rb_node rb;
9 unsigned long start; /* Start of interval */
10 unsigned long last; /* Last location _in_ interval */
11 unsigned long __subtree_last;
12};
13
14extern void
Davidlohr Buesof808c132017-09-08 16:15:08 -070015interval_tree_insert(struct interval_tree_node *node,
16 struct rb_root_cached *root);
Michel Lespinassefff3fd82012-10-08 16:31:23 -070017
18extern void
Davidlohr Buesof808c132017-09-08 16:15:08 -070019interval_tree_remove(struct interval_tree_node *node,
20 struct rb_root_cached *root);
Michel Lespinassefff3fd82012-10-08 16:31:23 -070021
22extern struct interval_tree_node *
Davidlohr Buesof808c132017-09-08 16:15:08 -070023interval_tree_iter_first(struct rb_root_cached *root,
Michel Lespinassefff3fd82012-10-08 16:31:23 -070024 unsigned long start, unsigned long last);
25
26extern struct interval_tree_node *
27interval_tree_iter_next(struct interval_tree_node *node,
28 unsigned long start, unsigned long last);
29
30#endif /* _LINUX_INTERVAL_TREE_H */