diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2014-03-17 08:21:54 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2014-05-05 03:09:14 -0400 |
commit | a88cc108f6f39e56577793f66ac69eb0e18ae099 (patch) | |
tree | ea07f899e8d482e15654d06d7df9aae857166dda /lib/interval_tree.c | |
parent | 8d4eee9cd7a170342dc6fbc2ee19ae77031a8cd5 (diff) |
lib: Export interval_tree
lib/interval_tree.c provides a simple interface for an interval-tree
(an augmented red-black tree) but is only built when testing the generic
macros for building interval-trees. For drivers with modest needs,
export the simple interval-tree library as is.
v2: Lots of help from Michel Lespinasse to only compile the code
as required:
- make INTERVAL_TREE a config option
- make INTERVAL_TREE_TEST select the library functions
and sanitize the filenames & Makefile
- prepare interval_tree for being built as a module if required
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Michel Lespinasse <walken@google.com>
Cc: Rik van Riel <riel@redhat.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Reviewed-by: Michel Lespinasse <walken@google.com>
[Acked for inclusion via drm/i915 by Andrew Morton.]
[danvet: switch to _GPL as per the mailing list discussion.]
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'lib/interval_tree.c')
-rw-r--r-- | lib/interval_tree.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/interval_tree.c b/lib/interval_tree.c index e6eb406f2d65..f367f9ad544c 100644 --- a/lib/interval_tree.c +++ b/lib/interval_tree.c | |||
@@ -1,6 +1,7 @@ | |||
1 | #include <linux/init.h> | 1 | #include <linux/init.h> |
2 | #include <linux/interval_tree.h> | 2 | #include <linux/interval_tree.h> |
3 | #include <linux/interval_tree_generic.h> | 3 | #include <linux/interval_tree_generic.h> |
4 | #include <linux/module.h> | ||
4 | 5 | ||
5 | #define START(node) ((node)->start) | 6 | #define START(node) ((node)->start) |
6 | #define LAST(node) ((node)->last) | 7 | #define LAST(node) ((node)->last) |
@@ -8,3 +9,8 @@ | |||
8 | INTERVAL_TREE_DEFINE(struct interval_tree_node, rb, | 9 | INTERVAL_TREE_DEFINE(struct interval_tree_node, rb, |
9 | unsigned long, __subtree_last, | 10 | unsigned long, __subtree_last, |
10 | START, LAST,, interval_tree) | 11 | START, LAST,, interval_tree) |
12 | |||
13 | EXPORT_SYMBOL_GPL(interval_tree_insert); | ||
14 | EXPORT_SYMBOL_GPL(interval_tree_remove); | ||
15 | EXPORT_SYMBOL_GPL(interval_tree_iter_first); | ||
16 | EXPORT_SYMBOL_GPL(interval_tree_iter_next); | ||