The commit is pushed to "branch-rh9-5.14.0-427.37.1.vz9.78.x-ovz" and will 
appear at g...@bitbucket.org:openvz/vzkernel.git
after rh9-5.14.0-427.37.1.vz9.78.4
------>
commit 96fe95db737e0b44cd31b66d1b2f7f8c0a0c5efc
Author: Alexey Kuznetsov <kuz...@virtuozzo.com>
Date:   Fri Nov 15 22:13:34 2024 +0800

    fs: fuse: rwwr deadlock in fallocate
    
    One thread has made fallocate and needs to take inode_lock()
    to commit attributes _before_ it dropped dio write iocount.
    Another thread took inode_mutex and has to wait for pending
    writes since it hit fuse cached writeback region.
    
    Affects: #VSTOR-95025
    https://virtuozzo.atlassian.net/browse/VSTOR-95025
    Fixes: ead9b9aec946 ("fs: fuse: kio: resolve race condition fallocate vs
    shrink")
    
    Signed-off-by: Alexey Kuznetsov <kuz...@virtuozzo.com>
    
    Feature: vStorage
---
 fs/fuse/file.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/fs/fuse/file.c b/fs/fuse/file.c
index aa248bd90694..6a89f9642325 100644
--- a/fs/fuse/file.c
+++ b/fs/fuse/file.c
@@ -3469,8 +3469,8 @@ static long fuse_file_fallocate(struct file *file, int 
mode, loff_t offset,
        args.in_args[0].value = &inarg;
        err = fuse_simple_request(fm, &args);
        if (revoke_lock) {
-               inode_lock(inode);
                fuse_write_dio_end(fi);
+               inode_lock(inode);
        }
        if (err == -ENOSYS) {
                fm->fc->no_fallocate = 1;
_______________________________________________
Devel mailing list
Devel@openvz.org
https://lists.openvz.org/mailman/listinfo/devel

Reply via email to