1. 03 12月, 2020 8 次提交
  2. 03 11月, 2020 4 次提交
    • D
      f2fs: add F2FS_IOC_GET_COMPRESS_OPTION ioctl · 9e2a5f8c
      Daeho Jeong 提交于
      Added a new F2FS_IOC_GET_COMPRESS_OPTION ioctl to get file compression
      option of a file.
      
      struct f2fs_comp_option {
          u8 algorithm;         => compression algorithm
                                => 0:lzo, 1:lz4, 2:zstd, 3:lzorle
          u8 log_cluster_size;  => log scale cluster size
                                => 2 ~ 8
      };
      
      struct f2fs_comp_option option;
      
      ioctl(fd, F2FS_IOC_GET_COMPRESS_OPTION, &option);
      Signed-off-by: NDaeho Jeong <daehojeong@google.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      9e2a5f8c
    • C
      f2fs: move ioctl interface definitions to separated file · fa4320ce
      Chao Yu 提交于
      Like other filesystem does, we introduce a new file f2fs.h in path of
      include/uapi/linux/, and move f2fs-specified ioctl interface definitions
      to that file, after then, in order to use those definitions, userspace
      developer only need to include the new header file rather than
      copy & paste definitions from fs/f2fs/f2fs.h.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      fa4320ce
    • C
      f2fs: fix to seek incorrect data offset in inline data file · 7a6e59d7
      Chao Yu 提交于
      As kitestramuort reported:
      
      F2FS-fs (nvme0n1p4): access invalid blkaddr:1598541474
      [   25.725898] ------------[ cut here ]------------
      [   25.725903] WARNING: CPU: 6 PID: 2018 at f2fs_is_valid_blkaddr+0x23a/0x250
      [   25.725923] Call Trace:
      [   25.725927]  ? f2fs_llseek+0x204/0x620
      [   25.725929]  ? ovl_copy_up_data+0x14f/0x200
      [   25.725931]  ? ovl_copy_up_inode+0x174/0x1e0
      [   25.725933]  ? ovl_copy_up_one+0xa22/0xdf0
      [   25.725936]  ? ovl_copy_up_flags+0xa6/0xf0
      [   25.725938]  ? ovl_aio_cleanup_handler+0xd0/0xd0
      [   25.725939]  ? ovl_maybe_copy_up+0x86/0xa0
      [   25.725941]  ? ovl_open+0x22/0x80
      [   25.725943]  ? do_dentry_open+0x136/0x350
      [   25.725945]  ? path_openat+0xb7e/0xf40
      [   25.725947]  ? __check_sticky+0x40/0x40
      [   25.725948]  ? do_filp_open+0x70/0x100
      [   25.725950]  ? __check_sticky+0x40/0x40
      [   25.725951]  ? __check_sticky+0x40/0x40
      [   25.725953]  ? __x64_sys_openat+0x1db/0x2c0
      [   25.725955]  ? do_syscall_64+0x2d/0x40
      [   25.725957]  ? entry_SYSCALL_64_after_hwframe+0x44/0xa9
      
      llseek() reports invalid block address access, the root cause is if
      file has inline data, f2fs_seek_block() will access inline data regard
      as block address index in inode block, which should be wrong, fix it.
      Reported-by: Nkitestramuort <kitestramuort@autistici.org>
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      7a6e59d7
    • J
      f2fs: call f2fs_get_meta_page_retry for nat page · 3acc4522
      Jaegeuk Kim 提交于
      When running fault injection test, if we don't stop checkpoint, some stale
      NAT entries were flushed which breaks consistency.
      
      Fixes: 86f33603 ("f2fs: handle errors of f2fs_get_meta_page_nofail")
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      3acc4522
  3. 17 10月, 2020 1 次提交
  4. 15 10月, 2020 2 次提交
    • C
      f2fs: code cleanup by removing unnecessary check · 788e96d1
      Chengguang Xu 提交于
      f2fs_seek_block() is only used for regular file,
      so don't have to check inline dentry in it.
      Signed-off-by: NChengguang Xu <cgxu519@mykernel.net>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      788e96d1
    • J
      f2fs: wait for sysfs kobject removal before freeing f2fs_sb_info · ae284d87
      Jamie Iles 提交于
      syzkaller found that with CONFIG_DEBUG_KOBJECT_RELEASE=y, unmounting an
      f2fs filesystem could result in the following splat:
      
        kobject: 'loop5' ((____ptrval____)): kobject_release, parent 0000000000000000 (delayed 250)
        kobject: 'f2fs_xattr_entry-7:5' ((____ptrval____)): kobject_release, parent 0000000000000000 (delayed 750)
        ------------[ cut here ]------------
        ODEBUG: free active (active state 0) object type: timer_list hint: delayed_work_timer_fn+0x0/0x98
        WARNING: CPU: 0 PID: 699 at lib/debugobjects.c:485 debug_print_object+0x180/0x240
        Kernel panic - not syncing: panic_on_warn set ...
        CPU: 0 PID: 699 Comm: syz-executor.5 Tainted: G S                5.9.0-rc8+ #101
        Hardware name: linux,dummy-virt (DT)
        Call trace:
         dump_backtrace+0x0/0x4d8
         show_stack+0x34/0x48
         dump_stack+0x174/0x1f8
         panic+0x360/0x7a0
         __warn+0x244/0x2ec
         report_bug+0x240/0x398
         bug_handler+0x50/0xc0
         call_break_hook+0x160/0x1d8
         brk_handler+0x30/0xc0
         do_debug_exception+0x184/0x340
         el1_dbg+0x48/0xb0
         el1_sync_handler+0x170/0x1c8
         el1_sync+0x80/0x100
         debug_print_object+0x180/0x240
         debug_check_no_obj_freed+0x200/0x430
         slab_free_freelist_hook+0x190/0x210
         kfree+0x13c/0x460
         f2fs_put_super+0x624/0xa58
         generic_shutdown_super+0x120/0x300
         kill_block_super+0x94/0xf8
         kill_f2fs_super+0x244/0x308
         deactivate_locked_super+0x104/0x150
         deactivate_super+0x118/0x148
         cleanup_mnt+0x27c/0x3c0
         __cleanup_mnt+0x28/0x38
         task_work_run+0x10c/0x248
         do_notify_resume+0x9d4/0x1188
         work_pending+0x8/0x34c
      
      Like the error handling for f2fs_register_sysfs(), we need to wait for
      the kobject to be destroyed before returning to prevent a potential
      use-after-free.
      
      Fixes: bf9e697e ("f2fs: expose features to sysfs entry")
      Cc: Jaegeuk Kim <jaegeuk@kernel.org>
      Cc: Chao Yu <chao@kernel.org>
      Signed-off-by: NJamie Iles <jamie@nuviainc.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      ae284d87
  5. 14 10月, 2020 4 次提交
    • D
      f2fs: fix writecount false positive in releasing compress blocks · 8c8cf26a
      Daeho Jeong 提交于
      In current condition check, if it detects writecount, it return -EBUSY
      regardless of f_mode of the file. Fixed it.
      Signed-off-by: NDaeho Jeong <daehojeong@google.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      8c8cf26a
    • C
      f2fs: introduce check_swap_activate_fast() · af4b6b8e
      Chao Yu 提交于
      check_swap_activate() will lookup block mapping via bmap() one by one, so
      its performance is very bad, this patch introduces check_swap_activate_fast()
      to use f2fs_fiemap() to boost this process, since f2fs_fiemap() will lookup
      block mappings in batch, therefore, it can improve swapon()'s performance
      significantly.
      
      Note that this enhancement only works when page size is equal to f2fs' block
      size.
      
      Testcase: (backend device: zram)
      - touch file
      - pin & fallocate file to 8GB
      - mkswap file
      - swapon file
      
      Before:
      real	0m2.999s
      user	0m0.000s
      sys	0m2.980s
      
      After:
      real	0m0.081s
      user	0m0.000s
      sys	0m0.064s
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      af4b6b8e
    • C
      f2fs: don't issue flush in f2fs_flush_device_cache() for nobarrier case · 6ed29fe1
      Chao Yu 提交于
      This patch changes f2fs_flush_device_cache() to skip issuing flush for
      nobarrier case.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      6ed29fe1
    • J
      f2fs: handle errors of f2fs_get_meta_page_nofail · 86f33603
      Jaegeuk Kim 提交于
      First problem is we hit BUG_ON() in f2fs_get_sum_page given EIO on
      f2fs_get_meta_page_nofail().
      
      Quick fix was not to give any error with infinite loop, but syzbot caught
      a case where it goes to that loop from fuzzed image. In turned out we abused
      f2fs_get_meta_page_nofail() like in the below call stack.
      
      - f2fs_fill_super
       - f2fs_build_segment_manager
        - build_sit_entries
         - get_current_sit_page
      
      INFO: task syz-executor178:6870 can't die for more than 143 seconds.
      task:syz-executor178 state:R
       stack:26960 pid: 6870 ppid:  6869 flags:0x00004006
      Call Trace:
      
      Showing all locks held in the system:
      1 lock held by khungtaskd/1179:
       #0: ffffffff8a554da0 (rcu_read_lock){....}-{1:2}, at: debug_show_all_locks+0x53/0x260 kernel/locking/lockdep.c:6242
      1 lock held by systemd-journal/3920:
      1 lock held by in:imklog/6769:
       #0: ffff88809eebc130 (&f->f_pos_lock){+.+.}-{3:3}, at: __fdget_pos+0xe9/0x100 fs/file.c:930
      1 lock held by syz-executor178/6870:
       #0: ffff8880925120e0 (&type->s_umount_key#47/1){+.+.}-{3:3}, at: alloc_super+0x201/0xaf0 fs/super.c:229
      
      Actually, we didn't have to use _nofail in this case, since we could return
      error to mount(2) already with the error handler.
      
      As a result, this patch tries to 1) remove _nofail callers as much as possible,
      2) deal with error case in last remaining caller, f2fs_get_sum_page().
      
      Reported-by: syzbot+ee250ac8137be41d7b13@syzkaller.appspotmail.com
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      86f33603
  6. 10 10月, 2020 1 次提交
  7. 09 10月, 2020 2 次提交
    • E
      f2fs: reject CASEFOLD inode flag without casefold feature · f6322f3f
      Eric Biggers 提交于
      syzbot reported:
      
          general protection fault, probably for non-canonical address 0xdffffc0000000001: 0000 [#1] PREEMPT SMP KASAN
          KASAN: null-ptr-deref in range [0x0000000000000008-0x000000000000000f]
          CPU: 0 PID: 6860 Comm: syz-executor835 Not tainted 5.9.0-rc8-syzkaller #0
          Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
          RIP: 0010:utf8_casefold+0x43/0x1b0 fs/unicode/utf8-core.c:107
          [...]
          Call Trace:
           f2fs_init_casefolded_name fs/f2fs/dir.c:85 [inline]
           __f2fs_setup_filename fs/f2fs/dir.c:118 [inline]
           f2fs_prepare_lookup+0x3bf/0x640 fs/f2fs/dir.c:163
           f2fs_lookup+0x10d/0x920 fs/f2fs/namei.c:494
           __lookup_hash+0x115/0x240 fs/namei.c:1445
           filename_create+0x14b/0x630 fs/namei.c:3467
           user_path_create fs/namei.c:3524 [inline]
           do_mkdirat+0x56/0x310 fs/namei.c:3664
           do_syscall_64+0x31/0x70 arch/x86/entry/common.c:46
           entry_SYSCALL_64_after_hwframe+0x44/0xa9
          [...]
      
      The problem is that an inode has F2FS_CASEFOLD_FL set, but the
      filesystem doesn't have the casefold feature flag set, and therefore
      super_block::s_encoding is NULL.
      
      Fix this by making sanity_check_inode() reject inodes that have
      F2FS_CASEFOLD_FL when the filesystem doesn't have the casefold feature.
      
      Reported-by: syzbot+05139c4039d0679e19ff@syzkaller.appspotmail.com
      Fixes: 2c2eb7a3 ("f2fs: Support case-insensitive file name lookups")
      Signed-off-by: NEric Biggers <ebiggers@google.com>
      Reviewed-by: NGabriel Krisman Bertazi <krisman@collabora.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      f6322f3f
    • J
      f2fs: fix memory alignment to support 32bit · 48046cb5
      Jaegeuk Kim 提交于
      In 32bit system, 64-bits key breaks memory alignment.
      This fixes the commit "f2fs: support 64-bits key in f2fs rb-tree node entry".
      Reported-by: NNicolas Chauvet <kwizart@gmail.com>
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      48046cb5
  8. 30 9月, 2020 4 次提交
    • J
      f2fs: fix slab leak of rpages pointer · adfc6943
      Jaegeuk Kim 提交于
      This fixes the below mem leak.
      
      [  130.157600] =============================================================================
      [  130.159662] BUG f2fs_page_array_entry-252:16 (Tainted: G        W  O     ): Objects remaining in f2fs_page_array_entry-252:16 on __kmem_cache_shutdown()
      [  130.162742] -----------------------------------------------------------------------------
      [  130.162742]
      [  130.164979] Disabling lock debugging due to kernel taint
      [  130.166188] INFO: Slab 0x000000009f5a52d2 objects=22 used=4 fp=0x00000000ba72c3e9 flags=0xfffffc0010200
      [  130.168269] CPU: 7 PID: 3560 Comm: umount Tainted: G    B   W  O      5.9.0-rc4+ #35
      [  130.170019] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.13.0-1 04/01/2014
      [  130.171941] Call Trace:
      [  130.172528]  dump_stack+0x74/0x9a
      [  130.173298]  slab_err+0xb7/0xdc
      [  130.174044]  ? kernel_poison_pages+0xc0/0xc0
      [  130.175065]  ? on_each_cpu_cond_mask+0x48/0x90
      [  130.176096]  __kmem_cache_shutdown.cold+0x34/0x141
      [  130.177190]  kmem_cache_destroy+0x59/0x100
      [  130.178223]  f2fs_destroy_page_array_cache+0x15/0x20 [f2fs]
      [  130.179527]  f2fs_put_super+0x1bc/0x380 [f2fs]
      [  130.180538]  generic_shutdown_super+0x72/0x110
      [  130.181547]  kill_block_super+0x27/0x50
      [  130.182438]  kill_f2fs_super+0x76/0xe0 [f2fs]
      [  130.183448]  deactivate_locked_super+0x3b/0x80
      [  130.184456]  deactivate_super+0x3e/0x50
      [  130.185363]  cleanup_mnt+0x109/0x160
      [  130.186179]  __cleanup_mnt+0x12/0x20
      [  130.187003]  task_work_run+0x70/0xb0
      [  130.187841]  exit_to_user_mode_prepare+0x18f/0x1b0
      [  130.188917]  syscall_exit_to_user_mode+0x31/0x170
      [  130.189989]  do_syscall_64+0x45/0x90
      [  130.190828]  entry_SYSCALL_64_after_hwframe+0x44/0xa9
      [  130.191986] RIP: 0033:0x7faf868ea2eb
      [  130.192815] Code: 7b 0c 00 f7 d8 64 89 01 48 83 c8 ff c3 66 90 f3 0f 1e fa 31 f6 e9 05 00 00 00 0f 1f 44 00 00 f3 0f 1e fa b8 a6 00 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 75 7b 0c 00 f7 d8 64 89 01
      [  130.196872] RSP: 002b:00007fffb7edb478 EFLAGS: 00000246 ORIG_RAX: 00000000000000a6
      [  130.198494] RAX: 0000000000000000 RBX: 00007faf86a18204 RCX: 00007faf868ea2eb
      [  130.201021] RDX: 0000000000000000 RSI: 0000000000000000 RDI: 000055971df71c50
      [  130.203415] RBP: 000055971df71a40 R08: 0000000000000000 R09: 00007fffb7eda1f0
      [  130.205772] R10: 00007faf86a04339 R11: 0000000000000246 R12: 000055971df71c50
      [  130.208150] R13: 0000000000000000 R14: 000055971df71b38 R15: 0000000000000000
      [  130.210515] INFO: Object 0x00000000a980843a @offset=744
      [  130.212476] INFO: Allocated in page_array_alloc+0x3d/0xe0 [f2fs] age=1572 cpu=0 pid=3297
      [  130.215030] 	__slab_alloc+0x20/0x40
      [  130.216566] 	kmem_cache_alloc+0x2a0/0x2e0
      [  130.218217] 	page_array_alloc+0x3d/0xe0 [f2fs]
      [  130.219940] 	f2fs_init_compress_ctx+0x1f/0x40 [f2fs]
      [  130.221736] 	f2fs_write_cache_pages+0x3db/0x860 [f2fs]
      [  130.223591] 	f2fs_write_data_pages+0x2c9/0x300 [f2fs]
      [  130.225414] 	do_writepages+0x43/0xd0
      [  130.226907] 	__filemap_fdatawrite_range+0xd5/0x110
      [  130.228632] 	filemap_write_and_wait_range+0x48/0xb0
      [  130.230336] 	__generic_file_write_iter+0x18a/0x1d0
      [  130.232035] 	f2fs_file_write_iter+0x226/0x550 [f2fs]
      [  130.233737] 	new_sync_write+0x113/0x1a0
      [  130.235204] 	vfs_write+0x1a6/0x200
      [  130.236579] 	ksys_write+0x67/0xe0
      [  130.237898] 	__x64_sys_write+0x1a/0x20
      [  130.239309] 	do_syscall_64+0x38/0x90
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      adfc6943
    • C
      f2fs: compress: fix to disallow enabling compress on non-empty file · 519a5a2f
      Chao Yu 提交于
      Compressed inode and normal inode has different layout, so we should
      disallow enabling compress on non-empty file to avoid race condition
      during inode .i_addr array parsing and updating.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      [Jaegeuk Kim: Fix missing condition]
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      519a5a2f
    • C
      f2fs: compress: introduce cic/dic slab cache · c68d6c88
      Chao Yu 提交于
      Add two slab caches: "f2fs_cic_entry" and "f2fs_dic_entry" for memory
      allocation of compress_io_ctx and decompress_io_ctx structure.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      c68d6c88
    • C
      f2fs: compress: introduce page array slab cache · 31083031
      Chao Yu 提交于
      Add a per-sbi slab cache "f2fs_page_array_entry-%u:%u" for memory
      allocation of page pointer array in compress context.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      [Jaegeuk Kim: Fix wrong memory allocation]
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      31083031
  9. 29 9月, 2020 11 次提交
    • C
      f2fs: fix to do sanity check on segment/section count · 3a22e9ac
      Chao Yu 提交于
      As syzbot reported:
      
      BUG: KASAN: slab-out-of-bounds in init_min_max_mtime fs/f2fs/segment.c:4710 [inline]
      BUG: KASAN: slab-out-of-bounds in f2fs_build_segment_manager+0x9302/0xa6d0 fs/f2fs/segment.c:4792
      Read of size 8 at addr ffff8880a1b934a8 by task syz-executor682/6878
      
      CPU: 1 PID: 6878 Comm: syz-executor682 Not tainted 5.9.0-rc6-syzkaller #0
      Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
      Call Trace:
       __dump_stack lib/dump_stack.c:77 [inline]
       dump_stack+0x198/0x1fd lib/dump_stack.c:118
       print_address_description.constprop.0.cold+0xae/0x497 mm/kasan/report.c:383
       __kasan_report mm/kasan/report.c:513 [inline]
       kasan_report.cold+0x1f/0x37 mm/kasan/report.c:530
       init_min_max_mtime fs/f2fs/segment.c:4710 [inline]
       f2fs_build_segment_manager+0x9302/0xa6d0 fs/f2fs/segment.c:4792
       f2fs_fill_super+0x381a/0x6e80 fs/f2fs/super.c:3633
       mount_bdev+0x32e/0x3f0 fs/super.c:1417
       legacy_get_tree+0x105/0x220 fs/fs_context.c:592
       vfs_get_tree+0x89/0x2f0 fs/super.c:1547
       do_new_mount fs/namespace.c:2875 [inline]
       path_mount+0x1387/0x20a0 fs/namespace.c:3192
       do_mount fs/namespace.c:3205 [inline]
       __do_sys_mount fs/namespace.c:3413 [inline]
       __se_sys_mount fs/namespace.c:3390 [inline]
       __x64_sys_mount+0x27f/0x300 fs/namespace.c:3390
       do_syscall_64+0x2d/0x70 arch/x86/entry/common.c:46
       entry_SYSCALL_64_after_hwframe+0x44/0xa9
      
      The root cause is: if segs_per_sec is larger than one, and segment count
      in last section is less than segs_per_sec, we will suffer out-of-boundary
      memory access on sit_i->sentries[] in init_min_max_mtime().
      
      Fix this by adding sanity check among segment count, section count and
      segs_per_sec value in sanity_check_raw_super().
      
      Reported-by: syzbot+481a3ffab50fed41dcc0@syzkaller.appspotmail.com
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      3a22e9ac
    • C
      f2fs: fix to check segment boundary during SIT page readahead · 6a257471
      Chao Yu 提交于
      As syzbot reported:
      
      kernel BUG at fs/f2fs/segment.h:657!
      invalid opcode: 0000 [#1] PREEMPT SMP KASAN
      CPU: 1 PID: 16220 Comm: syz-executor.0 Not tainted 5.9.0-rc5-syzkaller #0
      Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
      RIP: 0010:f2fs_ra_meta_pages+0xa51/0xdc0 fs/f2fs/segment.h:657
      Call Trace:
       build_sit_entries fs/f2fs/segment.c:4195 [inline]
       f2fs_build_segment_manager+0x4b8a/0xa3c0 fs/f2fs/segment.c:4779
       f2fs_fill_super+0x377d/0x6b80 fs/f2fs/super.c:3633
       mount_bdev+0x32e/0x3f0 fs/super.c:1417
       legacy_get_tree+0x105/0x220 fs/fs_context.c:592
       vfs_get_tree+0x89/0x2f0 fs/super.c:1547
       do_new_mount fs/namespace.c:2875 [inline]
       path_mount+0x1387/0x2070 fs/namespace.c:3192
       do_mount fs/namespace.c:3205 [inline]
       __do_sys_mount fs/namespace.c:3413 [inline]
       __se_sys_mount fs/namespace.c:3390 [inline]
       __x64_sys_mount+0x27f/0x300 fs/namespace.c:3390
       do_syscall_64+0x2d/0x70 arch/x86/entry/common.c:46
       entry_SYSCALL_64_after_hwframe+0x44/0xa9
      
      @blkno in f2fs_ra_meta_pages could exceed max segment count, causing panic
      in following sanity check in current_sit_addr(), add check condition to
      avoid this issue.
      
      Reported-by: syzbot+3698081bcf0bb2d12174@syzkaller.appspotmail.com
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      6a257471
    • C
      f2fs: fix uninit-value in f2fs_lookup · 6d7ab88a
      Chao Yu 提交于
      As syzbot reported:
      
      Call Trace:
       __dump_stack lib/dump_stack.c:77 [inline]
       dump_stack+0x21c/0x280 lib/dump_stack.c:118
       kmsan_report+0xf7/0x1e0 mm/kmsan/kmsan_report.c:122
       __msan_warning+0x58/0xa0 mm/kmsan/kmsan_instr.c:219
       f2fs_lookup+0xe05/0x1a80 fs/f2fs/namei.c:503
       lookup_open fs/namei.c:3082 [inline]
       open_last_lookups fs/namei.c:3177 [inline]
       path_openat+0x2729/0x6a90 fs/namei.c:3365
       do_filp_open+0x2b8/0x710 fs/namei.c:3395
       do_sys_openat2+0xa88/0x1140 fs/open.c:1168
       do_sys_open fs/open.c:1184 [inline]
       __do_compat_sys_openat fs/open.c:1242 [inline]
       __se_compat_sys_openat+0x2a4/0x310 fs/open.c:1240
       __ia32_compat_sys_openat+0x56/0x70 fs/open.c:1240
       do_syscall_32_irqs_on arch/x86/entry/common.c:80 [inline]
       __do_fast_syscall_32+0x129/0x180 arch/x86/entry/common.c:139
       do_fast_syscall_32+0x6a/0xc0 arch/x86/entry/common.c:162
       do_SYSENTER_32+0x73/0x90 arch/x86/entry/common.c:205
       entry_SYSENTER_compat_after_hwframe+0x4d/0x5c
      
      In f2fs_lookup(), @res_page could be used before being initialized,
      because in __f2fs_find_entry(), once F2FS_I(dir)->i_current_depth was
      been fuzzed to zero, then @res_page will never be initialized, causing
      this kmsan warning, relocating @res_page initialization place to fix
      this bug.
      
      Reported-by: syzbot+0eac6f0bbd558fd866d7@syzkaller.appspotmail.com
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      6d7ab88a
    • C
      f2fs: remove unneeded parameter in find_in_block() · 17f930e0
      Chao Yu 提交于
      We can relocate @res_page assignment in find_in_block() to
      its caller, so unneeded parameter could be removed for cleanup.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      17f930e0
    • W
      f2fs: fix wrong total_sections check and fsmeta check · f99ba9ad
      Wang Xiaojun 提交于
      Meta area is not included in section_count computation.
      So the minimum number of total_sections is 1 meanwhile it cannot be
      greater than segment_count_main.
      
      The minimum number of meta segments is 8 (SB + 2 (CP + SIT + NAT) + SSA).
      Signed-off-by: NWang Xiaojun <wangxiaojun11@huawei.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      f99ba9ad
    • W
      f2fs: remove duplicated code in sanity_check_area_boundary · d89f5891
      Wang Xiaojun 提交于
      Use seg_end_blkaddr instead of "segment0_blkaddr + (segment_count <<
      log_blocks_per_seg)".
      Signed-off-by: NWang Xiaojun <wangxiaojun11@huawei.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      d89f5891
    • W
      f2fs: remove unused check on version_bitmap · e6e42187
      Wang Xiaojun 提交于
      A NULL will not be return by __bitmap_ptr here.
      Remove the unused check.
      Signed-off-by: NWang Xiaojun <wangxiaojun11@huawei.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      e6e42187
    • C
      f2fs: relocate blkzoned feature check · d0660122
      Chao Yu 提交于
      Relocate blkzoned feature check into parse_options() like
      other feature check.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      d0660122
    • C
      f2fs: do sanity check on zoned block device path · 07eb1d69
      Chao Yu 提交于
      sbi->devs would be initialized only if image enables multiple device
      feature or blkzoned feature, if blkzoned feature flag was set by fuzz
      in non-blkzoned device, we will suffer below panic:
      
      get_zone_idx fs/f2fs/segment.c:4892 [inline]
      f2fs_usable_zone_blks_in_seg fs/f2fs/segment.c:4943 [inline]
      f2fs_usable_blks_in_seg+0x39b/0xa00 fs/f2fs/segment.c:4999
      Call Trace:
       check_block_count+0x69/0x4e0 fs/f2fs/segment.h:704
       build_sit_entries fs/f2fs/segment.c:4403 [inline]
       f2fs_build_segment_manager+0x51da/0xa370 fs/f2fs/segment.c:5100
       f2fs_fill_super+0x3880/0x6ff0 fs/f2fs/super.c:3684
       mount_bdev+0x32e/0x3f0 fs/super.c:1417
       legacy_get_tree+0x105/0x220 fs/fs_context.c:592
       vfs_get_tree+0x89/0x2f0 fs/super.c:1547
       do_new_mount fs/namespace.c:2896 [inline]
       path_mount+0x12ae/0x1e70 fs/namespace.c:3216
       do_mount fs/namespace.c:3229 [inline]
       __do_sys_mount fs/namespace.c:3437 [inline]
       __se_sys_mount fs/namespace.c:3414 [inline]
       __x64_sys_mount+0x27f/0x300 fs/namespace.c:3414
       do_syscall_64+0x2d/0x70 arch/x86/entry/common.c:46
      
      Add sanity check to inconsistency on factors: blkzoned flag, device
      path and device character to avoid above panic.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      07eb1d69
    • Z
      f2fs: add trace exit in exception path · 9b664822
      Zhang Qilong 提交于
      Missing the trace exit in f2fs_sync_dirty_inodes
      Signed-off-by: NZhang Qilong <zhangqilong3@huawei.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      9b664822
    • X
      f2fs: change return value of reserved_segments to unsigned int · 4470eb28
      Xiaojun Wang 提交于
      The type of SM_I(sbi)->reserved_segments is unsigned int,
      so change the return value to unsigned int.
      The type cast can be removed in reserved_sections as a result.
      Signed-off-by: NXiaojun Wang <wangxiaojun11@huawei.com>
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      4470eb28
  10. 24 9月, 2020 1 次提交
  11. 22 9月, 2020 2 次提交
    • E
      fscrypt: make fscrypt_set_test_dummy_encryption() take a 'const char *' · c8c868ab
      Eric Biggers 提交于
      fscrypt_set_test_dummy_encryption() requires that the optional argument
      to the test_dummy_encryption mount option be specified as a substring_t.
      That doesn't work well with filesystems that use the new mount API,
      since the new way of parsing mount options doesn't use substring_t.
      
      Make it take the argument as a 'const char *' instead.
      
      Instead of moving the match_strdup() into the callers in ext4 and f2fs,
      make them just use arg->from directly.  Since the pattern is
      "test_dummy_encryption=%s", the argument will be null-terminated.
      Acked-by: NJeff Layton <jlayton@kernel.org>
      Link: https://lore.kernel.org/r/20200917041136.178600-14-ebiggers@kernel.orgSigned-off-by: NEric Biggers <ebiggers@google.com>
      c8c868ab
    • E
      fscrypt: handle test_dummy_encryption in more logical way · ac4acb1f
      Eric Biggers 提交于
      The behavior of the test_dummy_encryption mount option is that when a
      new file (or directory or symlink) is created in an unencrypted
      directory, it's automatically encrypted using a dummy encryption policy.
      That's it; in particular, the encryption (or lack thereof) of existing
      files (or directories or symlinks) doesn't change.
      
      Unfortunately the implementation of test_dummy_encryption is a bit weird
      and confusing.  When test_dummy_encryption is enabled and a file is
      being created in an unencrypted directory, we set up an encryption key
      (->i_crypt_info) for the directory.  This isn't actually used to do any
      encryption, however, since the directory is still unencrypted!  Instead,
      ->i_crypt_info is only used for inheriting the encryption policy.
      
      One consequence of this is that the filesystem ends up providing a
      "dummy context" (policy + nonce) instead of a "dummy policy".  In
      commit ed318a6c ("fscrypt: support test_dummy_encryption=v2"), I
      mistakenly thought this was required.  However, actually the nonce only
      ends up being used to derive a key that is never used.
      
      Another consequence of this implementation is that it allows for
      'inode->i_crypt_info != NULL && !IS_ENCRYPTED(inode)', which is an edge
      case that can be forgotten about.  For example, currently
      FS_IOC_GET_ENCRYPTION_POLICY on an unencrypted directory may return the
      dummy encryption policy when the filesystem is mounted with
      test_dummy_encryption.  That seems like the wrong thing to do, since
      again, the directory itself is not actually encrypted.
      
      Therefore, switch to a more logical and maintainable implementation
      where the dummy encryption policy inheritance is done without setting up
      keys for unencrypted directories.  This involves:
      
      - Adding a function fscrypt_policy_to_inherit() which returns the
        encryption policy to inherit from a directory.  This can be a real
        policy, a dummy policy, or no policy.
      
      - Replacing struct fscrypt_dummy_context, ->get_dummy_context(), etc.
        with struct fscrypt_dummy_policy, ->get_dummy_policy(), etc.
      
      - Making fscrypt_fname_encrypted_size() take an fscrypt_policy instead
        of an inode.
      Acked-by: NJaegeuk Kim <jaegeuk@kernel.org>
      Acked-by: NJeff Layton <jlayton@kernel.org>
      Link: https://lore.kernel.org/r/20200917041136.178600-13-ebiggers@kernel.orgSigned-off-by: NEric Biggers <ebiggers@google.com>
      ac4acb1f