[PATCH 24/49] xfs: kill xfs_vnodeops.[ch]
Mark Tinguely
tinguely at sgi.com
Fri Jul 26 14:18:41 CDT 2013
On 07/19/13 01:24, Dave Chinner wrote:
> From: Dave Chinner<dchinner at redhat.com>
>
> Now we have xfs_inode.c for holding kernel-only XFS inode
> operations, move all the inode operations from xfs_vnodeops.c to
> this new file as it holds another set of kernel-only inode
> operations. The name of this file traces back to the days of Irix
> and it's vnodes which we don't have anymore.
>
> Essentially this move consolidates the inode locking functions
> and a bunch of XFS inode operations into the one file. Eventually
> the high level functions will be merged into the VFS interface
> functions in xfs_iops.c.
>
> This leaves only internal preallocation, EOF block manipulation and
> hole punching functions in vnodeops.c. Move these to xfs_bmap_util.c
> where we are already consolidating various in-kernel physical extent
> manipulation and querying functions.
>
> Signed-off-by: Dave Chinner<dchinner at redhat.com>
> ---
As already mentioned, xfs_inode_fork.c still has a unwanted include of
now removed xfs_vnodeops.h.
A xfs_qm_dqrele(pdqp) does not exist in the copied code:
> +int
> +xfs_create(
> + xfs_inode_t *dp,
> + struct xfs_name *name,
> + umode_t mode,
> + xfs_dev_t rdev,
> + xfs_inode_t **ipp)
> +{
...
> + /*
> + * Attach the dquot(s) to the inodes and modify them incore.
> + * These ids of the inode couldn't have changed since the new
> + * inode has been locked ever since it was created.
> + */
> + xfs_qm_vop_create_dqattach(tp, ip, udqp, gdqp, pdqp);
> +
> + error = xfs_bmap_finish(&tp,&free_list,&committed);
> + if (error)
> + goto out_bmap_cancel;
> +
> + error = xfs_trans_commit(tp, XFS_TRANS_RELEASE_LOG_RES);
> + if (error)
> + goto out_release_inode;
> +
> + xfs_qm_dqrele(udqp);
> + xfs_qm_dqrele(gdqp);
^^^ does not exist here,
> +
> + *ipp = ip;
> + return 0;
> +
> + out_bmap_cancel:
> + xfs_bmap_cancel(&free_list);
> + out_trans_abort:
> + cancel_flags |= XFS_TRANS_ABORT;
> + out_trans_cancel:
> + xfs_trans_cancel(tp, cancel_flags);
> + out_release_inode:
> + /*
> + * Wait until after the current transaction is aborted to
> + * release the inode. This prevents recursive transactions
> + * and deadlocks from xfs_inactive.
> + */
> + if (ip)
> + IRELE(ip);
> +
> + xfs_qm_dqrele(udqp);
> + xfs_qm_dqrele(gdqp);
> + xfs_qm_dqrele(pdqp);
> +
> + if (unlock_dp_on_error)
> + xfs_iunlock(dp, XFS_ILOCK_EXCL);
> + return error;
> +}
> +
>
> -
> -int
> -xfs_create(
> - xfs_inode_t *dp,
> - struct xfs_name *name,
> - umode_t mode,
> - xfs_dev_t rdev,
> - xfs_inode_t **ipp)
> -{
...
> -
> - /*
> - * Attach the dquot(s) to the inodes and modify them incore.
> - * These ids of the inode couldn't have changed since the new
> - * inode has been locked ever since it was created.
> - */
> - xfs_qm_vop_create_dqattach(tp, ip, udqp, gdqp, pdqp);
> -
> - error = xfs_bmap_finish(&tp,&free_list,&committed);
> - if (error)
> - goto out_bmap_cancel;
> -
> - error = xfs_trans_commit(tp, XFS_TRANS_RELEASE_LOG_RES);
> - if (error)
> - goto out_release_inode;
> -
> - xfs_qm_dqrele(udqp);
> - xfs_qm_dqrele(gdqp);
> - xfs_qm_dqrele(pdqp);
exists here
> -
> - *ipp = ip;
> - return 0;
> -
> - out_bmap_cancel:
> - xfs_bmap_cancel(&free_list);
> - out_trans_abort:
> - cancel_flags |= XFS_TRANS_ABORT;
> - out_trans_cancel:
> - xfs_trans_cancel(tp, cancel_flags);
> - out_release_inode:
> - /*
> - * Wait until after the current transaction is aborted to
> - * release the inode. This prevents recursive transactions
> - * and deadlocks from xfs_inactive.
> - */
> - if (ip)
> - IRELE(ip);
> -
> - xfs_qm_dqrele(udqp);
> - xfs_qm_dqrele(gdqp);
> - xfs_qm_dqrele(pdqp);
> -
> - if (unlock_dp_on_error)
> - xfs_iunlock(dp, XFS_ILOCK_EXCL);
> - return error;
> -}
The format for xfs_rename() in xfs_inode.h is funky.
Hopefully I caught everything.
--Mark.
More information about the xfs
mailing list