diff options
author | Lai Jiangshan <laijs@cn.fujitsu.com> | 2014-09-18 10:49:42 -0400 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2014-09-18 11:00:17 -0400 |
commit | e9f05b4cfed38d0e57b0a705a7f480cfbe0c3247 (patch) | |
tree | 9b0a98ac1bb1cc83947c5b9843ab72f89a8644ac /drivers/block | |
parent | 82cfb90bc99d7b7e0ec62d0505b9d4f06805d5db (diff) |
drbd: use RB_DECLARE_CALLBACKS() to define augment callbacks
The original code are the same as RB_DECLARE_CALLBACKS().
CC: Michel Lespinasse <walken@google.com>
Signed-off-by: Lai Jiangshan <laijs@cn.fujitsu.com>
Signed-off-by: Andreas Gruenbacher <agruen@linbit.com>
Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/drbd/drbd_interval.c | 36 |
1 files changed, 2 insertions, 34 deletions
diff --git a/drivers/block/drbd/drbd_interval.c b/drivers/block/drbd/drbd_interval.c index 04a14e0f8878..51b25ad85251 100644 --- a/drivers/block/drbd/drbd_interval.c +++ b/drivers/block/drbd/drbd_interval.c | |||
@@ -37,40 +37,8 @@ compute_subtree_last(struct drbd_interval *node) | |||
37 | return max; | 37 | return max; |
38 | } | 38 | } |
39 | 39 | ||
40 | static void augment_propagate(struct rb_node *rb, struct rb_node *stop) | 40 | RB_DECLARE_CALLBACKS(static, augment_callbacks, struct drbd_interval, rb, |
41 | { | 41 | sector_t, end, compute_subtree_last); |
42 | while (rb != stop) { | ||
43 | struct drbd_interval *node = rb_entry(rb, struct drbd_interval, rb); | ||
44 | sector_t subtree_last = compute_subtree_last(node); | ||
45 | if (node->end == subtree_last) | ||
46 | break; | ||
47 | node->end = subtree_last; | ||
48 | rb = rb_parent(&node->rb); | ||
49 | } | ||
50 | } | ||
51 | |||
52 | static void augment_copy(struct rb_node *rb_old, struct rb_node *rb_new) | ||
53 | { | ||
54 | struct drbd_interval *old = rb_entry(rb_old, struct drbd_interval, rb); | ||
55 | struct drbd_interval *new = rb_entry(rb_new, struct drbd_interval, rb); | ||
56 | |||
57 | new->end = old->end; | ||
58 | } | ||
59 | |||
60 | static void augment_rotate(struct rb_node *rb_old, struct rb_node *rb_new) | ||
61 | { | ||
62 | struct drbd_interval *old = rb_entry(rb_old, struct drbd_interval, rb); | ||
63 | struct drbd_interval *new = rb_entry(rb_new, struct drbd_interval, rb); | ||
64 | |||
65 | new->end = old->end; | ||
66 | old->end = compute_subtree_last(old); | ||
67 | } | ||
68 | |||
69 | static const struct rb_augment_callbacks augment_callbacks = { | ||
70 | augment_propagate, | ||
71 | augment_copy, | ||
72 | augment_rotate, | ||
73 | }; | ||
74 | 42 | ||
75 | /** | 43 | /** |
76 | * drbd_insert_interval - insert a new interval into a tree | 44 | * drbd_insert_interval - insert a new interval into a tree |