mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-01 10:42:11 +00:00
xfs: pass the icreate args object to xfs_dialloc
Pass the xfs_icreate_args object to xfs_dialloc since we can extract the relevant mode (really just the file type) and parent inumber from there. This simplifies the calling convention in preparation for the next patch. Signed-off-by: Darrick J. Wong <djwong@kernel.org> Reviewed-by: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
feb09b727b
commit
390b4775d6
@ -1855,11 +1855,12 @@ xfs_dialloc_try_ag(
|
|||||||
int
|
int
|
||||||
xfs_dialloc(
|
xfs_dialloc(
|
||||||
struct xfs_trans **tpp,
|
struct xfs_trans **tpp,
|
||||||
xfs_ino_t parent,
|
const struct xfs_icreate_args *args,
|
||||||
umode_t mode,
|
|
||||||
xfs_ino_t *new_ino)
|
xfs_ino_t *new_ino)
|
||||||
{
|
{
|
||||||
struct xfs_mount *mp = (*tpp)->t_mountp;
|
struct xfs_mount *mp = (*tpp)->t_mountp;
|
||||||
|
xfs_ino_t parent = args->pip ? args->pip->i_ino : 0;
|
||||||
|
umode_t mode = args->mode & S_IFMT;
|
||||||
xfs_agnumber_t agno;
|
xfs_agnumber_t agno;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
xfs_agnumber_t start_agno;
|
xfs_agnumber_t start_agno;
|
||||||
|
@ -33,11 +33,13 @@ xfs_make_iptr(struct xfs_mount *mp, struct xfs_buf *b, int o)
|
|||||||
return xfs_buf_offset(b, o << (mp)->m_sb.sb_inodelog);
|
return xfs_buf_offset(b, o << (mp)->m_sb.sb_inodelog);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct xfs_icreate_args;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Allocate an inode on disk. Mode is used to tell whether the new inode will
|
* Allocate an inode on disk. Mode is used to tell whether the new inode will
|
||||||
* need space, and whether it is a directory.
|
* need space, and whether it is a directory.
|
||||||
*/
|
*/
|
||||||
int xfs_dialloc(struct xfs_trans **tpp, xfs_ino_t parent, umode_t mode,
|
int xfs_dialloc(struct xfs_trans **tpp, const struct xfs_icreate_args *args,
|
||||||
xfs_ino_t *new_ino);
|
xfs_ino_t *new_ino);
|
||||||
|
|
||||||
int xfs_difree(struct xfs_trans *tp, struct xfs_perag *pag,
|
int xfs_difree(struct xfs_trans *tp, struct xfs_perag *pag,
|
||||||
|
@ -88,7 +88,7 @@ xrep_tempfile_create(
|
|||||||
goto out_release_dquots;
|
goto out_release_dquots;
|
||||||
|
|
||||||
/* Allocate inode, set up directory. */
|
/* Allocate inode, set up directory. */
|
||||||
error = xfs_dialloc(&tp, dp->i_ino, mode, &ino);
|
error = xfs_dialloc(&tp, &args, &ino);
|
||||||
if (error)
|
if (error)
|
||||||
goto out_trans_cancel;
|
goto out_trans_cancel;
|
||||||
error = xfs_icreate(tp, ino, &args, &sc->tempip);
|
error = xfs_icreate(tp, ino, &args, &sc->tempip);
|
||||||
|
@ -704,7 +704,7 @@ xfs_create(
|
|||||||
* entry pointing to them, but a directory also the "." entry
|
* entry pointing to them, but a directory also the "." entry
|
||||||
* pointing to itself.
|
* pointing to itself.
|
||||||
*/
|
*/
|
||||||
error = xfs_dialloc(&tp, dp->i_ino, args->mode, &ino);
|
error = xfs_dialloc(&tp, args, &ino);
|
||||||
if (!error)
|
if (!error)
|
||||||
error = xfs_icreate(tp, ino, args, &du.ip);
|
error = xfs_icreate(tp, ino, args, &du.ip);
|
||||||
if (error)
|
if (error)
|
||||||
@ -812,7 +812,7 @@ xfs_create_tmpfile(
|
|||||||
if (error)
|
if (error)
|
||||||
goto out_release_dquots;
|
goto out_release_dquots;
|
||||||
|
|
||||||
error = xfs_dialloc(&tp, dp->i_ino, args->mode, &ino);
|
error = xfs_dialloc(&tp, args, &ino);
|
||||||
if (!error)
|
if (!error)
|
||||||
error = xfs_icreate(tp, ino, args, &ip);
|
error = xfs_icreate(tp, ino, args, &ip);
|
||||||
if (error)
|
if (error)
|
||||||
|
@ -799,7 +799,7 @@ xfs_qm_qino_alloc(
|
|||||||
};
|
};
|
||||||
xfs_ino_t ino;
|
xfs_ino_t ino;
|
||||||
|
|
||||||
error = xfs_dialloc(&tp, 0, S_IFREG, &ino);
|
error = xfs_dialloc(&tp, &args, &ino);
|
||||||
if (!error)
|
if (!error)
|
||||||
error = xfs_icreate(tp, ino, &args, ipp);
|
error = xfs_icreate(tp, ino, &args, ipp);
|
||||||
if (error) {
|
if (error) {
|
||||||
|
@ -165,7 +165,7 @@ xfs_symlink(
|
|||||||
/*
|
/*
|
||||||
* Allocate an inode for the symlink.
|
* Allocate an inode for the symlink.
|
||||||
*/
|
*/
|
||||||
error = xfs_dialloc(&tp, dp->i_ino, S_IFLNK, &ino);
|
error = xfs_dialloc(&tp, &args, &ino);
|
||||||
if (!error)
|
if (!error)
|
||||||
error = xfs_icreate(tp, ino, &args, &du.ip);
|
error = xfs_icreate(tp, ino, &args, &du.ip);
|
||||||
if (error)
|
if (error)
|
||||||
|
Loading…
Reference in New Issue
Block a user