call_rcu(&devlink->rcu, __devlink_put_rcu);
 }
 
-struct devlink *
-devlinks_xa_find_get(struct net *net, unsigned long *indexp,
-                    void * (*xa_find_fn)(struct xarray *, unsigned long *,
-                                         unsigned long, xa_mark_t))
+struct devlink *devlinks_xa_find_get(struct net *net, unsigned long *indexp)
 {
-       struct devlink *devlink;
+       struct devlink *devlink = NULL;
 
        rcu_read_lock();
 retry:
-       devlink = xa_find_fn(&devlinks, indexp, ULONG_MAX, DEVLINK_REGISTERED);
+       devlink = xa_find(&devlinks, indexp, ULONG_MAX, DEVLINK_REGISTERED);
        if (!devlink)
                goto unlock;
 
         * This prevents live-lock of devlink_unregister() wait for completion.
         */
        if (xa_get_mark(&devlinks, *indexp, DEVLINK_UNREGISTERING))
-               goto retry;
+               goto next;
 
-       /* For a possible retry, the xa_find_after() should be always used */
-       xa_find_fn = xa_find_after;
        if (!devlink_try_get(devlink))
-               goto retry;
+               goto next;
        if (!net_eq(devlink_net(devlink), net)) {
                devlink_put(devlink);
-               goto retry;
+               goto next;
        }
 unlock:
        rcu_read_unlock();
        return devlink;
-}
-
-struct devlink *
-devlinks_xa_find_get_first(struct net *net, unsigned long *indexp)
-{
-       return devlinks_xa_find_get(net, indexp, xa_find);
-}
 
-struct devlink *
-devlinks_xa_find_get_next(struct net *net, unsigned long *indexp)
-{
-       return devlinks_xa_find_get(net, indexp, xa_find_after);
+next:
+       (*indexp)++;
+       goto retry;
 }
 
 /**
 
  * in loop body in order to release the reference.
  */
 #define devlinks_xa_for_each_registered_get(net, index, devlink)       \
-       for (index = 0,                                                 \
-            devlink = devlinks_xa_find_get_first(net, &index); \
-            devlink; devlink = devlinks_xa_find_get_next(net, &index))
-
-struct devlink *
-devlinks_xa_find_get(struct net *net, unsigned long *indexp,
-                    void * (*xa_find_fn)(struct xarray *, unsigned long *,
-                                         unsigned long, xa_mark_t));
-struct devlink *
-devlinks_xa_find_get_first(struct net *net, unsigned long *indexp);
-struct devlink *
-devlinks_xa_find_get_next(struct net *net, unsigned long *indexp);
+       for (index = 0; (devlink = devlinks_xa_find_get(net, &index)); index++)
+
+struct devlink *devlinks_xa_find_get(struct net *net, unsigned long *indexp);
 
 /* Netlink */
 #define DEVLINK_NL_FLAG_NEED_PORT              BIT(0)
  */
 #define devlink_dump_for_each_instance_get(msg, state, devlink)                \
        for (; (devlink = devlinks_xa_find_get(sock_net(msg->sk),       \
-                                              &state->instance, xa_find)); \
+                                              &state->instance));      \
             state->instance++, state->idx = 0)
 
 extern const struct genl_small_ops devlink_nl_ops[56];