Commit 330018fe authored by Peng Zhang's avatar Peng Zhang Committed by Andrew Morton

maple_tree: simplify mas_leaf_set_meta()

Now it seems that the incoming 'end' is already pointing to the last item,
so we can simplify this function, considering only whether the last slot
is being used.  This has passed the maple tree test suite.

Link: https://lkml.kernel.org/r/20231120070937.35481-6-zhangpeng.00@bytedance.comSigned-off-by: default avatarPeng Zhang <zhangpeng.00@bytedance.com>
Reviewed-by: default avatarLiam R. Howlett <Liam.Howlett@oracle.com>
Cc: Dan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 026b935c
...@@ -1964,27 +1964,13 @@ static inline void mas_mab_cp(struct ma_state *mas, unsigned char mas_start, ...@@ -1964,27 +1964,13 @@ static inline void mas_mab_cp(struct ma_state *mas, unsigned char mas_start,
/* /*
* mas_leaf_set_meta() - Set the metadata of a leaf if possible. * mas_leaf_set_meta() - Set the metadata of a leaf if possible.
* @mas: The maple state
* @node: The maple node * @node: The maple node
* @pivots: pointer to the maple node pivots
* @mt: The maple type * @mt: The maple type
* @end: The assumed end * @end: The node end
*
* Note, end may be incremented within this function but not modified at the
* source. This is fine since the metadata is the last thing to be stored in a
* node during a write.
*/ */
static inline void mas_leaf_set_meta(struct ma_state *mas, static inline void mas_leaf_set_meta(struct maple_node *node,
struct maple_node *node, unsigned long *pivots,
enum maple_type mt, unsigned char end) enum maple_type mt, unsigned char end)
{ {
/* There is no room for metadata already */
if (mt_pivots[mt] <= end)
return;
if (pivots[end] && pivots[end] < mas->max)
end++;
if (end < mt_slots[mt] - 1) if (end < mt_slots[mt] - 1)
ma_set_meta(node, mt, 0, end); ma_set_meta(node, mt, 0, end);
} }
...@@ -2041,7 +2027,7 @@ static inline void mab_mas_cp(struct maple_big_node *b_node, ...@@ -2041,7 +2027,7 @@ static inline void mab_mas_cp(struct maple_big_node *b_node,
ma_set_meta(node, mt, offset, end); ma_set_meta(node, mt, offset, end);
} else { } else {
mas_leaf_set_meta(mas, node, pivots, mt, end); mas_leaf_set_meta(node, mt, end);
} }
} }
...@@ -3962,7 +3948,7 @@ static inline bool mas_wr_node_store(struct ma_wr_state *wr_mas, ...@@ -3962,7 +3948,7 @@ static inline bool mas_wr_node_store(struct ma_wr_state *wr_mas,
dst_pivots[new_end] = mas->max; dst_pivots[new_end] = mas->max;
done: done:
mas_leaf_set_meta(mas, newnode, dst_pivots, maple_leaf_64, new_end); mas_leaf_set_meta(newnode, maple_leaf_64, new_end);
if (in_rcu) { if (in_rcu) {
struct maple_enode *old_enode = mas->node; struct maple_enode *old_enode = mas->node;
......
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