blob: b61676cfdc36ea3ab4b89e2d572aabbd478fd22c [file] [log] [blame]
From: Liam Howlett <liam.howlett@oracle.com>
Subject: maple_tree: fix mas_empty_area_rev() search exhaustion at root node
Date: Tue, 12 Jul 2022 01:50:36 +0000
When the possibilities of finding a gap are exhausted at the root node,
the error code was not returned which results in returning a range that
is currently occupied. Add the necessary check for the error code and
return to the caller.
Link: https://lkml.kernel.org/r/20220712014957.4064879-1-Liam.Howlett@oracle.com
Fixes: d0aac5e48048 (Maple Tree: add new data structure)
Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
Reported-by: Alexander Gordeev <agordeev@linux.ibm.com>
Tested-by: Alexander Gordeev <agordeev@linux.ibm.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
---
lib/maple_tree.c | 3 +++
1 file changed, 3 insertions(+)
--- a/lib/maple_tree.c~maple-tree-add-new-data-structure-fix-5
+++ a/lib/maple_tree.c
@@ -5287,6 +5287,9 @@ int mas_empty_area_rev(struct ma_state *
}
}
+ if (mas_is_err(mas))
+ return xa_err(mas->node);
+
if (unlikely(mas->offset == MAPLE_NODE_SLOTS))
return -EBUSY;
_