Xarray: use xa_mark_t in xas_squash_marks() to keep code consistent

Besides xas_squash_marks(), all functions use xa_mark_t type to iterate
all possible marks.  Use xa_mark_t in xas_squash_marks() to keep code
consistent.

Link: https://lkml.kernel.org/r/20241213122523.12764-6-shikemeng@huaweicloud.com
Signed-off-by: Kemeng Shi <shikemeng@huaweicloud.com>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Baolin Wang <baolin.wang@linux.alibaba.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
Kemeng Shi 2024-12-13 20:25:23 +08:00 committed by Andrew Morton
parent 1c9a909431
commit 5cee753945

View File

@ -125,16 +125,20 @@ static inline void node_mark_all(struct xa_node *node, xa_mark_t mark)
*/ */
static void xas_squash_marks(const struct xa_state *xas) static void xas_squash_marks(const struct xa_state *xas)
{ {
unsigned int mark = 0; xa_mark_t mark = 0;
unsigned int limit = xas->xa_offset + xas->xa_sibs + 1; unsigned int limit = xas->xa_offset + xas->xa_sibs + 1;
do { for (;;) {
unsigned long *marks = xas->xa_node->marks[mark]; unsigned long *marks = node_marks(xas->xa_node, mark);
if (find_next_bit(marks, limit, xas->xa_offset + 1) == limit)
continue; if (find_next_bit(marks, limit, xas->xa_offset + 1) != limit) {
__set_bit(xas->xa_offset, marks); __set_bit(xas->xa_offset, marks);
bitmap_clear(marks, xas->xa_offset + 1, xas->xa_sibs); bitmap_clear(marks, xas->xa_offset + 1, xas->xa_sibs);
} while (mark++ != (__force unsigned)XA_MARK_MAX); }
if (mark == XA_MARK_MAX)
break;
mark_inc(mark);
}
} }
/* extracts the offset within this node from the index */ /* extracts the offset within this node from the index */