Line data Source code
1 : /*
2 : Red Black Trees
3 : (C) 1999 Andrea Arcangeli <andrea@suse.de>
4 : (C) 2002 David Woodhouse <dwmw2@infradead.org>
5 :
6 : This program is free software; you can redistribute it and/or modify
7 : it under the terms of the GNU General Public License as published by
8 : the Free Software Foundation; either version 2 of the License, or
9 : (at your option) any later version.
10 :
11 : This program is distributed in the hope that it will be useful,
12 : but WITHOUT ANY WARRANTY; without even the implied warranty of
13 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 : GNU General Public License for more details.
15 :
16 : You should have received a copy of the GNU General Public License
17 : along with this program; if not, write to the Free Software
18 : Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 :
20 : linux/lib/rbtree.c
21 : */
22 :
23 : #include "replace.h"
24 : #include "rbtree.h"
25 : #include "fault.h"
26 :
27 : #define RB_RED 0
28 : #define RB_BLACK 1
29 :
30 : #define rb_parent(r) ((struct rb_node *)((r)->rb_parent_color & ~3))
31 : #define rb_color(r) ((r)->rb_parent_color & 1)
32 : #define rb_is_red(r) (!rb_color(r))
33 : #define rb_is_black(r) rb_color(r)
34 : #define rb_set_red(r) do { (r)->rb_parent_color &= ~1; } while (0)
35 : #define rb_set_black(r) do { (r)->rb_parent_color |= 1; } while (0)
36 :
37 5383535 : static void rb_set_parent(struct rb_node *rb, struct rb_node *p)
38 : {
39 5383535 : rb->rb_parent_color = (rb->rb_parent_color & 3) | (unsigned long)p;
40 5328910 : }
41 35612 : static void rb_set_color(struct rb_node *rb, int color)
42 : {
43 35612 : rb->rb_parent_color = (rb->rb_parent_color & ~1) | color;
44 35312 : }
45 :
46 : #define RB_EMPTY_ROOT(root) ((root)->rb_node == NULL)
47 : #define RB_EMPTY_NODE(node) (rb_parent(node) == node)
48 : #define RB_CLEAR_NODE(node) (rb_set_parent(node, node))
49 :
50 1245544 : static void __rb_rotate_left(struct rb_node *node, struct rb_root *root)
51 : {
52 1245544 : struct rb_node *right = node->rb_right;
53 1245544 : struct rb_node *parent = rb_parent(node);
54 :
55 1245544 : if ((node->rb_right = right->rb_left))
56 296038 : rb_set_parent(right->rb_left, node);
57 1245544 : right->rb_left = node;
58 :
59 1245544 : rb_set_parent(right, parent);
60 :
61 1245544 : if (parent)
62 : {
63 1091159 : if (node == parent->rb_left)
64 691789 : parent->rb_left = right;
65 : else
66 399370 : parent->rb_right = right;
67 : }
68 : else
69 154385 : root->rb_node = right;
70 1245544 : rb_set_parent(node, right);
71 1245544 : }
72 :
73 1006388 : static void __rb_rotate_right(struct rb_node *node, struct rb_root *root)
74 : {
75 1006388 : struct rb_node *left = node->rb_left;
76 1006388 : struct rb_node *parent = rb_parent(node);
77 :
78 1006388 : if ((node->rb_left = left->rb_right))
79 227574 : rb_set_parent(left->rb_right, node);
80 1006388 : left->rb_right = node;
81 :
82 1006388 : rb_set_parent(left, parent);
83 :
84 1006388 : if (parent)
85 : {
86 930943 : if (node == parent->rb_right)
87 641377 : parent->rb_right = left;
88 : else
89 289566 : parent->rb_left = left;
90 : }
91 : else
92 75445 : root->rb_node = left;
93 1006388 : rb_set_parent(node, left);
94 1006388 : }
95 :
96 4361658 : void rb_insert_color(struct rb_node *node, struct rb_root *root)
97 : {
98 48645 : struct rb_node *parent, *gparent;
99 :
100 7349279 : while ((parent = rb_parent(node)) && rb_is_red(parent))
101 : {
102 2987621 : gparent = rb_parent(parent);
103 :
104 2987621 : if (parent == gparent->rb_left)
105 : {
106 : {
107 1331330 : register struct rb_node *uncle = gparent->rb_right;
108 1331330 : if (uncle && rb_is_red(uncle))
109 : {
110 621148 : rb_set_black(uncle);
111 621148 : rb_set_black(parent);
112 621148 : rb_set_red(gparent);
113 621148 : node = gparent;
114 621148 : continue;
115 : }
116 : }
117 :
118 710182 : if (parent->rb_right == node)
119 : {
120 4080 : register struct rb_node *tmp;
121 426806 : __rb_rotate_left(parent, root);
122 426806 : tmp = parent;
123 426806 : parent = node;
124 426806 : node = tmp;
125 : }
126 :
127 710182 : rb_set_black(parent);
128 710182 : rb_set_red(gparent);
129 710182 : __rb_rotate_right(gparent, root);
130 : } else {
131 : {
132 1656291 : register struct rb_node *uncle = gparent->rb_left;
133 1656291 : if (uncle && rb_is_red(uncle))
134 : {
135 876791 : rb_set_black(uncle);
136 876791 : rb_set_black(parent);
137 876791 : rb_set_red(gparent);
138 876791 : node = gparent;
139 876791 : continue;
140 : }
141 : }
142 :
143 779500 : if (parent->rb_left == node)
144 : {
145 4814 : register struct rb_node *tmp;
146 260815 : __rb_rotate_right(parent, root);
147 260815 : tmp = parent;
148 260815 : parent = node;
149 260815 : node = tmp;
150 : }
151 :
152 779500 : rb_set_black(parent);
153 779500 : rb_set_red(gparent);
154 779500 : __rb_rotate_left(gparent, root);
155 : }
156 : }
157 :
158 4361658 : rb_set_black(root->rb_node);
159 4361658 : }
160 :
161 234485 : static void __rb_erase_color(struct rb_node *node, struct rb_node *parent,
162 : struct rb_root *root)
163 : {
164 2510 : struct rb_node *other;
165 :
166 318768 : while ((!node || rb_is_black(node)) && node != root->rb_node)
167 : {
168 119895 : if (parent->rb_left == node)
169 : {
170 65087 : other = parent->rb_right;
171 65087 : if (other == NULL) {
172 : /* we should never get here */
173 0 : smb_panic("corrupted rb tree");
174 : /* satisfy static checkers */
175 : return;
176 : }
177 65087 : if (rb_is_red(other))
178 : {
179 11800 : rb_set_black(other);
180 11800 : rb_set_red(parent);
181 11800 : __rb_rotate_left(parent, root);
182 11800 : other = parent->rb_right;
183 : }
184 65087 : if ((!other->rb_left || rb_is_black(other->rb_left)) &&
185 51150 : (!other->rb_right || rb_is_black(other->rb_right)))
186 : {
187 46022 : rb_set_red(other);
188 46022 : node = parent;
189 46022 : parent = rb_parent(node);
190 : }
191 : else
192 : {
193 19065 : if (!other->rb_right || rb_is_black(other->rb_right))
194 : {
195 51 : struct rb_node *o_left;
196 9330 : if ((o_left = other->rb_left))
197 9330 : rb_set_black(o_left);
198 9330 : rb_set_red(other);
199 9330 : __rb_rotate_right(other, root);
200 9330 : other = parent->rb_right;
201 : }
202 19065 : rb_set_color(other, rb_color(parent));
203 19065 : rb_set_black(parent);
204 19065 : if (other->rb_right)
205 19065 : rb_set_black(other->rb_right);
206 19065 : __rb_rotate_left(parent, root);
207 19065 : node = root->rb_node;
208 19065 : break;
209 : }
210 : }
211 : else
212 : {
213 54808 : other = parent->rb_left;
214 54808 : if (rb_is_red(other))
215 : {
216 9514 : rb_set_black(other);
217 9514 : rb_set_red(parent);
218 9514 : __rb_rotate_right(parent, root);
219 9514 : other = parent->rb_left;
220 : }
221 54808 : if ((!other->rb_left || rb_is_black(other->rb_left)) &&
222 46634 : (!other->rb_right || rb_is_black(other->rb_right)))
223 : {
224 38261 : rb_set_red(other);
225 38261 : node = parent;
226 38261 : parent = rb_parent(node);
227 : }
228 : else
229 : {
230 16547 : if (!other->rb_left || rb_is_black(other->rb_left))
231 : {
232 62 : register struct rb_node *o_right;
233 8373 : if ((o_right = other->rb_right))
234 8373 : rb_set_black(o_right);
235 8373 : rb_set_red(other);
236 8373 : __rb_rotate_left(other, root);
237 8373 : other = parent->rb_left;
238 : }
239 16547 : rb_set_color(other, rb_color(parent));
240 16547 : rb_set_black(parent);
241 16547 : if (other->rb_left)
242 16547 : rb_set_black(other->rb_left);
243 16547 : __rb_rotate_right(parent, root);
244 16547 : node = root->rb_node;
245 16547 : break;
246 : }
247 : }
248 : }
249 234485 : if (node)
250 159328 : rb_set_black(node);
251 : }
252 :
253 784856 : void rb_erase(struct rb_node *node, struct rb_root *root)
254 : {
255 4277 : struct rb_node *child, *parent;
256 4277 : int color;
257 :
258 784856 : if (!node->rb_left)
259 563498 : child = node->rb_right;
260 221358 : else if (!node->rb_right)
261 26057 : child = node->rb_left;
262 : else
263 : {
264 194708 : struct rb_node *old = node, *left;
265 :
266 194708 : node = node->rb_right;
267 339161 : while ((left = node->rb_left) != NULL)
268 143683 : node = left;
269 195109 : child = node->rb_right;
270 195109 : parent = rb_parent(node);
271 195109 : color = rb_color(node);
272 :
273 195109 : if (child)
274 20971 : rb_set_parent(child, parent);
275 195109 : if (parent == old) {
276 116549 : parent->rb_right = child;
277 116549 : parent = node;
278 : } else
279 78560 : parent->rb_left = child;
280 :
281 195109 : node->rb_parent_color = old->rb_parent_color;
282 195109 : node->rb_right = old->rb_right;
283 195109 : node->rb_left = old->rb_left;
284 :
285 195109 : if (rb_parent(old))
286 : {
287 186499 : if (rb_parent(old)->rb_left == old)
288 63214 : rb_parent(old)->rb_left = node;
289 : else
290 123285 : rb_parent(old)->rb_right = node;
291 : } else
292 8610 : root->rb_node = node;
293 :
294 195109 : rb_set_parent(old->rb_left, node);
295 195109 : if (old->rb_right)
296 86494 : rb_set_parent(old->rb_right, node);
297 195109 : goto color;
298 : }
299 :
300 589747 : parent = rb_parent(node);
301 589747 : color = rb_color(node);
302 :
303 589747 : if (child)
304 53485 : rb_set_parent(child, parent);
305 589747 : if (parent)
306 : {
307 513791 : if (parent->rb_left == node)
308 78382 : parent->rb_left = child;
309 : else
310 435409 : parent->rb_right = child;
311 : }
312 : else
313 75956 : root->rb_node = child;
314 :
315 784856 : color:
316 784856 : if (color == RB_BLACK)
317 234485 : __rb_erase_color(child, parent, root);
318 784856 : }
319 :
320 : /*
321 : * This function returns the first node (in sort order) of the tree.
322 : */
323 0 : struct rb_node *rb_first(struct rb_root *root)
324 : {
325 0 : struct rb_node *n;
326 :
327 0 : n = root->rb_node;
328 0 : if (!n)
329 0 : return NULL;
330 0 : while (n->rb_left)
331 0 : n = n->rb_left;
332 0 : return n;
333 : }
334 :
335 0 : struct rb_node *rb_last(struct rb_root *root)
336 : {
337 0 : struct rb_node *n;
338 :
339 0 : n = root->rb_node;
340 0 : if (!n)
341 0 : return NULL;
342 0 : while (n->rb_right)
343 0 : n = n->rb_right;
344 0 : return n;
345 : }
346 :
347 42012 : struct rb_node *rb_next(struct rb_node *node)
348 : {
349 1 : struct rb_node *parent;
350 :
351 42012 : if (rb_parent(node) == node)
352 0 : return NULL;
353 :
354 : /* If we have a right-hand child, go down and then left as far
355 : as we can. */
356 42012 : if (node->rb_right) {
357 20065 : node = node->rb_right;
358 20079 : while (node->rb_left)
359 14 : node=node->rb_left;
360 20065 : return node;
361 : }
362 :
363 : /* No right-hand children. Everything down and left is
364 : smaller than us, so any 'next' node must be in the general
365 : direction of our parent. Go up the tree; any time the
366 : ancestor is a right-hand child of its parent, keep going
367 : up. First time it's a left-hand child of its parent, said
368 : parent is our 'next' node. */
369 44307 : while ((parent = rb_parent(node)) && node == parent->rb_right)
370 22360 : node = parent;
371 :
372 21946 : return parent;
373 : }
374 :
375 21898 : struct rb_node *rb_prev(struct rb_node *node)
376 : {
377 1 : struct rb_node *parent;
378 :
379 21898 : if (rb_parent(node) == node)
380 0 : return NULL;
381 :
382 : /* If we have a left-hand child, go down and then right as far
383 : as we can. */
384 21898 : if (node->rb_left) {
385 154 : node = node->rb_left;
386 154 : while (node->rb_right)
387 0 : node=node->rb_right;
388 154 : return node;
389 : }
390 :
391 : /* No left-hand children. Go up till we find an ancestor which
392 : is a right-hand child of its parent */
393 21795 : while ((parent = rb_parent(node)) && node == parent->rb_left)
394 51 : node = parent;
395 :
396 21743 : return parent;
397 : }
398 :
399 0 : void rb_replace_node(struct rb_node *victim, struct rb_node *new_node,
400 : struct rb_root *root)
401 : {
402 0 : struct rb_node *parent = rb_parent(victim);
403 :
404 : /* Set the surrounding nodes to point to the replacement */
405 0 : if (parent) {
406 0 : if (victim == parent->rb_left)
407 0 : parent->rb_left = new_node;
408 : else
409 0 : parent->rb_right = new_node;
410 : } else {
411 0 : root->rb_node = new_node;
412 : }
413 0 : if (victim->rb_left)
414 0 : rb_set_parent(victim->rb_left, new_node);
415 0 : if (victim->rb_right)
416 0 : rb_set_parent(victim->rb_right, new_node);
417 :
418 : /* Copy the pointers/colour from the victim to the replacement */
419 0 : *new_node = *victim;
420 0 : }
421 :
422 4361658 : void rb_link_node(struct rb_node * node, struct rb_node * parent,
423 : struct rb_node ** rb_link)
424 : {
425 4361658 : node->rb_parent_color = (unsigned long )parent;
426 4361658 : node->rb_left = node->rb_right = NULL;
427 :
428 4361658 : *rb_link = node;
429 4361658 : }
|