diff options
Diffstat (limited to 'lib/rbtree.c')
| -rw-r--r-- | lib/rbtree.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/rbtree.c b/lib/rbtree.c index 1e55ba1c2edf..48499c2d88cc 100644 --- a/lib/rbtree.c +++ b/lib/rbtree.c | |||
| @@ -322,6 +322,9 @@ struct rb_node *rb_next(struct rb_node *node) | |||
| 322 | { | 322 | { |
| 323 | struct rb_node *parent; | 323 | struct rb_node *parent; |
| 324 | 324 | ||
| 325 | if (rb_parent(node) == node) | ||
| 326 | return NULL; | ||
| 327 | |||
| 325 | /* If we have a right-hand child, go down and then left as far | 328 | /* If we have a right-hand child, go down and then left as far |
| 326 | as we can. */ | 329 | as we can. */ |
| 327 | if (node->rb_right) { | 330 | if (node->rb_right) { |
| @@ -348,6 +351,9 @@ struct rb_node *rb_prev(struct rb_node *node) | |||
| 348 | { | 351 | { |
| 349 | struct rb_node *parent; | 352 | struct rb_node *parent; |
| 350 | 353 | ||
| 354 | if (rb_parent(node) == node) | ||
| 355 | return NULL; | ||
| 356 | |||
| 351 | /* If we have a left-hand child, go down and then right as far | 357 | /* If we have a left-hand child, go down and then right as far |
| 352 | as we can. */ | 358 | as we can. */ |
| 353 | if (node->rb_left) { | 359 | if (node->rb_left) { |
