/* Keep unconverted code working */
 #define radix_tree_root                xarray
+#define radix_tree_node                xa_node
 
 /*
  * The bottom two bits of the slot determine how the remaining bits in the
 
 /*** radix-tree API starts here ***/
 
-#define RADIX_TREE_MAX_TAGS 3
-
 #define RADIX_TREE_MAP_SHIFT   XA_CHUNK_SHIFT
 #define RADIX_TREE_MAP_SIZE    (1UL << RADIX_TREE_MAP_SHIFT)
 #define RADIX_TREE_MAP_MASK    (RADIX_TREE_MAP_SIZE-1)
 
-#define RADIX_TREE_TAG_LONGS   \
-       ((RADIX_TREE_MAP_SIZE + BITS_PER_LONG - 1) / BITS_PER_LONG)
+#define RADIX_TREE_MAX_TAGS    XA_MAX_MARKS
+#define RADIX_TREE_TAG_LONGS   XA_MARK_LONGS
 
 #define RADIX_TREE_INDEX_BITS  (8 /* CHAR_BIT */ * sizeof(unsigned long))
 #define RADIX_TREE_MAX_PATH (DIV_ROUND_UP(RADIX_TREE_INDEX_BITS, \
                                          RADIX_TREE_MAP_SHIFT))
 
-/*
- * @count is the count of every non-NULL element in the ->slots array
- * whether that is a value entry, a retry entry, a user pointer,
- * a sibling entry or a pointer to the next level of the tree.
- * @exceptional is the count of every element in ->slots which is
- * either a value entry or a sibling of a value entry.
- */
-struct radix_tree_node {
-       unsigned char   shift;          /* Bits remaining in each slot */
-       unsigned char   offset;         /* Slot offset in parent */
-       unsigned char   count;          /* Total entry count */
-       unsigned char   exceptional;    /* Exceptional entry count */
-       struct radix_tree_node *parent;         /* Used when ascending tree */
-       struct radix_tree_root *root;           /* The tree we belong to */
-       union {
-               struct list_head private_list;  /* For tree user */
-               struct rcu_head rcu_head;       /* Used when freeing node */
-       };
-       void __rcu      *slots[RADIX_TREE_MAP_SIZE];
-       unsigned long   tags[RADIX_TREE_MAX_TAGS][RADIX_TREE_TAG_LONGS];
-};
-
 /* The IDR tag is stored in the low bits of xa_flags */
 #define ROOT_IS_IDR    ((__force gfp_t)4)
 /* The top bits of xa_flags are used to store the root tags */
 
 #endif
 #define XA_CHUNK_SIZE          (1UL << XA_CHUNK_SHIFT)
 #define XA_CHUNK_MASK          (XA_CHUNK_SIZE - 1)
+#define XA_MAX_MARKS           3
+#define XA_MARK_LONGS          DIV_ROUND_UP(XA_CHUNK_SIZE, BITS_PER_LONG)
+
+/*
+ * @count is the count of every non-NULL element in the ->slots array
+ * whether that is a value entry, a retry entry, a user pointer,
+ * a sibling entry or a pointer to the next level of the tree.
+ * @nr_values is the count of every element in ->slots which is
+ * either a value entry or a sibling of a value entry.
+ */
+struct xa_node {
+       unsigned char   shift;          /* Bits remaining in each slot */
+       unsigned char   offset;         /* Slot offset in parent */
+       unsigned char   count;          /* Total entry count */
+       unsigned char   nr_values;      /* Value entry count */
+       struct xa_node __rcu *parent;   /* NULL at top of tree */
+       struct xarray   *array;         /* The array we belong to */
+       union {
+               struct list_head private_list;  /* For tree user */
+               struct rcu_head rcu_head;       /* Used when freeing node */
+       };
+       void __rcu      *slots[XA_CHUNK_SIZE];
+       union {
+               unsigned long   tags[XA_MAX_MARKS][XA_MARK_LONGS];
+               unsigned long   marks[XA_MAX_MARKS][XA_MARK_LONGS];
+       };
+};
 
 /* Private */
 static inline bool xa_is_node(const void *entry)
 
 {
        unsigned long i;
 
-       pr_debug("radix node: %p offset %d indices %lu-%lu parent %p tags %lx %lx %lx shift %d count %d exceptional %d\n",
+       pr_debug("radix node: %p offset %d indices %lu-%lu parent %p tags %lx %lx %lx shift %d count %d nr_values %d\n",
                node, node->offset, index, index | node_maxindex(node),
                node->parent,
                node->tags[0][0], node->tags[1][0], node->tags[2][0],
-               node->shift, node->count, node->exceptional);
+               node->shift, node->count, node->nr_values);
 
        for (i = 0; i < RADIX_TREE_MAP_SIZE; i++) {
                unsigned long first = index | (i << node->shift);
 radix_tree_node_alloc(gfp_t gfp_mask, struct radix_tree_node *parent,
                        struct radix_tree_root *root,
                        unsigned int shift, unsigned int offset,
-                       unsigned int count, unsigned int exceptional)
+                       unsigned int count, unsigned int nr_values)
 {
        struct radix_tree_node *ret = NULL;
 
                ret->shift = shift;
                ret->offset = offset;
                ret->count = count;
-               ret->exceptional = exceptional;
+               ret->nr_values = nr_values;
                ret->parent = parent;
-               ret->root = root;
+               ret->array = root;
        }
        return ret;
 }
                if (radix_tree_is_internal_node(entry)) {
                        entry_to_node(entry)->parent = node;
                } else if (xa_is_value(entry)) {
-                       /* Moving an exceptional root->xa_head to a node */
-                       node->exceptional = 1;
+                       /* Moving a value entry root->xa_head to a node */
+                       node->nr_values = 1;
                }
                /*
                 * entry was already in the radix tree, so we do not need
                if (xa_is_node(old))
                        radix_tree_free_nodes(old);
                if (xa_is_value(old))
-                       node->exceptional--;
+                       node->nr_values--;
        }
        if (node) {
                node->count += n;
                if (xa_is_value(item))
-                       node->exceptional += n;
+                       node->nr_values += n;
        }
        return n;
 }
        if (node) {
                node->count++;
                if (xa_is_value(item))
-                       node->exceptional++;
+                       node->nr_values++;
        }
        return 1;
 }
 EXPORT_SYMBOL(radix_tree_lookup);
 
 static inline void replace_sibling_entries(struct radix_tree_node *node,
-                               void __rcu **slot, int count, int exceptional)
+                               void __rcu **slot, int count, int values)
 {
 #ifdef CONFIG_RADIX_TREE_MULTIORDER
        unsigned offset = get_slot_offset(node, slot);
                        node->slots[offset] = NULL;
                        node->count--;
                }
-               node->exceptional += exceptional;
+               node->nr_values += values;
        }
 #endif
 }
 
 static void replace_slot(void __rcu **slot, void *item,
-               struct radix_tree_node *node, int count, int exceptional)
+               struct radix_tree_node *node, int count, int values)
 {
-       if (node && (count || exceptional)) {
+       if (node && (count || values)) {
                node->count += count;
-               node->exceptional += exceptional;
-               replace_sibling_entries(node, slot, count, exceptional);
+               node->nr_values += values;
+               replace_sibling_entries(node, slot, count, values);
        }
 
        rcu_assign_pointer(*slot, item);
                          radix_tree_update_node_t update_node)
 {
        void *old = rcu_dereference_raw(*slot);
-       int exceptional = !!xa_is_value(item) - !!xa_is_value(old);
+       int values = !!xa_is_value(item) - !!xa_is_value(old);
        int count = calculate_count(root, node, slot, item, old);
 
        /*
-        * This function supports replacing exceptional entries and
+        * This function supports replacing value entries and
         * deleting entries, but that needs accounting against the
         * node unless the slot is root->xa_head.
         */
        WARN_ON_ONCE(!node && (slot != (void __rcu **)&root->xa_head) &&
-                       (count || exceptional));
-       replace_slot(slot, item, node, count, exceptional);
+                       (count || values));
+       replace_slot(slot, item, node, count, values);
 
        if (!node)
                return;
  * across slot lookup and replacement.
  *
  * NOTE: This cannot be used to switch between non-entries (empty slots),
- * regular entries, and exceptional entries, as that requires accounting
+ * regular entries, and value entries, as that requires accounting
  * inside the radix tree node. When switching from one type of entry or
  * deleting, use __radix_tree_lookup() and __radix_tree_replace() or
  * radix_tree_iter_replace().
                rcu_assign_pointer(parent->slots[end], RADIX_TREE_RETRY);
        }
        rcu_assign_pointer(parent->slots[offset], RADIX_TREE_RETRY);
-       parent->exceptional -= (end - offset);
+       parent->nr_values -= (end - offset);
 
        if (order == parent->shift)
                return 0;
                                struct radix_tree_node *node, void __rcu **slot)
 {
        void *old = rcu_dereference_raw(*slot);
-       int exceptional = xa_is_value(old) ? -1 : 0;
+       int values = xa_is_value(old) ? -1 : 0;
        unsigned offset = get_slot_offset(node, slot);
        int tag;
 
                for (tag = 0; tag < RADIX_TREE_MAX_TAGS; tag++)
                        node_tag_clear(root, node, tag, offset);
 
-       replace_slot(slot, NULL, node, -1, exceptional);
+       replace_slot(slot, NULL, node, -1, values);
        return node && delete_node(root, node, NULL);
 }
 
 
         * already where they should be. The list_empty() test is safe
         * as node->private_list is protected by the i_pages lock.
         */
-       if (node->count && node->count == node->exceptional) {
+       if (node->count && node->count == node->nr_values) {
                if (list_empty(&node->private_list))
                        list_lru_add(&shadow_nodes, &node->private_list);
        } else {
         * to reclaim, take the node off-LRU, and drop the lru_lock.
         */
 
-       node = container_of(item, struct radix_tree_node, private_list);
-       mapping = container_of(node->root, struct address_space, i_pages);
+       node = container_of(item, struct xa_node, private_list);
+       mapping = container_of(node->array, struct address_space, i_pages);
 
        /* Coming from the list, invert the lock order */
        if (!xa_trylock(&mapping->i_pages)) {
         * no pages, so we expect to be able to remove them all and
         * delete and free the empty node afterwards.
         */
-       if (WARN_ON_ONCE(!node->exceptional))
+       if (WARN_ON_ONCE(!node->nr_values))
                goto out_invalid;
-       if (WARN_ON_ONCE(node->count != node->exceptional))
+       if (WARN_ON_ONCE(node->count != node->nr_values))
                goto out_invalid;
        for (i = 0; i < RADIX_TREE_MAP_SIZE; i++) {
                if (node->slots[i]) {
                        if (WARN_ON_ONCE(!xa_is_value(node->slots[i])))
                                goto out_invalid;
-                       if (WARN_ON_ONCE(!node->exceptional))
+                       if (WARN_ON_ONCE(!node->nr_values))
                                goto out_invalid;
                        if (WARN_ON_ONCE(!mapping->nrexceptional))
                                goto out_invalid;
                        node->slots[i] = NULL;
-                       node->exceptional--;
+                       node->nr_values--;
                        node->count--;
                        mapping->nrexceptional--;
                }
        }
-       if (WARN_ON_ONCE(node->exceptional))
+       if (WARN_ON_ONCE(node->nr_values))
                goto out_invalid;
        inc_lruvec_page_state(virt_to_page(node), WORKINGSET_NODERECLAIM);
        __radix_tree_delete_node(&mapping->i_pages, node,
 
        radix_tree_insert(&tree, 1 << order2, xa_mk_value(5));
        item2 = __radix_tree_lookup(&tree, 1 << order2, &node, NULL);
        assert(item2 == xa_mk_value(5));
-       assert(node->exceptional == 1);
+       assert(node->nr_values == 1);
 
        item2 = radix_tree_lookup(&tree, 0);
        free(item2);
        radix_tree_join(&tree, 0, order1, item1);
        item2 = __radix_tree_lookup(&tree, 1 << order2, &node, NULL);
        assert(item2 == item1);
-       assert(node->exceptional == 0);
+       assert(node->nr_values == 0);
        item_kill_tree(&tree);
 }
 
  * This test revealed an accounting bug for value entries at one point.
  * Nodes were being freed back into the pool with an elevated exception count
  * by radix_tree_join() and then radix_tree_split() was failing to zero the
- * count of exceptional entries.
+ * count of value entries.
  */
 static void multiorder_join3(unsigned int order)
 {
        }
 
        __radix_tree_lookup(&tree, 0, &node, NULL);
-       assert(node->exceptional == node->count);
+       assert(node->nr_values == node->count);
 
        item_kill_tree(&tree);
 }
 
        item = __radix_tree_lookup(&tree, 0, &node, NULL);
        assert(item == xa_mk_value(5));
-       assert(node->exceptional > 0);
+       assert(node->nr_values > 0);
 
        radix_tree_split(&tree, 0, new_order);
        radix_tree_for_each_slot(slot, &tree, &iter, 0) {
 
        item = __radix_tree_lookup(&tree, 0, &node, NULL);
        assert(item != xa_mk_value(5));
-       assert(node->exceptional == 0);
+       assert(node->nr_values == 0);
 
        item_kill_tree(&tree);
 }
 
        item = __radix_tree_lookup(&tree, 0, &node, NULL);
        assert(item == xa_mk_value(5));
-       assert(node->exceptional > 0);
+       assert(node->nr_values > 0);
 
        radix_tree_split(&tree, 0, new_order);
        radix_tree_for_each_slot(slot, &tree, &iter, 0) {
 
        item = __radix_tree_lookup(&tree, 0, &node, NULL);
        assert(item == xa_mk_value(7));
-       assert(node->exceptional > 0);
+       assert(node->nr_values > 0);
 
        item_kill_tree(&tree);
 
 
        item = __radix_tree_lookup(&tree, 0, &node, NULL);
        assert(item == xa_mk_value(5));
-       assert(node->exceptional > 0);
+       assert(node->nr_values > 0);
 
        radix_tree_split(&tree, 0, new_order);
        radix_tree_for_each_slot(slot, &tree, &iter, 0) {
 
        item = __radix_tree_lookup(&tree, 1 << new_order, &node, NULL);
        assert(item == xa_mk_value(7));
-       assert(node->count == node->exceptional);
+       assert(node->count == node->nr_values);
        do {
                node = node->parent;
                if (!node)
                        break;
                assert(node->count == 1);
-               assert(node->exceptional == 0);
+               assert(node->nr_values == 0);
        } while (1);
 
        item_kill_tree(&tree);
 
        __radix_tree_insert(&tree, 1 << 5, 5, xa_mk_value(5));
        __radix_tree_lookup(&tree, 0, &node, NULL);
-       assert(node->count == node->exceptional * 2);
+       assert(node->count == node->nr_values * 2);
        radix_tree_delete(&tree, 1 << 5);
-       assert(node->exceptional == 0);
+       assert(node->nr_values == 0);
 
        __radix_tree_insert(&tree, 1 << 5, 5, xa_mk_value(5));
        __radix_tree_lookup(&tree, 1 << 5, &node, &slot);
-       assert(node->count == node->exceptional * 2);
+       assert(node->count == node->nr_values * 2);
        __radix_tree_replace(&tree, node, slot, NULL, NULL);
-       assert(node->exceptional == 0);
+       assert(node->nr_values == 0);
 
        item_kill_tree(&tree);
 }