*/
 STATIC int xfs_attr_node_get(xfs_da_args_t *args);
 STATIC void xfs_attr_restore_rmt_blk(struct xfs_da_args *args);
-STATIC int xfs_attr_node_addname(struct xfs_delattr_context *dac);
-STATIC int xfs_attr_node_addname_find_attr(struct xfs_delattr_context *dac);
-STATIC int xfs_attr_node_addname_clear_incomplete(
-                               struct xfs_delattr_context *dac);
+STATIC int xfs_attr_node_addname(struct xfs_attr_item *attr);
+STATIC int xfs_attr_node_addname_find_attr(struct xfs_attr_item *attr);
+STATIC int xfs_attr_node_addname_clear_incomplete(struct xfs_attr_item *attr);
 STATIC int xfs_attr_node_hasname(xfs_da_args_t *args,
                                 struct xfs_da_state **state);
 STATIC int xfs_attr_fillstate(xfs_da_state_t *state);
 
 STATIC int
 xfs_attr_sf_addname(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
+       struct xfs_da_args              *args = attr->xattri_da_args;
        struct xfs_inode                *dp = args->dp;
        int                             error = 0;
 
         * It won't fit in the shortform, transform to a leaf block.  GROT:
         * another possible req'mt for a double-split btree op.
         */
-       error = xfs_attr_shortform_to_leaf(args, &dac->leaf_bp);
+       error = xfs_attr_shortform_to_leaf(args, &attr->xattri_leaf_bp);
        if (error)
                return error;
 
         * push cannot grab the half-baked leaf buffer and run into problems
         * with the write verifier.
         */
-       xfs_trans_bhold(args->trans, dac->leaf_bp);
+       xfs_trans_bhold(args->trans, attr->xattri_leaf_bp);
 
        /*
         * We're still in XFS_DAS_UNINIT state here.  We've converted
  */
 int
 xfs_attr_set_iter(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
+       struct xfs_da_args              *args = attr->xattri_da_args;
        struct xfs_inode                *dp = args->dp;
        struct xfs_buf                  *bp = NULL;
        int                             forkoff, error = 0;
        struct xfs_mount                *mp = args->dp->i_mount;
 
        /* State machine switch */
-       switch (dac->dela_state) {
+       switch (attr->xattri_dela_state) {
        case XFS_DAS_UNINIT:
                /*
                 * If the fork is shortform, attempt to add the attr. If there
                 * release the hold once we return with a clean transaction.
                 */
                if (xfs_attr_is_shortform(dp))
-                       return xfs_attr_sf_addname(dac);
-               if (dac->leaf_bp != NULL) {
-                       xfs_trans_bhold_release(args->trans, dac->leaf_bp);
-                       dac->leaf_bp = NULL;
+                       return xfs_attr_sf_addname(attr);
+               if (attr->xattri_leaf_bp != NULL) {
+                       xfs_trans_bhold_release(args->trans,
+                                               attr->xattri_leaf_bp);
+                       attr->xattri_leaf_bp = NULL;
                }
 
                if (xfs_attr_is_leaf(dp)) {
-                       error = xfs_attr_leaf_try_add(args, dac->leaf_bp);
+                       error = xfs_attr_leaf_try_add(args,
+                                                     attr->xattri_leaf_bp);
                        if (error == -ENOSPC) {
                                error = xfs_attr3_leaf_to_node(args);
                                if (error)
                                 * handling code below
                                 */
                                trace_xfs_attr_set_iter_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                                return -EAGAIN;
                        } else if (error) {
                                return error;
                        }
 
-                       dac->dela_state = XFS_DAS_FOUND_LBLK;
+                       attr->xattri_dela_state = XFS_DAS_FOUND_LBLK;
                } else {
-                       error = xfs_attr_node_addname_find_attr(dac);
+                       error = xfs_attr_node_addname_find_attr(attr);
                        if (error)
                                return error;
 
-                       error = xfs_attr_node_addname(dac);
+                       error = xfs_attr_node_addname(attr);
                        if (error)
                                return error;
 
                            !(args->op_flags & XFS_DA_OP_RENAME))
                                return 0;
 
-                       dac->dela_state = XFS_DAS_FOUND_NBLK;
+                       attr->xattri_dela_state = XFS_DAS_FOUND_NBLK;
                }
-               trace_xfs_attr_set_iter_return(dac->dela_state, args->dp);
+               trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
+                                              args->dp);
                return -EAGAIN;
        case XFS_DAS_FOUND_LBLK:
                /*
                 */
 
                /* Open coded xfs_attr_rmtval_set without trans handling */
-               if ((dac->flags & XFS_DAC_LEAF_ADDNAME_INIT) == 0) {
-                       dac->flags |= XFS_DAC_LEAF_ADDNAME_INIT;
+               if ((attr->xattri_flags & XFS_DAC_LEAF_ADDNAME_INIT) == 0) {
+                       attr->xattri_flags |= XFS_DAC_LEAF_ADDNAME_INIT;
                        if (args->rmtblkno > 0) {
-                               error = xfs_attr_rmtval_find_space(dac);
+                               error = xfs_attr_rmtval_find_space(attr);
                                if (error)
                                        return error;
                        }
                 * Repeat allocating remote blocks for the attr value until
                 * blkcnt drops to zero.
                 */
-               if (dac->blkcnt > 0) {
-                       error = xfs_attr_rmtval_set_blk(dac);
+               if (attr->xattri_blkcnt > 0) {
+                       error = xfs_attr_rmtval_set_blk(attr);
                        if (error)
                                return error;
-                       trace_xfs_attr_set_iter_return(dac->dela_state,
+                       trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
                                                       args->dp);
                        return -EAGAIN;
                }
                         * Commit the flag value change and start the next trans
                         * in series.
                         */
-                       dac->dela_state = XFS_DAS_FLIP_LFLAG;
-                       trace_xfs_attr_set_iter_return(dac->dela_state,
+                       attr->xattri_dela_state = XFS_DAS_FLIP_LFLAG;
+                       trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
                                                       args->dp);
                        return -EAGAIN;
                }
                fallthrough;
        case XFS_DAS_RM_LBLK:
                /* Set state in case xfs_attr_rmtval_remove returns -EAGAIN */
-               dac->dela_state = XFS_DAS_RM_LBLK;
+               attr->xattri_dela_state = XFS_DAS_RM_LBLK;
                if (args->rmtblkno) {
-                       error = xfs_attr_rmtval_remove(dac);
+                       error = xfs_attr_rmtval_remove(attr);
                        if (error == -EAGAIN)
                                trace_xfs_attr_set_iter_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                        if (error)
                                return error;
 
-                       dac->dela_state = XFS_DAS_RD_LEAF;
-                       trace_xfs_attr_set_iter_return(dac->dela_state, args->dp);
+                       attr->xattri_dela_state = XFS_DAS_RD_LEAF;
+                       trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
+                                                      args->dp);
                        return -EAGAIN;
                }
 
                 * state.
                 */
                if (args->rmtblkno > 0) {
-                       error = xfs_attr_rmtval_find_space(dac);
+                       error = xfs_attr_rmtval_find_space(attr);
                        if (error)
                                return error;
                }
                 * after we create the attribute so that we don't overflow the
                 * maximum size of a transaction and/or hit a deadlock.
                 */
-               dac->dela_state = XFS_DAS_ALLOC_NODE;
+               attr->xattri_dela_state = XFS_DAS_ALLOC_NODE;
                if (args->rmtblkno > 0) {
-                       if (dac->blkcnt > 0) {
-                               error = xfs_attr_rmtval_set_blk(dac);
+                       if (attr->xattri_blkcnt > 0) {
+                               error = xfs_attr_rmtval_set_blk(attr);
                                if (error)
                                        return error;
                                trace_xfs_attr_set_iter_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                                return -EAGAIN;
                        }
 
                         * Commit the flag value change and start the next trans
                         * in series
                         */
-                       dac->dela_state = XFS_DAS_FLIP_NFLAG;
-                       trace_xfs_attr_set_iter_return(dac->dela_state,
+                       attr->xattri_dela_state = XFS_DAS_FLIP_NFLAG;
+                       trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
                                                       args->dp);
                        return -EAGAIN;
                }
                fallthrough;
        case XFS_DAS_RM_NBLK:
                /* Set state in case xfs_attr_rmtval_remove returns -EAGAIN */
-               dac->dela_state = XFS_DAS_RM_NBLK;
+               attr->xattri_dela_state = XFS_DAS_RM_NBLK;
                if (args->rmtblkno) {
-                       error = xfs_attr_rmtval_remove(dac);
+                       error = xfs_attr_rmtval_remove(attr);
                        if (error == -EAGAIN)
                                trace_xfs_attr_set_iter_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
 
                        if (error)
                                return error;
 
-                       dac->dela_state = XFS_DAS_CLR_FLAG;
-                       trace_xfs_attr_set_iter_return(dac->dela_state, args->dp);
+                       attr->xattri_dela_state = XFS_DAS_CLR_FLAG;
+                       trace_xfs_attr_set_iter_return(attr->xattri_dela_state,
+                                                      args->dp);
                        return -EAGAIN;
                }
 
                 * The last state for node format. Look up the old attr and
                 * remove it.
                 */
-               error = xfs_attr_node_addname_clear_incomplete(dac);
+               error = xfs_attr_node_addname_clear_incomplete(attr);
                break;
        default:
                ASSERT(0);
 
        new = kmem_zalloc(sizeof(struct xfs_attr_item), KM_NOFS);
        new->xattri_op_flags = op_flags;
-       new->xattri_dac.da_args = args;
+       new->xattri_da_args = args;
 
        *attr = new;
        return 0;
 
 STATIC int
 xfs_attr_node_addname_find_attr(
-       struct xfs_delattr_context      *dac)
+        struct xfs_attr_item           *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
+       struct xfs_da_args              *args = attr->xattri_da_args;
        int                             retval;
 
        /*
         * Search to see if name already exists, and get back a pointer
         * to where it should go.
         */
-       retval = xfs_attr_node_hasname(args, &dac->da_state);
+       retval = xfs_attr_node_hasname(args, &attr->xattri_da_state);
        if (retval != -ENOATTR && retval != -EEXIST)
                goto error;
 
 
        return 0;
 error:
-       if (dac->da_state)
-               xfs_da_state_free(dac->da_state);
+       if (attr->xattri_da_state)
+               xfs_da_state_free(attr->xattri_da_state);
        return retval;
 }
 
  */
 STATIC int
 xfs_attr_node_addname(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
-       struct xfs_da_state             *state = dac->da_state;
+       struct xfs_da_args              *args = attr->xattri_da_args;
+       struct xfs_da_state             *state = attr->xattri_da_state;
        struct xfs_da_state_blk         *blk;
        int                             error;
 
                         * this point.
                         */
                        trace_xfs_attr_node_addname_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                        return -EAGAIN;
                }
 
 
 STATIC int
 xfs_attr_node_addname_clear_incomplete(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
+       struct xfs_da_args              *args = attr->xattri_da_args;
        struct xfs_da_state             *state = NULL;
        struct xfs_mount                *mp = args->dp->i_mount;
        int                             retval = 0;
  */
 STATIC
 int xfs_attr_node_removename_setup(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
-       struct xfs_da_state             **state = &dac->da_state;
+       struct xfs_da_args              *args = attr->xattri_da_args;
+       struct xfs_da_state             **state = &attr->xattri_da_state;
        int                             error;
 
        error = xfs_attr_node_hasname(args, state);
  */
 int
 xfs_attr_remove_iter(
-       struct xfs_delattr_context      *dac)
+       struct xfs_attr_item            *attr)
 {
-       struct xfs_da_args              *args = dac->da_args;
-       struct xfs_da_state             *state = dac->da_state;
+       struct xfs_da_args              *args = attr->xattri_da_args;
+       struct xfs_da_state             *state = attr->xattri_da_state;
        int                             retval, error = 0;
        struct xfs_inode                *dp = args->dp;
 
        trace_xfs_attr_node_removename(args);
 
-       switch (dac->dela_state) {
+       switch (attr->xattri_dela_state) {
        case XFS_DAS_UNINIT:
                if (!xfs_inode_hasattr(dp))
                        return -ENOATTR;
                 * Node format may require transaction rolls. Set up the
                 * state context and fall into the state machine.
                 */
-               if (!dac->da_state) {
-                       error = xfs_attr_node_removename_setup(dac);
+               if (!attr->xattri_da_state) {
+                       error = xfs_attr_node_removename_setup(attr);
                        if (error)
                                return error;
-                       state = dac->da_state;
+                       state = attr->xattri_da_state;
                }
 
                fallthrough;
        case XFS_DAS_RMTBLK:
-               dac->dela_state = XFS_DAS_RMTBLK;
+               attr->xattri_dela_state = XFS_DAS_RMTBLK;
 
                /*
                 * If there is an out-of-line value, de-allocate the blocks.
                         * May return -EAGAIN. Roll and repeat until all remote
                         * blocks are removed.
                         */
-                       error = xfs_attr_rmtval_remove(dac);
+                       error = xfs_attr_rmtval_remove(attr);
                        if (error == -EAGAIN) {
                                trace_xfs_attr_remove_iter_return(
-                                               dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                                return error;
                        } else if (error) {
                                goto out;
                        error = xfs_attr_refillstate(state);
                        if (error)
                                goto out;
-                       dac->dela_state = XFS_DAS_RM_NAME;
-                       trace_xfs_attr_remove_iter_return(dac->dela_state, args->dp);
+
+                       attr->xattri_dela_state = XFS_DAS_RM_NAME;
+                       trace_xfs_attr_remove_iter_return(
+                                       attr->xattri_dela_state, args->dp);
                        return -EAGAIN;
                }
 
                 * If we came here fresh from a transaction roll, reattach all
                 * the buffers to the current transaction.
                 */
-               if (dac->dela_state == XFS_DAS_RM_NAME) {
+               if (attr->xattri_dela_state == XFS_DAS_RM_NAME) {
                        error = xfs_attr_refillstate(state);
                        if (error)
                                goto out;
                        if (error)
                                goto out;
 
-                       dac->dela_state = XFS_DAS_RM_SHRINK;
+                       attr->xattri_dela_state = XFS_DAS_RM_SHRINK;
                        trace_xfs_attr_remove_iter_return(
-                                       dac->dela_state, args->dp);
+                                       attr->xattri_dela_state, args->dp);
                        return -EAGAIN;
                }
 
 
  */
 
 /*
- * Enum values for xfs_delattr_context.da_state
+ * Enum values for xfs_attr_item.xattri_da_state
  *
  * These values are used by delayed attribute operations to keep track  of where
  * they were before they returned -EAGAIN.  A return code of -EAGAIN signals the
 };
 
 /*
- * Defines for xfs_delattr_context.flags
+ * Defines for xfs_attr_item.xattri_flags
  */
 #define XFS_DAC_LEAF_ADDNAME_INIT      0x01 /* xfs_attr_leaf_addname init*/
 
 /*
  * Context used for keeping track of delayed attribute operations
  */
-struct xfs_delattr_context {
-       struct xfs_da_args      *da_args;
+struct xfs_attr_item {
+       struct xfs_da_args              *xattri_da_args;
 
        /*
         * Used by xfs_attr_set to hold a leaf buffer across a transaction roll
         */
-       struct xfs_buf          *leaf_bp;
+       struct xfs_buf                  *xattri_leaf_bp;
 
        /* Used in xfs_attr_rmtval_set_blk to roll through allocating blocks */
-       struct xfs_bmbt_irec    map;
-       xfs_dablk_t             lblkno;
-       int                     blkcnt;
+       struct xfs_bmbt_irec            xattri_map;
+       xfs_dablk_t                     xattri_lblkno;
+       int                             xattri_blkcnt;
 
        /* Used in xfs_attr_node_removename to roll through removing blocks */
-       struct xfs_da_state     *da_state;
+       struct xfs_da_state             *xattri_da_state;
 
        /* Used to keep track of current state of delayed operation */
-       unsigned int            flags;
-       enum xfs_delattr_state  dela_state;
-};
-
-/*
- * List of attrs to commit later.
- */
-struct xfs_attr_item {
-       struct xfs_delattr_context      xattri_dac;
+       unsigned int                    xattri_flags;
+       enum xfs_delattr_state          xattri_dela_state;
 
        /*
         * Indicates if the attr operation is a set or a remove
         */
        unsigned int                    xattri_op_flags;
 
-       /* used to log this item to an intent */
+       /*
+        * used to log this item to an intent containing a list of attrs to
+        * commit later
+        */
        struct list_head                xattri_list;
 };
 
 int xfs_attr_get_ilocked(struct xfs_da_args *args);
 int xfs_attr_get(struct xfs_da_args *args);
 int xfs_attr_set(struct xfs_da_args *args);
-int xfs_attr_set_iter(struct xfs_delattr_context *dac);
-int xfs_attr_remove_iter(struct xfs_delattr_context *dac);
+int xfs_attr_set_iter(struct xfs_attr_item *attr);
+int xfs_attr_remove_iter(struct xfs_attr_item *attr);
 bool xfs_attr_namecheck(const void *name, size_t length);
-void xfs_delattr_context_init(struct xfs_delattr_context *dac,
-                             struct xfs_da_args *args);
 int xfs_attr_calc_size(struct xfs_da_args *args, int *local);
 int xfs_attr_set_deferred(struct xfs_da_args *args);
 int xfs_attr_remove_deferred(struct xfs_da_args *args);
 
  */
 STATIC int
 xfs_xattri_finish_update(
-       struct xfs_delattr_context      *dac,
+       struct xfs_attr_item            *attr,
        struct xfs_attrd_log_item       *attrdp,
        uint32_t                        op_flags)
 {
-       struct xfs_da_args              *args = dac->da_args;
+       struct xfs_da_args              *args = attr->xattri_da_args;
        unsigned int                    op = op_flags &
                                             XFS_ATTR_OP_FLAGS_TYPE_MASK;
        int                             error;
 
        switch (op) {
        case XFS_ATTR_OP_FLAGS_SET:
-               error = xfs_attr_set_iter(dac);
+               error = xfs_attr_set_iter(attr);
                break;
        case XFS_ATTR_OP_FLAGS_REMOVE:
                ASSERT(XFS_IFORK_Q(args->dp));
-               error = xfs_attr_remove_iter(dac);
+               error = xfs_attr_remove_iter(attr);
                break;
        default:
                error = -EFSCORRUPTED;
         * structure with fields from this xfs_attr_item
         */
        attrp = &attrip->attri_format;
-       attrp->alfi_ino = attr->xattri_dac.da_args->dp->i_ino;
+       attrp->alfi_ino = attr->xattri_da_args->dp->i_ino;
        attrp->alfi_op_flags = attr->xattri_op_flags;
-       attrp->alfi_value_len = attr->xattri_dac.da_args->valuelen;
-       attrp->alfi_name_len = attr->xattri_dac.da_args->namelen;
-       attrp->alfi_attr_flags = attr->xattri_dac.da_args->attr_filter;
-
-       memcpy(attrip->attri_name, attr->xattri_dac.da_args->name,
-              attr->xattri_dac.da_args->namelen);
-       memcpy(attrip->attri_value, attr->xattri_dac.da_args->value,
-              attr->xattri_dac.da_args->valuelen);
-       attrip->attri_name_len = attr->xattri_dac.da_args->namelen;
-       attrip->attri_value_len = attr->xattri_dac.da_args->valuelen;
+       attrp->alfi_value_len = attr->xattri_da_args->valuelen;
+       attrp->alfi_name_len = attr->xattri_da_args->namelen;
+       attrp->alfi_attr_flags = attr->xattri_da_args->attr_filter;
+
+       memcpy(attrip->attri_name, attr->xattri_da_args->name,
+              attr->xattri_da_args->namelen);
+       memcpy(attrip->attri_value, attr->xattri_da_args->value,
+              attr->xattri_da_args->valuelen);
+       attrip->attri_name_len = attr->xattri_da_args->namelen;
+       attrip->attri_value_len = attr->xattri_da_args->valuelen;
 }
 
 /* Get an ATTRI. */
         * this is a list of one
         */
        list_for_each_entry(attr, items, xattri_list) {
-               attrip = xfs_attri_init(mp, attr->xattri_dac.da_args->namelen,
-                                       attr->xattri_dac.da_args->valuelen);
+               attrip = xfs_attri_init(mp, attr->xattri_da_args->namelen,
+                                       attr->xattri_da_args->valuelen);
                if (attrip == NULL)
                        return NULL;
 
        struct xfs_attr_item            *attr;
        struct xfs_attrd_log_item       *done_item = NULL;
        int                             error;
-       struct xfs_delattr_context      *dac;
 
        attr = container_of(item, struct xfs_attr_item, xattri_list);
-       dac = &attr->xattri_dac;
        if (done)
                done_item = ATTRD_ITEM(done);
 
         * Always reset trans after EAGAIN cycle
         * since the transaction is new
         */
-       dac->da_args->trans = tp;
+       attr->xattri_da_args->trans = tp;
 
-       error = xfs_xattri_finish_update(dac, done_item, attr->xattri_op_flags);
+       error = xfs_xattri_finish_update(attr, done_item,
+                                        attr->xattri_op_flags);
        if (error != -EAGAIN)
                kmem_free(attr);
 
                           sizeof(struct xfs_da_args), KM_NOFS);
        args = (struct xfs_da_args *)(attr + 1);
 
-       attr->xattri_dac.da_args = args;
+       attr->xattri_da_args = args;
        attr->xattri_op_flags = attrp->alfi_op_flags;
 
        args->dp = ip;
        xfs_ilock(ip, XFS_ILOCK_EXCL);
        xfs_trans_ijoin(tp, ip, 0);
 
-       ret = xfs_xattri_finish_update(&attr->xattri_dac, done_item,
-                                      attrp->alfi_op_flags);
+       ret = xfs_xattri_finish_update(attr, done_item, attrp->alfi_op_flags);
        if (ret == -EAGAIN) {
                /* There's more work to do, so add it to this transaction */
                xfs_defer_add(tp, XFS_DEFER_OPS_TYPE_ATTR, &attr->xattri_list);
        error = xfs_defer_ops_capture_and_commit(tp, capture_list);
 
 out_unlock:
-       if (attr->xattri_dac.leaf_bp)
-               xfs_buf_relse(attr->xattri_dac.leaf_bp);
+       if (attr->xattri_leaf_bp)
+               xfs_buf_relse(attr->xattri_leaf_bp);
 
        xfs_iunlock(ip, XFS_ILOCK_EXCL);
        xfs_irele(ip);