uint64_t                        owner;
        uint64_t                        offset;
        unsigned int                    flags;
-       bool                            has_rmap;
 };
 
 /* For each rmap given, figure out if it doesn't match the key we want. */
        if (rks->owner == rec->rm_owner && rks->offset == rec->rm_offset &&
            ((rks->flags & rec->rm_flags) & XFS_RMAP_KEY_FLAGS) == rks->flags)
                return 0;
-       rks->has_rmap = true;
        return -ECANCELED;
 }
 
        int                             error;
 
        xfs_owner_info_unpack(oinfo, &rks.owner, &rks.offset, &rks.flags);
-       rks.has_rmap = false;
+       *has_rmap = false;
 
        low.rm_startblock = bno;
        memset(&high, 0xFF, sizeof(high));
 
        error = xfs_rmap_query_range(cur, &low, &high,
                        xfs_rmap_has_other_keys_helper, &rks);
-       if (error < 0)
-               return error;
+       if (error == -ECANCELED) {
+               *has_rmap = true;
+               return 0;
+       }
 
-       *has_rmap = rks.has_rmap;
-       return 0;
+       return error;
 }
 
 const struct xfs_owner_info XFS_RMAP_OINFO_SKIP_UPDATE = {