Commit 8b7569a2 authored by Wei Yang's avatar Wei Yang Committed by Linus Torvalds

lib/rbtree: get successor's color directly

After move parent assignment out, we can check the color directly.

Link: http://lkml.kernel.org/r/20191028021442.5450-2-richardw.yang@linux.intel.comSigned-off-by: default avatarWei Yang <richardw.yang@linux.intel.com>
Acked-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: default avatarMichel Lespinasse <walken@google.com>
Reviewed-by: default avatarDavidlohr Bueso <dbueso@suse.de>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 11d43e62
...@@ -286,8 +286,7 @@ __rb_erase_augmented(struct rb_node *node, struct rb_root *root, ...@@ -286,8 +286,7 @@ __rb_erase_augmented(struct rb_node *node, struct rb_root *root,
rb_set_parent_color(child2, parent, RB_BLACK); rb_set_parent_color(child2, parent, RB_BLACK);
rebalance = NULL; rebalance = NULL;
} else { } else {
unsigned long pc2 = successor->__rb_parent_color; rebalance = rb_is_black(successor) ? parent : NULL;
rebalance = __rb_is_black(pc2) ? parent : NULL;
} }
successor->__rb_parent_color = pc; successor->__rb_parent_color = pc;
tmp = successor; tmp = successor;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment