Lines Matching refs:xa_offset

129 	unsigned int limit = xas->xa_offset + xas->xa_sibs + 1;  in xas_squash_marks()
136 if (find_next_bit(marks, limit, xas->xa_offset + 1) == limit) in xas_squash_marks()
138 __set_bit(xas->xa_offset, marks); in xas_squash_marks()
139 bitmap_clear(marks, xas->xa_offset + 1, xas->xa_sibs); in xas_squash_marks()
151 xas->xa_offset = get_offset(xas->xa_index, xas->xa_node); in xas_set_offset()
164 xas->xa_offset++; in xas_next_offset()
165 xas_move_index(xas, xas->xa_offset); in xas_next_offset()
217 xas->xa_offset = offset; in xas_descend()
384 node->offset = xas->xa_offset; in xas_alloc()
495 xas->xa_offset = node->offset; in xas_delete_node()
504 parent->slots[xas->xa_offset] = NULL; in xas_delete_node()
664 unsigned int offset = xas->xa_offset; in xas_create()
690 slot = &node->slots[xas->xa_offset]; in xas_create()
713 xas->xa_offset |= sibs; in xas_create_range()
730 xas->xa_offset = node->offset - 1; in xas_create_range()
802 offset = xas->xa_offset; in xas_store()
803 max = xas->xa_offset + xas->xa_sibs; in xas_store()
831 entry = xa_mk_sibling(xas->xa_offset); in xas_store()
864 return node_get_mark(xas->xa_node, xas->xa_offset, mark); in xas_get_mark()
880 unsigned int offset = xas->xa_offset; in xas_set_mark()
909 unsigned int offset = xas->xa_offset; in xas_clear_mark()
1081 marks = node_get_marks(node, xas->xa_offset); in xas_split()
1083 offset = xas->xa_offset + sibs; in xas_split()
1113 } while (offset-- > xas->xa_offset); in xas_split()
1145 unsigned long offset = xas->xa_offset; in xas_pause()
1150 xas->xa_index += (offset - xas->xa_offset) << node->shift; in xas_pause()
1177 if (xas->xa_offset != get_offset(xas->xa_index, xas->xa_node)) in __xas_prev()
1178 xas->xa_offset--; in __xas_prev()
1180 while (xas->xa_offset == 255) { in __xas_prev()
1181 xas->xa_offset = xas->xa_node->offset - 1; in __xas_prev()
1188 entry = xa_entry(xas->xa, xas->xa_node, xas->xa_offset); in __xas_prev()
1216 if (xas->xa_offset != get_offset(xas->xa_index, xas->xa_node)) in __xas_next()
1217 xas->xa_offset++; in __xas_next()
1219 while (xas->xa_offset == XA_CHUNK_SIZE) { in __xas_next()
1220 xas->xa_offset = xas->xa_node->offset + 1; in __xas_next()
1227 entry = xa_entry(xas->xa, xas->xa_node, xas->xa_offset); in __xas_next()
1270 xas->xa_offset != (xas->xa_index & XA_CHUNK_MASK)) { in xas_find()
1271 xas->xa_offset = ((xas->xa_index - 1) & XA_CHUNK_MASK) + 1; in xas_find()
1277 if (unlikely(xas->xa_offset == XA_CHUNK_SIZE)) { in xas_find()
1278 xas->xa_offset = xas->xa_node->offset + 1; in xas_find()
1283 entry = xa_entry(xas->xa, xas->xa_node, xas->xa_offset); in xas_find()
1286 xas->xa_offset = 0; in xas_find()
1349 xas->xa_offset = xas->xa_index >> xas->xa_node->shift; in xas_find_marked()
1353 if (unlikely(xas->xa_offset == XA_CHUNK_SIZE)) { in xas_find_marked()
1354 xas->xa_offset = xas->xa_node->offset + 1; in xas_find_marked()
1363 entry = xa_entry(xas->xa, xas->xa_node, xas->xa_offset); in xas_find_marked()
1365 xas->xa_offset = xa_to_sibling(entry); in xas_find_marked()
1366 xas_move_index(xas, xas->xa_offset); in xas_find_marked()
1371 if (offset > xas->xa_offset) { in xas_find_marked()
1377 xas->xa_offset = offset; in xas_find_marked()
1382 entry = xa_entry(xas->xa, xas->xa_node, xas->xa_offset); in xas_find_marked()
1437 if ((xas->xa_offset & xas->xa_sibs) == xas->xa_sibs) in xas_find_conflict()
1439 } else if (xas->xa_offset == XA_CHUNK_MASK) { in xas_find_conflict()
1440 xas->xa_offset = xas->xa_node->offset; in xas_find_conflict()
1446 curr = xa_entry_locked(xas->xa, xas->xa_node, ++xas->xa_offset); in xas_find_conflict()
1451 xas->xa_offset = 0; in xas_find_conflict()
1457 xas->xa_offset -= xas->xa_sibs; in xas_find_conflict()
1784 unsigned int slot = xas->xa_offset + (1 << order); in xas_get_order()
2076 ((unsigned long)xas->xa_offset << node->shift); in xas_sibling()
2221 .xa_offset = node->offset, in xa_delete_node()