Commit 297da633 authored by Allison Henderson's avatar Allison Henderson Committed by Darrick J. Wong

xfs: Expose init_xattrs in xfs_create_tmpfile

Tmp files are used as part of rename operations and will need attr forks
initialized for parent pointers.  Expose the init_xattrs parameter to
the calling function to initialize the fork.
Signed-off-by: default avatarAllison Henderson <allison.henderson@oracle.com>
Reviewed-by: default avatarDarrick J. Wong <djwong@kernel.org>
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
parent ae673f53
...@@ -1185,6 +1185,7 @@ xfs_create_tmpfile( ...@@ -1185,6 +1185,7 @@ xfs_create_tmpfile(
struct mnt_idmap *idmap, struct mnt_idmap *idmap,
struct xfs_inode *dp, struct xfs_inode *dp,
umode_t mode, umode_t mode,
bool init_xattrs,
struct xfs_inode **ipp) struct xfs_inode **ipp)
{ {
struct xfs_mount *mp = dp->i_mount; struct xfs_mount *mp = dp->i_mount;
...@@ -1225,7 +1226,7 @@ xfs_create_tmpfile( ...@@ -1225,7 +1226,7 @@ xfs_create_tmpfile(
error = xfs_dialloc(&tp, dp->i_ino, mode, &ino); error = xfs_dialloc(&tp, dp->i_ino, mode, &ino);
if (!error) if (!error)
error = xfs_init_new_inode(idmap, tp, dp, ino, mode, error = xfs_init_new_inode(idmap, tp, dp, ino, mode,
0, 0, prid, false, &ip); 0, 0, prid, init_xattrs, &ip);
if (error) if (error)
goto out_trans_cancel; goto out_trans_cancel;
...@@ -3037,7 +3038,7 @@ xfs_rename_alloc_whiteout( ...@@ -3037,7 +3038,7 @@ xfs_rename_alloc_whiteout(
int error; int error;
error = xfs_create_tmpfile(idmap, dp, S_IFCHR | WHITEOUT_MODE, error = xfs_create_tmpfile(idmap, dp, S_IFCHR | WHITEOUT_MODE,
&tmpfile); false, &tmpfile);
if (error) if (error)
return error; return error;
......
...@@ -522,7 +522,7 @@ int xfs_create(struct mnt_idmap *idmap, ...@@ -522,7 +522,7 @@ int xfs_create(struct mnt_idmap *idmap,
umode_t mode, dev_t rdev, bool need_xattr, umode_t mode, dev_t rdev, bool need_xattr,
struct xfs_inode **ipp); struct xfs_inode **ipp);
int xfs_create_tmpfile(struct mnt_idmap *idmap, int xfs_create_tmpfile(struct mnt_idmap *idmap,
struct xfs_inode *dp, umode_t mode, struct xfs_inode *dp, umode_t mode, bool init_xattrs,
struct xfs_inode **ipp); struct xfs_inode **ipp);
int xfs_remove(struct xfs_inode *dp, struct xfs_name *name, int xfs_remove(struct xfs_inode *dp, struct xfs_name *name,
struct xfs_inode *ip); struct xfs_inode *ip);
......
...@@ -201,7 +201,7 @@ xfs_generic_create( ...@@ -201,7 +201,7 @@ xfs_generic_create(
xfs_create_need_xattr(dir, default_acl, acl), xfs_create_need_xattr(dir, default_acl, acl),
&ip); &ip);
} else { } else {
error = xfs_create_tmpfile(idmap, XFS_I(dir), mode, &ip); error = xfs_create_tmpfile(idmap, XFS_I(dir), mode, false, &ip);
} }
if (unlikely(error)) if (unlikely(error))
goto out_free_acl; goto out_free_acl;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment