diff options
author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-20 17:51:22 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-20 17:51:22 -0400 |
commit | 2edc322d420a4cec8dbc184a1220ecd7fa9f8ae6 (patch) | |
tree | e7be2cf442626316b6b6fb212960fe1f77ff2725 | |
parent | be967b7e2f7747a5ebf2a07ee627d9338491e784 (diff) | |
parent | 2f3243aebd8df4d9eecaeca04bbff6c7dbfb2142 (diff) |
Merge git://git.infradead.org/~dwmw2/rbtree-2.6
* git://git.infradead.org/~dwmw2/rbtree-2.6:
[RBTREE] Switch rb_colour() et al to en_US spelling of 'color' for consistency
Update UML kernel/physmem.c to use rb_parent() accessor macro
[RBTREE] Update hrtimers to use rb_parent() accessor macro.
[RBTREE] Add explicit alignment to sizeof(long) for struct rb_node.
[RBTREE] Merge colour and parent fields of struct rb_node.
[RBTREE] Remove dead code in rb_erase()
[RBTREE] Update JFFS2 to use rb_parent() accessor macro.
[RBTREE] Update eventpoll.c to use rb_parent() accessor macro.
[RBTREE] Update key.c to use rb_parent() accessor macro.
[RBTREE] Update ext3 to use rb_parent() accessor macro.
[RBTREE] Change rbtree off-tree marking in I/O schedulers.
[RBTREE] Add accessor macros for colour and parent fields of rb_node
-rw-r--r-- | arch/um/kernel/physmem.c | 2 | ||||
-rw-r--r-- | block/as-iosched.c | 5 | ||||
-rw-r--r-- | block/cfq-iosched.c | 8 | ||||
-rw-r--r-- | block/deadline-iosched.c | 5 | ||||
-rw-r--r-- | fs/eventpoll.c | 6 | ||||
-rw-r--r-- | fs/ext3/dir.c | 2 | ||||
-rw-r--r-- | fs/jffs2/nodelist.h | 1 | ||||
-rw-r--r-- | fs/jffs2/readinode.c | 18 | ||||
-rw-r--r-- | include/linux/hrtimer.h | 2 | ||||
-rw-r--r-- | include/linux/rbtree.h | 26 | ||||
-rw-r--r-- | kernel/hrtimer.c | 4 | ||||
-rw-r--r-- | lib/rbtree.c | 189 | ||||
-rw-r--r-- | security/keys/key.c | 8 |
13 files changed, 140 insertions, 136 deletions
diff --git a/arch/um/kernel/physmem.c b/arch/um/kernel/physmem.c index fc0f0b085ca7..166cb09cae4c 100644 --- a/arch/um/kernel/physmem.c +++ b/arch/um/kernel/physmem.c | |||
@@ -69,7 +69,7 @@ static void insert_phys_mapping(struct phys_desc *desc) | |||
69 | panic("Physical remapping for %p already present", | 69 | panic("Physical remapping for %p already present", |
70 | desc->virt); | 70 | desc->virt); |
71 | 71 | ||
72 | rb_link_node(&desc->rb, (*n)->rb_parent, n); | 72 | rb_link_node(&desc->rb, rb_parent(*n), n); |
73 | rb_insert_color(&desc->rb, &phys_mappings); | 73 | rb_insert_color(&desc->rb, &phys_mappings); |
74 | } | 74 | } |
75 | 75 | ||
diff --git a/block/as-iosched.c b/block/as-iosched.c index a7caf35ca0c2..0c750393be4a 100644 --- a/block/as-iosched.c +++ b/block/as-iosched.c | |||
@@ -353,10 +353,9 @@ static struct request *as_find_arq_hash(struct as_data *ad, sector_t offset) | |||
353 | /* | 353 | /* |
354 | * rb tree support functions | 354 | * rb tree support functions |
355 | */ | 355 | */ |
356 | #define RB_NONE (2) | ||
357 | #define RB_EMPTY(root) ((root)->rb_node == NULL) | 356 | #define RB_EMPTY(root) ((root)->rb_node == NULL) |
358 | #define ON_RB(node) ((node)->rb_color != RB_NONE) | 357 | #define ON_RB(node) (rb_parent(node) != node) |
359 | #define RB_CLEAR(node) ((node)->rb_color = RB_NONE) | 358 | #define RB_CLEAR(node) (rb_set_parent(node, node)) |
360 | #define rb_entry_arq(node) rb_entry((node), struct as_rq, rb_node) | 359 | #define rb_entry_arq(node) rb_entry((node), struct as_rq, rb_node) |
361 | #define ARQ_RB_ROOT(ad, arq) (&(ad)->sort_list[(arq)->is_sync]) | 360 | #define ARQ_RB_ROOT(ad, arq) (&(ad)->sort_list[(arq)->is_sync]) |
362 | #define rq_rb_key(rq) (rq)->sector | 361 | #define rq_rb_key(rq) (rq)->sector |
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index 052b17487625..6200d9b9af28 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c | |||
@@ -60,14 +60,9 @@ static DEFINE_SPINLOCK(cfq_exit_lock); | |||
60 | /* | 60 | /* |
61 | * rb-tree defines | 61 | * rb-tree defines |
62 | */ | 62 | */ |
63 | #define RB_NONE (2) | ||
64 | #define RB_EMPTY(node) ((node)->rb_node == NULL) | 63 | #define RB_EMPTY(node) ((node)->rb_node == NULL) |
65 | #define RB_CLEAR_COLOR(node) (node)->rb_color = RB_NONE | ||
66 | #define RB_CLEAR(node) do { \ | 64 | #define RB_CLEAR(node) do { \ |
67 | (node)->rb_parent = NULL; \ | 65 | memset(node, 0, sizeof(*node)); \ |
68 | RB_CLEAR_COLOR((node)); \ | ||
69 | (node)->rb_right = NULL; \ | ||
70 | (node)->rb_left = NULL; \ | ||
71 | } while (0) | 66 | } while (0) |
72 | #define RB_CLEAR_ROOT(root) ((root)->rb_node = NULL) | 67 | #define RB_CLEAR_ROOT(root) ((root)->rb_node = NULL) |
73 | #define rb_entry_crq(node) rb_entry((node), struct cfq_rq, rb_node) | 68 | #define rb_entry_crq(node) rb_entry((node), struct cfq_rq, rb_node) |
@@ -567,7 +562,6 @@ static inline void cfq_del_crq_rb(struct cfq_rq *crq) | |||
567 | cfq_update_next_crq(crq); | 562 | cfq_update_next_crq(crq); |
568 | 563 | ||
569 | rb_erase(&crq->rb_node, &cfqq->sort_list); | 564 | rb_erase(&crq->rb_node, &cfqq->sort_list); |
570 | RB_CLEAR_COLOR(&crq->rb_node); | ||
571 | 565 | ||
572 | if (cfq_cfqq_on_rr(cfqq) && RB_EMPTY(&cfqq->sort_list)) | 566 | if (cfq_cfqq_on_rr(cfqq) && RB_EMPTY(&cfqq->sort_list)) |
573 | cfq_del_cfqq_rr(cfqd, cfqq); | 567 | cfq_del_cfqq_rr(cfqd, cfqq); |
diff --git a/block/deadline-iosched.c b/block/deadline-iosched.c index 3bd0415a9828..c94de8e12fbf 100644 --- a/block/deadline-iosched.c +++ b/block/deadline-iosched.c | |||
@@ -165,10 +165,9 @@ deadline_find_drq_hash(struct deadline_data *dd, sector_t offset) | |||
165 | /* | 165 | /* |
166 | * rb tree support functions | 166 | * rb tree support functions |
167 | */ | 167 | */ |
168 | #define RB_NONE (2) | ||
169 | #define RB_EMPTY(root) ((root)->rb_node == NULL) | 168 | #define RB_EMPTY(root) ((root)->rb_node == NULL) |
170 | #define ON_RB(node) ((node)->rb_color != RB_NONE) | 169 | #define ON_RB(node) (rb_parent(node) != node) |
171 | #define RB_CLEAR(node) ((node)->rb_color = RB_NONE) | 170 | #define RB_CLEAR(node) (rb_set_parent(node, node)) |
172 | #define rb_entry_drq(node) rb_entry((node), struct deadline_rq, rb_node) | 171 | #define rb_entry_drq(node) rb_entry((node), struct deadline_rq, rb_node) |
173 | #define DRQ_RB_ROOT(dd, drq) (&(dd)->sort_list[rq_data_dir((drq)->request)]) | 172 | #define DRQ_RB_ROOT(dd, drq) (&(dd)->sort_list[rq_data_dir((drq)->request)]) |
174 | #define rq_rb_key(rq) (rq)->sector | 173 | #define rq_rb_key(rq) (rq)->sector |
diff --git a/fs/eventpoll.c b/fs/eventpoll.c index 1b4491cdd115..2695337d4d64 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c | |||
@@ -337,20 +337,20 @@ static inline int ep_cmp_ffd(struct epoll_filefd *p1, | |||
337 | /* Special initialization for the rb-tree node to detect linkage */ | 337 | /* Special initialization for the rb-tree node to detect linkage */ |
338 | static inline void ep_rb_initnode(struct rb_node *n) | 338 | static inline void ep_rb_initnode(struct rb_node *n) |
339 | { | 339 | { |
340 | n->rb_parent = n; | 340 | rb_set_parent(n, n); |
341 | } | 341 | } |
342 | 342 | ||
343 | /* Removes a node from the rb-tree and marks it for a fast is-linked check */ | 343 | /* Removes a node from the rb-tree and marks it for a fast is-linked check */ |
344 | static inline void ep_rb_erase(struct rb_node *n, struct rb_root *r) | 344 | static inline void ep_rb_erase(struct rb_node *n, struct rb_root *r) |
345 | { | 345 | { |
346 | rb_erase(n, r); | 346 | rb_erase(n, r); |
347 | n->rb_parent = n; | 347 | rb_set_parent(n, n); |
348 | } | 348 | } |
349 | 349 | ||
350 | /* Fast check to verify that the item is linked to the main rb-tree */ | 350 | /* Fast check to verify that the item is linked to the main rb-tree */ |
351 | static inline int ep_rb_linked(struct rb_node *n) | 351 | static inline int ep_rb_linked(struct rb_node *n) |
352 | { | 352 | { |
353 | return n->rb_parent != n; | 353 | return rb_parent(n) != n; |
354 | } | 354 | } |
355 | 355 | ||
356 | /* | 356 | /* |
diff --git a/fs/ext3/dir.c b/fs/ext3/dir.c index f37528ed222e..fbb0d4ed07d4 100644 --- a/fs/ext3/dir.c +++ b/fs/ext3/dir.c | |||
@@ -284,7 +284,7 @@ static void free_rb_tree_fname(struct rb_root *root) | |||
284 | * beginning of the loop and try to free the parent | 284 | * beginning of the loop and try to free the parent |
285 | * node. | 285 | * node. |
286 | */ | 286 | */ |
287 | parent = n->rb_parent; | 287 | parent = rb_parent(n); |
288 | fname = rb_entry(n, struct fname, rb_hash); | 288 | fname = rb_entry(n, struct fname, rb_hash); |
289 | while (fname) { | 289 | while (fname) { |
290 | struct fname * old = fname; | 290 | struct fname * old = fname; |
diff --git a/fs/jffs2/nodelist.h b/fs/jffs2/nodelist.h index 7ad8ee043880..b16c60bbcf6e 100644 --- a/fs/jffs2/nodelist.h +++ b/fs/jffs2/nodelist.h | |||
@@ -315,7 +315,6 @@ static inline struct jffs2_node_frag *frag_last(struct rb_root *root) | |||
315 | return rb_entry(node, struct jffs2_node_frag, rb); | 315 | return rb_entry(node, struct jffs2_node_frag, rb); |
316 | } | 316 | } |
317 | 317 | ||
318 | #define rb_parent(rb) ((rb)->rb_parent) | ||
319 | #define frag_next(frag) rb_entry(rb_next(&(frag)->rb), struct jffs2_node_frag, rb) | 318 | #define frag_next(frag) rb_entry(rb_next(&(frag)->rb), struct jffs2_node_frag, rb) |
320 | #define frag_prev(frag) rb_entry(rb_prev(&(frag)->rb), struct jffs2_node_frag, rb) | 319 | #define frag_prev(frag) rb_entry(rb_prev(&(frag)->rb), struct jffs2_node_frag, rb) |
321 | #define frag_parent(frag) rb_entry(rb_parent(&(frag)->rb), struct jffs2_node_frag, rb) | 320 | #define frag_parent(frag) rb_entry(rb_parent(&(frag)->rb), struct jffs2_node_frag, rb) |
diff --git a/fs/jffs2/readinode.c b/fs/jffs2/readinode.c index 5ea4faafa2d3..5fec012b02ed 100644 --- a/fs/jffs2/readinode.c +++ b/fs/jffs2/readinode.c | |||
@@ -66,7 +66,7 @@ static void jffs2_free_tmp_dnode_info_list(struct rb_root *list) | |||
66 | jffs2_free_full_dnode(tn->fn); | 66 | jffs2_free_full_dnode(tn->fn); |
67 | jffs2_free_tmp_dnode_info(tn); | 67 | jffs2_free_tmp_dnode_info(tn); |
68 | 68 | ||
69 | this = this->rb_parent; | 69 | this = rb_parent(this); |
70 | if (!this) | 70 | if (!this) |
71 | break; | 71 | break; |
72 | 72 | ||
@@ -708,12 +708,12 @@ static int jffs2_do_read_inode_internal(struct jffs2_sb_info *c, | |||
708 | jffs2_mark_node_obsolete(c, fn->raw); | 708 | jffs2_mark_node_obsolete(c, fn->raw); |
709 | 709 | ||
710 | BUG_ON(rb->rb_left); | 710 | BUG_ON(rb->rb_left); |
711 | if (rb->rb_parent && rb->rb_parent->rb_left == rb) { | 711 | if (rb_parent(rb) && rb_parent(rb)->rb_left == rb) { |
712 | /* We were then left-hand child of our parent. We need | 712 | /* We were then left-hand child of our parent. We need |
713 | * to move our own right-hand child into our place. */ | 713 | * to move our own right-hand child into our place. */ |
714 | repl_rb = rb->rb_right; | 714 | repl_rb = rb->rb_right; |
715 | if (repl_rb) | 715 | if (repl_rb) |
716 | repl_rb->rb_parent = rb->rb_parent; | 716 | rb_set_parent(repl_rb, rb_parent(rb)); |
717 | } else | 717 | } else |
718 | repl_rb = NULL; | 718 | repl_rb = NULL; |
719 | 719 | ||
@@ -721,14 +721,14 @@ static int jffs2_do_read_inode_internal(struct jffs2_sb_info *c, | |||
721 | 721 | ||
722 | /* Remove the spent tn from the tree; don't bother rebalancing | 722 | /* Remove the spent tn from the tree; don't bother rebalancing |
723 | * but put our right-hand child in our own place. */ | 723 | * but put our right-hand child in our own place. */ |
724 | if (tn->rb.rb_parent) { | 724 | if (rb_parent(&tn->rb)) { |
725 | if (tn->rb.rb_parent->rb_left == &tn->rb) | 725 | if (rb_parent(&tn->rb)->rb_left == &tn->rb) |
726 | tn->rb.rb_parent->rb_left = repl_rb; | 726 | rb_parent(&tn->rb)->rb_left = repl_rb; |
727 | else if (tn->rb.rb_parent->rb_right == &tn->rb) | 727 | else if (rb_parent(&tn->rb)->rb_right == &tn->rb) |
728 | tn->rb.rb_parent->rb_right = repl_rb; | 728 | rb_parent(&tn->rb)->rb_right = repl_rb; |
729 | else BUG(); | 729 | else BUG(); |
730 | } else if (tn->rb.rb_right) | 730 | } else if (tn->rb.rb_right) |
731 | tn->rb.rb_right->rb_parent = NULL; | 731 | rb_set_parent(tn->rb.rb_right, NULL); |
732 | 732 | ||
733 | jffs2_free_tmp_dnode_info(tn); | 733 | jffs2_free_tmp_dnode_info(tn); |
734 | if (ret) { | 734 | if (ret) { |
diff --git a/include/linux/hrtimer.h b/include/linux/hrtimer.h index 306acf1dc6d5..7d2a1b974c5e 100644 --- a/include/linux/hrtimer.h +++ b/include/linux/hrtimer.h | |||
@@ -127,7 +127,7 @@ extern ktime_t hrtimer_get_next_event(void); | |||
127 | 127 | ||
128 | static inline int hrtimer_active(const struct hrtimer *timer) | 128 | static inline int hrtimer_active(const struct hrtimer *timer) |
129 | { | 129 | { |
130 | return timer->node.rb_parent != HRTIMER_INACTIVE; | 130 | return rb_parent(&timer->node) != &timer->node; |
131 | } | 131 | } |
132 | 132 | ||
133 | /* Forward a hrtimer so it expires after now: */ | 133 | /* Forward a hrtimer so it expires after now: */ |
diff --git a/include/linux/rbtree.h b/include/linux/rbtree.h index 4b7cc4fe366d..f37006f21664 100644 --- a/include/linux/rbtree.h +++ b/include/linux/rbtree.h | |||
@@ -99,19 +99,36 @@ static inline struct page * rb_insert_page_cache(struct inode * inode, | |||
99 | 99 | ||
100 | struct rb_node | 100 | struct rb_node |
101 | { | 101 | { |
102 | struct rb_node *rb_parent; | 102 | unsigned long rb_parent_color; |
103 | int rb_color; | ||
104 | #define RB_RED 0 | 103 | #define RB_RED 0 |
105 | #define RB_BLACK 1 | 104 | #define RB_BLACK 1 |
106 | struct rb_node *rb_right; | 105 | struct rb_node *rb_right; |
107 | struct rb_node *rb_left; | 106 | struct rb_node *rb_left; |
108 | }; | 107 | } __attribute__((aligned(sizeof(long)))); |
108 | /* The alignment might seem pointless, but allegedly CRIS needs it */ | ||
109 | 109 | ||
110 | struct rb_root | 110 | struct rb_root |
111 | { | 111 | { |
112 | struct rb_node *rb_node; | 112 | struct rb_node *rb_node; |
113 | }; | 113 | }; |
114 | 114 | ||
115 | |||
116 | #define rb_parent(r) ((struct rb_node *)((r)->rb_parent_color & ~3)) | ||
117 | #define rb_color(r) ((r)->rb_parent_color & 1) | ||
118 | #define rb_is_red(r) (!rb_color(r)) | ||
119 | #define rb_is_black(r) rb_color(r) | ||
120 | #define rb_set_red(r) do { (r)->rb_parent_color &= ~1; } while (0) | ||
121 | #define rb_set_black(r) do { (r)->rb_parent_color |= 1; } while (0) | ||
122 | |||
123 | static inline void rb_set_parent(struct rb_node *rb, struct rb_node *p) | ||
124 | { | ||
125 | rb->rb_parent_color = (rb->rb_parent_color & 3) | (unsigned long)p; | ||
126 | } | ||
127 | static inline void rb_set_color(struct rb_node *rb, int color) | ||
128 | { | ||
129 | rb->rb_parent_color = (rb->rb_parent_color & ~1) | color; | ||
130 | } | ||
131 | |||
115 | #define RB_ROOT (struct rb_root) { NULL, } | 132 | #define RB_ROOT (struct rb_root) { NULL, } |
116 | #define rb_entry(ptr, type, member) container_of(ptr, type, member) | 133 | #define rb_entry(ptr, type, member) container_of(ptr, type, member) |
117 | 134 | ||
@@ -131,8 +148,7 @@ extern void rb_replace_node(struct rb_node *victim, struct rb_node *new, | |||
131 | static inline void rb_link_node(struct rb_node * node, struct rb_node * parent, | 148 | static inline void rb_link_node(struct rb_node * node, struct rb_node * parent, |
132 | struct rb_node ** rb_link) | 149 | struct rb_node ** rb_link) |
133 | { | 150 | { |
134 | node->rb_parent = parent; | 151 | node->rb_parent_color = (unsigned long )parent; |
135 | node->rb_color = RB_RED; | ||
136 | node->rb_left = node->rb_right = NULL; | 152 | node->rb_left = node->rb_right = NULL; |
137 | 153 | ||
138 | *rb_link = node; | 154 | *rb_link = node; |
diff --git a/kernel/hrtimer.c b/kernel/hrtimer.c index 01fa2ae98a85..18324305724a 100644 --- a/kernel/hrtimer.c +++ b/kernel/hrtimer.c | |||
@@ -393,7 +393,7 @@ static void __remove_hrtimer(struct hrtimer *timer, struct hrtimer_base *base) | |||
393 | if (base->first == &timer->node) | 393 | if (base->first == &timer->node) |
394 | base->first = rb_next(&timer->node); | 394 | base->first = rb_next(&timer->node); |
395 | rb_erase(&timer->node, &base->active); | 395 | rb_erase(&timer->node, &base->active); |
396 | timer->node.rb_parent = HRTIMER_INACTIVE; | 396 | rb_set_parent(&timer->node, &timer->node); |
397 | } | 397 | } |
398 | 398 | ||
399 | /* | 399 | /* |
@@ -582,7 +582,7 @@ void hrtimer_init(struct hrtimer *timer, clockid_t clock_id, | |||
582 | clock_id = CLOCK_MONOTONIC; | 582 | clock_id = CLOCK_MONOTONIC; |
583 | 583 | ||
584 | timer->base = &bases[clock_id]; | 584 | timer->base = &bases[clock_id]; |
585 | timer->node.rb_parent = HRTIMER_INACTIVE; | 585 | rb_set_parent(&timer->node, &timer->node); |
586 | } | 586 | } |
587 | EXPORT_SYMBOL_GPL(hrtimer_init); | 587 | EXPORT_SYMBOL_GPL(hrtimer_init); |
588 | 588 | ||
diff --git a/lib/rbtree.c b/lib/rbtree.c index 14b791ac5089..1e55ba1c2edf 100644 --- a/lib/rbtree.c +++ b/lib/rbtree.c | |||
@@ -26,60 +26,66 @@ | |||
26 | static void __rb_rotate_left(struct rb_node *node, struct rb_root *root) | 26 | static void __rb_rotate_left(struct rb_node *node, struct rb_root *root) |
27 | { | 27 | { |
28 | struct rb_node *right = node->rb_right; | 28 | struct rb_node *right = node->rb_right; |
29 | struct rb_node *parent = rb_parent(node); | ||
29 | 30 | ||
30 | if ((node->rb_right = right->rb_left)) | 31 | if ((node->rb_right = right->rb_left)) |
31 | right->rb_left->rb_parent = node; | 32 | rb_set_parent(right->rb_left, node); |
32 | right->rb_left = node; | 33 | right->rb_left = node; |
33 | 34 | ||
34 | if ((right->rb_parent = node->rb_parent)) | 35 | rb_set_parent(right, parent); |
36 | |||
37 | if (parent) | ||
35 | { | 38 | { |
36 | if (node == node->rb_parent->rb_left) | 39 | if (node == parent->rb_left) |
37 | node->rb_parent->rb_left = right; | 40 | parent->rb_left = right; |
38 | else | 41 | else |
39 | node->rb_parent->rb_right = right; | 42 | parent->rb_right = right; |
40 | } | 43 | } |
41 | else | 44 | else |
42 | root->rb_node = right; | 45 | root->rb_node = right; |
43 | node->rb_parent = right; | 46 | rb_set_parent(node, right); |
44 | } | 47 | } |
45 | 48 | ||
46 | static void __rb_rotate_right(struct rb_node *node, struct rb_root *root) | 49 | static void __rb_rotate_right(struct rb_node *node, struct rb_root *root) |
47 | { | 50 | { |
48 | struct rb_node *left = node->rb_left; | 51 | struct rb_node *left = node->rb_left; |
52 | struct rb_node *parent = rb_parent(node); | ||
49 | 53 | ||
50 | if ((node->rb_left = left->rb_right)) | 54 | if ((node->rb_left = left->rb_right)) |
51 | left->rb_right->rb_parent = node; | 55 | rb_set_parent(left->rb_right, node); |
52 | left->rb_right = node; | 56 | left->rb_right = node; |
53 | 57 | ||
54 | if ((left->rb_parent = node->rb_parent)) | 58 | rb_set_parent(left, parent); |
59 | |||
60 | if (parent) | ||
55 | { | 61 | { |
56 | if (node == node->rb_parent->rb_right) | 62 | if (node == parent->rb_right) |
57 | node->rb_parent->rb_right = left; | 63 | parent->rb_right = left; |
58 | else | 64 | else |
59 | node->rb_parent->rb_left = left; | 65 | parent->rb_left = left; |
60 | } | 66 | } |
61 | else | 67 | else |
62 | root->rb_node = left; | 68 | root->rb_node = left; |
63 | node->rb_parent = left; | 69 | rb_set_parent(node, left); |
64 | } | 70 | } |
65 | 71 | ||
66 | void rb_insert_color(struct rb_node *node, struct rb_root *root) | 72 | void rb_insert_color(struct rb_node *node, struct rb_root *root) |
67 | { | 73 | { |
68 | struct rb_node *parent, *gparent; | 74 | struct rb_node *parent, *gparent; |
69 | 75 | ||
70 | while ((parent = node->rb_parent) && parent->rb_color == RB_RED) | 76 | while ((parent = rb_parent(node)) && rb_is_red(parent)) |
71 | { | 77 | { |
72 | gparent = parent->rb_parent; | 78 | gparent = rb_parent(parent); |
73 | 79 | ||
74 | if (parent == gparent->rb_left) | 80 | if (parent == gparent->rb_left) |
75 | { | 81 | { |
76 | { | 82 | { |
77 | register struct rb_node *uncle = gparent->rb_right; | 83 | register struct rb_node *uncle = gparent->rb_right; |
78 | if (uncle && uncle->rb_color == RB_RED) | 84 | if (uncle && rb_is_red(uncle)) |
79 | { | 85 | { |
80 | uncle->rb_color = RB_BLACK; | 86 | rb_set_black(uncle); |
81 | parent->rb_color = RB_BLACK; | 87 | rb_set_black(parent); |
82 | gparent->rb_color = RB_RED; | 88 | rb_set_red(gparent); |
83 | node = gparent; | 89 | node = gparent; |
84 | continue; | 90 | continue; |
85 | } | 91 | } |
@@ -94,17 +100,17 @@ void rb_insert_color(struct rb_node *node, struct rb_root *root) | |||
94 | node = tmp; | 100 | node = tmp; |
95 | } | 101 | } |
96 | 102 | ||
97 | parent->rb_color = RB_BLACK; | 103 | rb_set_black(parent); |
98 | gparent->rb_color = RB_RED; | 104 | rb_set_red(gparent); |
99 | __rb_rotate_right(gparent, root); | 105 | __rb_rotate_right(gparent, root); |
100 | } else { | 106 | } else { |
101 | { | 107 | { |
102 | register struct rb_node *uncle = gparent->rb_left; | 108 | register struct rb_node *uncle = gparent->rb_left; |
103 | if (uncle && uncle->rb_color == RB_RED) | 109 | if (uncle && rb_is_red(uncle)) |
104 | { | 110 | { |
105 | uncle->rb_color = RB_BLACK; | 111 | rb_set_black(uncle); |
106 | parent->rb_color = RB_BLACK; | 112 | rb_set_black(parent); |
107 | gparent->rb_color = RB_RED; | 113 | rb_set_red(gparent); |
108 | node = gparent; | 114 | node = gparent; |
109 | continue; | 115 | continue; |
110 | } | 116 | } |
@@ -119,13 +125,13 @@ void rb_insert_color(struct rb_node *node, struct rb_root *root) | |||
119 | node = tmp; | 125 | node = tmp; |
120 | } | 126 | } |
121 | 127 | ||
122 | parent->rb_color = RB_BLACK; | 128 | rb_set_black(parent); |
123 | gparent->rb_color = RB_RED; | 129 | rb_set_red(gparent); |
124 | __rb_rotate_left(gparent, root); | 130 | __rb_rotate_left(gparent, root); |
125 | } | 131 | } |
126 | } | 132 | } |
127 | 133 | ||
128 | root->rb_node->rb_color = RB_BLACK; | 134 | rb_set_black(root->rb_node); |
129 | } | 135 | } |
130 | EXPORT_SYMBOL(rb_insert_color); | 136 | EXPORT_SYMBOL(rb_insert_color); |
131 | 137 | ||
@@ -134,43 +140,40 @@ static void __rb_erase_color(struct rb_node *node, struct rb_node *parent, | |||
134 | { | 140 | { |
135 | struct rb_node *other; | 141 | struct rb_node *other; |
136 | 142 | ||
137 | while ((!node || node->rb_color == RB_BLACK) && node != root->rb_node) | 143 | while ((!node || rb_is_black(node)) && node != root->rb_node) |
138 | { | 144 | { |
139 | if (parent->rb_left == node) | 145 | if (parent->rb_left == node) |
140 | { | 146 | { |
141 | other = parent->rb_right; | 147 | other = parent->rb_right; |
142 | if (other->rb_color == RB_RED) | 148 | if (rb_is_red(other)) |
143 | { | 149 | { |
144 | other->rb_color = RB_BLACK; | 150 | rb_set_black(other); |
145 | parent->rb_color = RB_RED; | 151 | rb_set_red(parent); |
146 | __rb_rotate_left(parent, root); | 152 | __rb_rotate_left(parent, root); |
147 | other = parent->rb_right; | 153 | other = parent->rb_right; |
148 | } | 154 | } |
149 | if ((!other->rb_left || | 155 | if ((!other->rb_left || rb_is_black(other->rb_left)) && |
150 | other->rb_left->rb_color == RB_BLACK) | 156 | (!other->rb_right || rb_is_black(other->rb_right))) |
151 | && (!other->rb_right || | ||
152 | other->rb_right->rb_color == RB_BLACK)) | ||
153 | { | 157 | { |
154 | other->rb_color = RB_RED; | 158 | rb_set_red(other); |
155 | node = parent; | 159 | node = parent; |
156 | parent = node->rb_parent; | 160 | parent = rb_parent(node); |
157 | } | 161 | } |
158 | else | 162 | else |
159 | { | 163 | { |
160 | if (!other->rb_right || | 164 | if (!other->rb_right || rb_is_black(other->rb_right)) |
161 | other->rb_right->rb_color == RB_BLACK) | ||
162 | { | 165 | { |
163 | register struct rb_node *o_left; | 166 | struct rb_node *o_left; |
164 | if ((o_left = other->rb_left)) | 167 | if ((o_left = other->rb_left)) |
165 | o_left->rb_color = RB_BLACK; | 168 | rb_set_black(o_left); |
166 | other->rb_color = RB_RED; | 169 | rb_set_red(other); |
167 | __rb_rotate_right(other, root); | 170 | __rb_rotate_right(other, root); |
168 | other = parent->rb_right; | 171 | other = parent->rb_right; |
169 | } | 172 | } |
170 | other->rb_color = parent->rb_color; | 173 | rb_set_color(other, rb_color(parent)); |
171 | parent->rb_color = RB_BLACK; | 174 | rb_set_black(parent); |
172 | if (other->rb_right) | 175 | if (other->rb_right) |
173 | other->rb_right->rb_color = RB_BLACK; | 176 | rb_set_black(other->rb_right); |
174 | __rb_rotate_left(parent, root); | 177 | __rb_rotate_left(parent, root); |
175 | node = root->rb_node; | 178 | node = root->rb_node; |
176 | break; | 179 | break; |
@@ -179,38 +182,35 @@ static void __rb_erase_color(struct rb_node *node, struct rb_node *parent, | |||
179 | else | 182 | else |
180 | { | 183 | { |
181 | other = parent->rb_left; | 184 | other = parent->rb_left; |
182 | if (other->rb_color == RB_RED) | 185 | if (rb_is_red(other)) |
183 | { | 186 | { |
184 | other->rb_color = RB_BLACK; | 187 | rb_set_black(other); |
185 | parent->rb_color = RB_RED; | 188 | rb_set_red(parent); |
186 | __rb_rotate_right(parent, root); | 189 | __rb_rotate_right(parent, root); |
187 | other = parent->rb_left; | 190 | other = parent->rb_left; |
188 | } | 191 | } |
189 | if ((!other->rb_left || | 192 | if ((!other->rb_left || rb_is_black(other->rb_left)) && |
190 | other->rb_left->rb_color == RB_BLACK) | 193 | (!other->rb_right || rb_is_black(other->rb_right))) |
191 | && (!other->rb_right || | ||
192 | other->rb_right->rb_color == RB_BLACK)) | ||
193 | { | 194 | { |
194 | other->rb_color = RB_RED; | 195 | rb_set_red(other); |
195 | node = parent; | 196 | node = parent; |
196 | parent = node->rb_parent; | 197 | parent = rb_parent(node); |
197 | } | 198 | } |
198 | else | 199 | else |
199 | { | 200 | { |
200 | if (!other->rb_left || | 201 | if (!other->rb_left || rb_is_black(other->rb_left)) |
201 | other->rb_left->rb_color == RB_BLACK) | ||
202 | { | 202 | { |
203 | register struct rb_node *o_right; | 203 | register struct rb_node *o_right; |
204 | if ((o_right = other->rb_right)) | 204 | if ((o_right = other->rb_right)) |
205 | o_right->rb_color = RB_BLACK; | 205 | rb_set_black(o_right); |
206 | other->rb_color = RB_RED; | 206 | rb_set_red(other); |
207 | __rb_rotate_left(other, root); | 207 | __rb_rotate_left(other, root); |
208 | other = parent->rb_left; | 208 | other = parent->rb_left; |
209 | } | 209 | } |
210 | other->rb_color = parent->rb_color; | 210 | rb_set_color(other, rb_color(parent)); |
211 | parent->rb_color = RB_BLACK; | 211 | rb_set_black(parent); |
212 | if (other->rb_left) | 212 | if (other->rb_left) |
213 | other->rb_left->rb_color = RB_BLACK; | 213 | rb_set_black(other->rb_left); |
214 | __rb_rotate_right(parent, root); | 214 | __rb_rotate_right(parent, root); |
215 | node = root->rb_node; | 215 | node = root->rb_node; |
216 | break; | 216 | break; |
@@ -218,7 +218,7 @@ static void __rb_erase_color(struct rb_node *node, struct rb_node *parent, | |||
218 | } | 218 | } |
219 | } | 219 | } |
220 | if (node) | 220 | if (node) |
221 | node->rb_color = RB_BLACK; | 221 | rb_set_black(node); |
222 | } | 222 | } |
223 | 223 | ||
224 | void rb_erase(struct rb_node *node, struct rb_root *root) | 224 | void rb_erase(struct rb_node *node, struct rb_root *root) |
@@ -238,48 +238,41 @@ void rb_erase(struct rb_node *node, struct rb_root *root) | |||
238 | while ((left = node->rb_left) != NULL) | 238 | while ((left = node->rb_left) != NULL) |
239 | node = left; | 239 | node = left; |
240 | child = node->rb_right; | 240 | child = node->rb_right; |
241 | parent = node->rb_parent; | 241 | parent = rb_parent(node); |
242 | color = node->rb_color; | 242 | color = rb_color(node); |
243 | 243 | ||
244 | if (child) | 244 | if (child) |
245 | child->rb_parent = parent; | 245 | rb_set_parent(child, parent); |
246 | if (parent) | 246 | if (parent == old) { |
247 | { | 247 | parent->rb_right = child; |
248 | if (parent->rb_left == node) | ||
249 | parent->rb_left = child; | ||
250 | else | ||
251 | parent->rb_right = child; | ||
252 | } | ||
253 | else | ||
254 | root->rb_node = child; | ||
255 | |||
256 | if (node->rb_parent == old) | ||
257 | parent = node; | 248 | parent = node; |
258 | node->rb_parent = old->rb_parent; | 249 | } else |
259 | node->rb_color = old->rb_color; | 250 | parent->rb_left = child; |
251 | |||
252 | node->rb_parent_color = old->rb_parent_color; | ||
260 | node->rb_right = old->rb_right; | 253 | node->rb_right = old->rb_right; |
261 | node->rb_left = old->rb_left; | 254 | node->rb_left = old->rb_left; |
262 | 255 | ||
263 | if (old->rb_parent) | 256 | if (rb_parent(old)) |
264 | { | 257 | { |
265 | if (old->rb_parent->rb_left == old) | 258 | if (rb_parent(old)->rb_left == old) |
266 | old->rb_parent->rb_left = node; | 259 | rb_parent(old)->rb_left = node; |
267 | else | 260 | else |
268 | old->rb_parent->rb_right = node; | 261 | rb_parent(old)->rb_right = node; |
269 | } else | 262 | } else |
270 | root->rb_node = node; | 263 | root->rb_node = node; |
271 | 264 | ||
272 | old->rb_left->rb_parent = node; | 265 | rb_set_parent(old->rb_left, node); |
273 | if (old->rb_right) | 266 | if (old->rb_right) |
274 | old->rb_right->rb_parent = node; | 267 | rb_set_parent(old->rb_right, node); |
275 | goto color; | 268 | goto color; |
276 | } | 269 | } |
277 | 270 | ||
278 | parent = node->rb_parent; | 271 | parent = rb_parent(node); |
279 | color = node->rb_color; | 272 | color = rb_color(node); |
280 | 273 | ||
281 | if (child) | 274 | if (child) |
282 | child->rb_parent = parent; | 275 | rb_set_parent(child, parent); |
283 | if (parent) | 276 | if (parent) |
284 | { | 277 | { |
285 | if (parent->rb_left == node) | 278 | if (parent->rb_left == node) |
@@ -327,6 +320,8 @@ EXPORT_SYMBOL(rb_last); | |||
327 | 320 | ||
328 | struct rb_node *rb_next(struct rb_node *node) | 321 | struct rb_node *rb_next(struct rb_node *node) |
329 | { | 322 | { |
323 | struct rb_node *parent; | ||
324 | |||
330 | /* If we have a right-hand child, go down and then left as far | 325 | /* If we have a right-hand child, go down and then left as far |
331 | as we can. */ | 326 | as we can. */ |
332 | if (node->rb_right) { | 327 | if (node->rb_right) { |
@@ -342,15 +337,17 @@ struct rb_node *rb_next(struct rb_node *node) | |||
342 | ancestor is a right-hand child of its parent, keep going | 337 | ancestor is a right-hand child of its parent, keep going |
343 | up. First time it's a left-hand child of its parent, said | 338 | up. First time it's a left-hand child of its parent, said |
344 | parent is our 'next' node. */ | 339 | parent is our 'next' node. */ |
345 | while (node->rb_parent && node == node->rb_parent->rb_right) | 340 | while ((parent = rb_parent(node)) && node == parent->rb_right) |
346 | node = node->rb_parent; | 341 | node = parent; |
347 | 342 | ||
348 | return node->rb_parent; | 343 | return parent; |
349 | } | 344 | } |
350 | EXPORT_SYMBOL(rb_next); | 345 | EXPORT_SYMBOL(rb_next); |
351 | 346 | ||
352 | struct rb_node *rb_prev(struct rb_node *node) | 347 | struct rb_node *rb_prev(struct rb_node *node) |
353 | { | 348 | { |
349 | struct rb_node *parent; | ||
350 | |||
354 | /* If we have a left-hand child, go down and then right as far | 351 | /* If we have a left-hand child, go down and then right as far |
355 | as we can. */ | 352 | as we can. */ |
356 | if (node->rb_left) { | 353 | if (node->rb_left) { |
@@ -362,17 +359,17 @@ struct rb_node *rb_prev(struct rb_node *node) | |||
362 | 359 | ||
363 | /* No left-hand children. Go up till we find an ancestor which | 360 | /* No left-hand children. Go up till we find an ancestor which |
364 | is a right-hand child of its parent */ | 361 | is a right-hand child of its parent */ |
365 | while (node->rb_parent && node == node->rb_parent->rb_left) | 362 | while ((parent = rb_parent(node)) && node == parent->rb_left) |
366 | node = node->rb_parent; | 363 | node = parent; |
367 | 364 | ||
368 | return node->rb_parent; | 365 | return parent; |
369 | } | 366 | } |
370 | EXPORT_SYMBOL(rb_prev); | 367 | EXPORT_SYMBOL(rb_prev); |
371 | 368 | ||
372 | void rb_replace_node(struct rb_node *victim, struct rb_node *new, | 369 | void rb_replace_node(struct rb_node *victim, struct rb_node *new, |
373 | struct rb_root *root) | 370 | struct rb_root *root) |
374 | { | 371 | { |
375 | struct rb_node *parent = victim->rb_parent; | 372 | struct rb_node *parent = rb_parent(victim); |
376 | 373 | ||
377 | /* Set the surrounding nodes to point to the replacement */ | 374 | /* Set the surrounding nodes to point to the replacement */ |
378 | if (parent) { | 375 | if (parent) { |
@@ -384,9 +381,9 @@ void rb_replace_node(struct rb_node *victim, struct rb_node *new, | |||
384 | root->rb_node = new; | 381 | root->rb_node = new; |
385 | } | 382 | } |
386 | if (victim->rb_left) | 383 | if (victim->rb_left) |
387 | victim->rb_left->rb_parent = new; | 384 | rb_set_parent(victim->rb_left, new); |
388 | if (victim->rb_right) | 385 | if (victim->rb_right) |
389 | victim->rb_right->rb_parent = new; | 386 | rb_set_parent(victim->rb_right, new); |
390 | 387 | ||
391 | /* Copy the pointers/colour from the victim to the replacement */ | 388 | /* Copy the pointers/colour from the victim to the replacement */ |
392 | *new = *victim; | 389 | *new = *victim; |
diff --git a/security/keys/key.c b/security/keys/key.c index b6061fa29da7..3fdc49c6a02c 100644 --- a/security/keys/key.c +++ b/security/keys/key.c | |||
@@ -211,12 +211,12 @@ static inline void key_alloc_serial(struct key *key) | |||
211 | key->serial = 2; | 211 | key->serial = 2; |
212 | key_serial_next = key->serial + 1; | 212 | key_serial_next = key->serial + 1; |
213 | 213 | ||
214 | if (!parent->rb_parent) | 214 | if (!rb_parent(parent)) |
215 | p = &key_serial_tree.rb_node; | 215 | p = &key_serial_tree.rb_node; |
216 | else if (parent->rb_parent->rb_left == parent) | 216 | else if (rb_parent(parent)->rb_left == parent) |
217 | p = &parent->rb_parent->rb_left; | 217 | p = &(rb_parent(parent)->rb_left); |
218 | else | 218 | else |
219 | p = &parent->rb_parent->rb_right; | 219 | p = &(rb_parent(parent)->rb_right); |
220 | 220 | ||
221 | parent = rb_next(parent); | 221 | parent = rb_next(parent); |
222 | if (!parent) | 222 | if (!parent) |