[Devel] [PATCH RHEL7 COMMIT] fuse: no mtime flush on fdatasync

Konstantin Khorenko khorenko at virtuozzo.com
Wed Dec 7 07:24:33 PST 2016


Please consider to RK.

--
Best regards,

Konstantin Khorenko,
Virtuozzo Linux Kernel Team

On 12/02/2016 05:35 PM, Konstantin Khorenko wrote:
> The commit is pushed to "branch-rh7-3.10.0-327.36.1.vz7.20.x-ovz" and will appear at https://src.openvz.org/scm/ovz/vzkernel.git
> after rh7-3.10.0-327.36.1.vz7.20.9
> ------>
> commit 2b39263eeee33196c731257c173f7be35d4bd8a4
> Author: Maxim Patlasov <mpatlasov at virtuozzo.com>
> Date:   Fri Dec 2 18:34:57 2016 +0400
>
>     fuse: no mtime flush on fdatasync
>
>     fuse_fsync_common() may skip fuse_flush_mtime() if datasync=1 because
>     mtime is pure metadata and the content of file doesn't depend on it.
>
>     https://jira.sw.ru/browse/PSBM-55919
>
>     Signed-off-by: Maxim Patlasov <mpatlasov at virtuozzo.com>
>     Acked-by: Dmitry Monakhov <dmonakhov at openvz.org>
> ---
>  fs/fuse/file.c | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/fs/fuse/file.c b/fs/fuse/file.c
> index d11125f..52bca91 100644
> --- a/fs/fuse/file.c
> +++ b/fs/fuse/file.c
> @@ -691,8 +691,8 @@ int fuse_fsync_common(struct file *file, loff_t start, loff_t end,
>  	if (err)
>  		goto out;
>
> -	if (test_bit(FUSE_I_MTIME_UPDATED,
> -		     &get_fuse_inode(inode)->state)) {
> +	if (!datasync && test_bit(FUSE_I_MTIME_UPDATED,
> +				  &get_fuse_inode(inode)->state)) {
>  		err = fuse_flush_mtime(file, false);
>  		if (err)
>  			goto out;
> .
>


More information about the Devel mailing list