[Ocfs2-devel] [PATCH 3/4] ocfs2: fix disk file size and memory file size mismatch
Junxiao Bi
junxiao.bi at oracle.com
Mon Nov 30 22:44:54 PST 2015
On 11/20/2015 04:23 PM, Ryan Ding wrote:
> When doing append direct write in an already allocated cluster, and fast path
> in ocfs2_dio_get_block() is triggered, function ocfs2_dio_end_io_write() will
> be skipped as there is no context allocated. So disk file size will not be
> changed as it should be.
> The solution is to skip fast path when we are about to change file size.
>
> Fixes: af1310367f41 ("ocfs2: fix sparse file & data ordering issue in direct io.")
Patch looks good. But this tag is useless for a commit not merged into
mainline. Maybe we can fold this patch into above commit.
Thanks,
Junxiao.
> Signed-off-by: Ryan Ding <ryan.ding at oracle.com>
> ---
> fs/ocfs2/aops.c | 27 +++++++++++++++++----------
> 1 files changed, 17 insertions(+), 10 deletions(-)
>
> diff --git a/fs/ocfs2/aops.c b/fs/ocfs2/aops.c
> index d571509..f33cfe4 100644
> --- a/fs/ocfs2/aops.c
> +++ b/fs/ocfs2/aops.c
> @@ -2167,19 +2167,26 @@ static int ocfs2_dio_get_block(struct inode *inode, sector_t iblock,
> mlog(0, "get block of %lu at %llu:%u req %u\n",
> inode->i_ino, pos, len, total_len);
>
> - down_read(&oi->ip_alloc_sem);
> - /* This is the fast path for re-write. */
> - ret = ocfs2_get_block(inode, iblock, bh_result, create);
> + /*
> + * Because we need to change file size in ocfs2_dio_end_io_write(), or
> + * we may need to add it to orphan dir. So can not fall to fast path
> + * while file size will be changed.
> + */
> + if (pos + total_len <= i_size_read(inode)) {
> + down_read(&oi->ip_alloc_sem);
> + /* This is the fast path for re-write. */
> + ret = ocfs2_get_block(inode, iblock, bh_result, create);
>
> - up_read(&oi->ip_alloc_sem);
> + up_read(&oi->ip_alloc_sem);
>
> - if (buffer_mapped(bh_result) &&
> - !buffer_new(bh_result) &&
> - ret == 0)
> - goto out;
> + if (buffer_mapped(bh_result) &&
> + !buffer_new(bh_result) &&
> + ret == 0)
> + goto out;
>
> - /* Clear state set by ocfs2_get_block. */
> - bh_result->b_state = 0;
> + /* Clear state set by ocfs2_get_block. */
> + bh_result->b_state = 0;
> + }
>
> dwc = ocfs2_dio_alloc_write_ctx(bh_result, &first_get_block);
> if (unlikely(dwc == NULL)) {
>
More information about the Ocfs2-devel
mailing list