mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 10:43:43 +00:00
maple_tree: simplify mas_push_node()
When count is not 0, we know head is valid. So we can put the assignment in if (count) instead of checking the head pointer again. Also count represents current total, we can assign the new total by increasing the count by one. Link: https://lkml.kernel.org/r/20241015120746.15850-4-richard.weiyang@gmail.com Signed-off-by: Wei Yang <richard.weiyang@gmail.com> Reviewed-by: Liam R. Howlett <Liam.Howlett@Oracle.com> Cc: Sidhartha Kumar <sidhartha.kumar@oracle.com> Cc: Lorenzo Stoakes <lorenzo.stoakes@oracle.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
4223dd93bf
commit
908378a30b
@ -1207,19 +1207,17 @@ static inline void mas_push_node(struct ma_state *mas, struct maple_node *used)
|
||||
|
||||
reuse->request_count = 0;
|
||||
reuse->node_count = 0;
|
||||
if (count && (head->node_count < MAPLE_ALLOC_SLOTS)) {
|
||||
head->slot[head->node_count++] = reuse;
|
||||
head->total++;
|
||||
goto done;
|
||||
}
|
||||
|
||||
reuse->total = 1;
|
||||
if ((head) && !((unsigned long)head & 0x1)) {
|
||||
if (count) {
|
||||
if (head->node_count < MAPLE_ALLOC_SLOTS) {
|
||||
head->slot[head->node_count++] = reuse;
|
||||
head->total++;
|
||||
goto done;
|
||||
}
|
||||
reuse->slot[0] = head;
|
||||
reuse->node_count = 1;
|
||||
reuse->total += head->total;
|
||||
}
|
||||
|
||||
reuse->total = count + 1;
|
||||
mas->alloc = reuse;
|
||||
done:
|
||||
if (requested > 1)
|
||||
|
Loading…
Reference in New Issue
Block a user