Re: [PATCH v4 03/27] xfs: Hold inode locks in xfs_ialloc

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> On Oct 21, 2022, at 3:29 PM, allison.henderson@xxxxxxxxxx wrote:
> 
> From: Allison Henderson <allison.henderson@xxxxxxxxxx>
> 
> Modify xfs_ialloc to hold locks after return.  Caller will be
> responsible for manual unlock.  We will need this later to hold locks
> across parent pointer operations
> 
> Signed-off-by: Allison Henderson <allison.henderson@xxxxxxxxxx>
> Reviewed-by: Darrick J. Wong <djwong@xxxxxxxxxx>

Looks good
Reviewed-by: Catherine Hoang <catherine.hoang@xxxxxxxxxx>
> ---
> fs/xfs/xfs_inode.c   | 6 +++++-
> fs/xfs/xfs_qm.c      | 4 +++-
> fs/xfs/xfs_symlink.c | 3 +++
> 3 files changed, 11 insertions(+), 2 deletions(-)
> 
> diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c
> index 5ebbfceb1ada..f21f625b428e 100644
> --- a/fs/xfs/xfs_inode.c
> +++ b/fs/xfs/xfs_inode.c
> @@ -774,6 +774,8 @@ xfs_inode_inherit_flags2(
> /*
>  * Initialise a newly allocated inode and return the in-core inode to the
>  * caller locked exclusively.
> + *
> + * Caller is responsible for unlocking the inode manually upon return
>  */
> int
> xfs_init_new_inode(
> @@ -899,7 +901,7 @@ xfs_init_new_inode(
> 	/*
> 	 * Log the new values stuffed into the inode.
> 	 */
> -	xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL);
> +	xfs_trans_ijoin(tp, ip, 0);
> 	xfs_trans_log_inode(tp, ip, flags);
> 
> 	/* now that we have an i_mode we can setup the inode structure */
> @@ -1076,6 +1078,7 @@ xfs_create(
> 	xfs_qm_dqrele(pdqp);
> 
> 	*ipp = ip;
> +	xfs_iunlock(ip, XFS_ILOCK_EXCL);
> 	return 0;
> 
>  out_trans_cancel:
> @@ -1172,6 +1175,7 @@ xfs_create_tmpfile(
> 	xfs_qm_dqrele(pdqp);
> 
> 	*ipp = ip;
> +	xfs_iunlock(ip, XFS_ILOCK_EXCL);
> 	return 0;
> 
>  out_trans_cancel:
> diff --git a/fs/xfs/xfs_qm.c b/fs/xfs/xfs_qm.c
> index 18bb4ec4d7c9..96e7b4959721 100644
> --- a/fs/xfs/xfs_qm.c
> +++ b/fs/xfs/xfs_qm.c
> @@ -818,8 +818,10 @@ xfs_qm_qino_alloc(
> 		ASSERT(xfs_is_shutdown(mp));
> 		xfs_alert(mp, "%s failed (error %d)!", __func__, error);
> 	}
> -	if (need_alloc)
> +	if (need_alloc) {
> 		xfs_finish_inode_setup(*ipp);
> +		xfs_iunlock(*ipp, XFS_ILOCK_EXCL);
> +	}
> 	return error;
> }
> 
> diff --git a/fs/xfs/xfs_symlink.c b/fs/xfs/xfs_symlink.c
> index 8389f3ef88ef..d8e120913036 100644
> --- a/fs/xfs/xfs_symlink.c
> +++ b/fs/xfs/xfs_symlink.c
> @@ -337,6 +337,7 @@ xfs_symlink(
> 	xfs_qm_dqrele(pdqp);
> 
> 	*ipp = ip;
> +	xfs_iunlock(ip, XFS_ILOCK_EXCL);
> 	return 0;
> 
> out_trans_cancel:
> @@ -358,6 +359,8 @@ xfs_symlink(
> 
> 	if (unlock_dp_on_error)
> 		xfs_iunlock(dp, XFS_ILOCK_EXCL);
> +	if (ip)
> +		xfs_iunlock(ip, XFS_ILOCK_EXCL);
> 	return error;
> }
> 
> -- 
> 2.25.1
> 





[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux