android_kernel_xiaomi_sm7250/fs/fuse
Miklos Szeredi 9440600419 BACKPORT: fuse: fix warning in tree_insert() and clean up writepage insertion
fuse_writepages_fill() calls tree_insert() with ap->num_pages = 0 which
triggers the following warning:

 WARNING: CPU: 1 PID: 17211 at fs/fuse/file.c:1728 tree_insert+0xab/0xc0 [fuse]
 RIP: 0010:tree_insert+0xab/0xc0 [fuse]
 Call Trace:
  fuse_writepages_fill+0x5da/0x6a0 [fuse]
  write_cache_pages+0x171/0x470
  fuse_writepages+0x8a/0x100 [fuse]
  do_writepages+0x43/0xe0

Fix up the warning and clean up the code around rb-tree insertion:

 - Rename tree_insert() to fuse_insert_writeback() and make it return the
   conflicting entry in case of failure

 - Re-add tree_insert() as a wrapper around fuse_insert_writeback()

 - Rename fuse_writepage_in_flight() to fuse_writepage_add() and reverse
   the meaning of the return value to mean

    + "true" in case the writepage entry was successfully added

    + "false" in case it was in-fligt queued on an existing writepage
       entry's auxiliary list or the existing writepage entry's temporary
       page updated

   Switch from fuse_find_writeback() + tree_insert() to
   fuse_insert_writeback()

 - Move setting orig_pages to before inserting/updating the entry; this may
   result in the orig_pages value being discarded later in case of an
   in-flight request

 - In case of a new writepage entry use fuse_writepage_add()
   unconditionally, only set data->wpa if the entry was added.

Fixes: 6b2fb79963fb ("fuse: optimize writepages search")
Reported-by: kernel test robot <rong.a.chen@intel.com>
Original-path-by: Vasily Averin <vvs@virtuozzo.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Signed-off-by: UtsavBalar1231 <utsavbalar1231@gmail.com>
Change-Id: I2ae5f55cc95ce93a5a6892baca52c9cfd4a85503
2022-11-12 11:22:15 +00:00
..
acl.c Revert "fuse: fix bad inode" 2022-11-12 11:21:59 +00:00
control.c BACKPORT: fuse: clean up aborted 2022-11-12 11:21:58 +00:00
cuse.c BACKPORT: cuse: convert init to simple api 2022-11-12 11:22:07 +00:00
dev.c fs: fuse: Resolve commit 99db28212b with upstream 2022-11-12 11:22:14 +00:00
dir.c ANDROID: fuse: Allocate zeroed memory for canonical path 2022-11-12 11:22:14 +00:00
file.c BACKPORT: fuse: fix warning in tree_insert() and clean up writepage insertion 2022-11-12 11:22:15 +00:00
fuse_i.h BACKPORT: fuse: optimize writepages search 2022-11-12 11:22:14 +00:00
inode.c FROMLIST: fuse: Passthrough initialization and release 2022-11-12 11:22:12 +00:00
Kconfig
Makefile FROMLIST: fuse: Definitions and ioctl for passthrough 2022-11-12 11:22:12 +00:00
OWNERS ANDROID: FUSE OWNERS pointing to android-mainline OWNERS 2021-05-14 11:43:20 +00:00
passthrough.c ANDROID: fs/fuse: Keep FUSE file times consistent with lower file 2022-11-12 11:22:14 +00:00
readdir.c BACKPORT: fuse: fix beyond-end-of-page access in fuse_parse_cache() 2022-11-12 11:22:10 +00:00
xattr.c BACKPORT: fuse: rearrange and resize fuse_args fields 2022-11-12 11:22:03 +00:00