提交 5bf1f262 编写于 作者: C Christoph Hellwig 提交者: Ben Myers

xfs: always return with the iolock held from xfs_file_aio_write_checks

While xfs_iunlock is fine with 0 lockflags the calling conventions are much
cleaner if xfs_file_aio_write_checks never returns without the iolock held.
Reviewed-by: NDave Chinner <dchinner@redhat.com>
Signed-off-by: NChristoph Hellwig <hch@lst.de>
Signed-off-by: NBen Myers <bpm@sgi.com>
上级 2813d682
...@@ -636,7 +636,9 @@ xfs_zero_eof( ...@@ -636,7 +636,9 @@ xfs_zero_eof(
/* /*
* Common pre-write limit and setup checks. * Common pre-write limit and setup checks.
* *
* Returns with iolock held according to @iolock. * Called with the iolocked held either shared and exclusive according to
* @iolock, and returns with it held. Might upgrade the iolock to exclusive
* if called for a direct write beyond i_size.
*/ */
STATIC ssize_t STATIC ssize_t
xfs_file_aio_write_checks( xfs_file_aio_write_checks(
...@@ -653,8 +655,7 @@ xfs_file_aio_write_checks( ...@@ -653,8 +655,7 @@ xfs_file_aio_write_checks(
restart: restart:
error = generic_write_checks(file, pos, count, S_ISBLK(inode->i_mode)); error = generic_write_checks(file, pos, count, S_ISBLK(inode->i_mode));
if (error) { if (error) {
xfs_rw_iunlock(ip, XFS_ILOCK_EXCL | *iolock); xfs_rw_iunlock(ip, XFS_ILOCK_EXCL);
*iolock = 0;
return error; return error;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册