diff options
Diffstat (limited to 'lib/rbtree.c')
-rw-r--r-- | lib/rbtree.c | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/lib/rbtree.c b/lib/rbtree.c index fe43c8c5f527..ccada9abe6f5 100644 --- a/lib/rbtree.c +++ b/lib/rbtree.c | |||
@@ -23,6 +23,24 @@ | |||
23 | #include <linux/rbtree.h> | 23 | #include <linux/rbtree.h> |
24 | #include <linux/export.h> | 24 | #include <linux/export.h> |
25 | 25 | ||
26 | #define RB_RED 0 | ||
27 | #define RB_BLACK 1 | ||
28 | |||
29 | #define rb_color(r) ((r)->__rb_parent_color & 1) | ||
30 | #define rb_is_red(r) (!rb_color(r)) | ||
31 | #define rb_is_black(r) rb_color(r) | ||
32 | #define rb_set_red(r) do { (r)->__rb_parent_color &= ~1; } while (0) | ||
33 | #define rb_set_black(r) do { (r)->__rb_parent_color |= 1; } while (0) | ||
34 | |||
35 | static inline void rb_set_parent(struct rb_node *rb, struct rb_node *p) | ||
36 | { | ||
37 | rb->__rb_parent_color = rb_color(rb) | (unsigned long)p; | ||
38 | } | ||
39 | static inline void rb_set_color(struct rb_node *rb, int color) | ||
40 | { | ||
41 | rb->__rb_parent_color = (rb->__rb_parent_color & ~1) | color; | ||
42 | } | ||
43 | |||
26 | static void __rb_rotate_left(struct rb_node *node, struct rb_root *root) | 44 | static void __rb_rotate_left(struct rb_node *node, struct rb_root *root) |
27 | { | 45 | { |
28 | struct rb_node *right = node->rb_right; | 46 | struct rb_node *right = node->rb_right; |
@@ -255,7 +273,7 @@ void rb_erase(struct rb_node *node, struct rb_root *root) | |||
255 | rb_set_parent(old->rb_right, node); | 273 | rb_set_parent(old->rb_right, node); |
256 | } | 274 | } |
257 | 275 | ||
258 | node->rb_parent_color = old->rb_parent_color; | 276 | node->__rb_parent_color = old->__rb_parent_color; |
259 | node->rb_left = old->rb_left; | 277 | node->rb_left = old->rb_left; |
260 | rb_set_parent(old->rb_left, node); | 278 | rb_set_parent(old->rb_left, node); |
261 | 279 | ||