1. 30 3月, 2017 1 次提交
  2. 25 3月, 2017 1 次提交
  3. 22 3月, 2017 2 次提交
    • J
      f2fs: add fault injection on f2fs_truncate · 14b44d23
      Jaegeuk Kim 提交于
      Inject a fault during f2fs_truncate().
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      14b44d23
    • J
      f2fs: build stat_info before orphan inode recovery · aa51d08a
      Jaegeuk Kim 提交于
      f2fs_sync_fs() -> write_checkpoint() calls stat_inc_cp_count(sbi->stat_info),
      which needs stat_info allocation.
      Otherwise, we can hit:
      
      [254042.598623]  ? count_shadow_nodes+0xa0/0xa0
      [254042.598633]  f2fs_sync_fs+0x65/0xd0 [f2fs]
      [254042.598645]  f2fs_balance_fs_bg+0xe4/0x1c0 [f2fs]
      [254042.598657]  f2fs_write_node_pages+0x34/0x1a0 [f2fs]
      [254042.598664]  ? pagevec_lookup_entries+0x1e/0x30
      [254042.598673]  do_writepages+0x1e/0x30
      [254042.598682]  __writeback_single_inode+0x45/0x330
      [254042.598688]  writeback_single_inode+0xd7/0x190
      [254042.598694]  write_inode_now+0x86/0xa0
      [254042.598699]  iput+0x122/0x200
      [254042.598709]  f2fs_fill_super+0xd4a/0x14d0 [f2fs]
      [254042.598717]  mount_bdev+0x184/0x1c0
      [254042.598934]  ? f2fs_commit_super+0x100/0x100 [f2fs]
      [254042.599142]  f2fs_mount+0x15/0x20 [f2fs]
      [254042.599349]  mount_fs+0x39/0x160
      [254042.599554]  ? __alloc_percpu+0x15/0x20
      [254042.599759]  vfs_kern_mount+0x67/0x110
      [254042.599972]  do_mount+0x1bb/0xc80
      [254042.600175]  ? memdup_user+0x42/0x60
      [254042.600380]  SyS_mount+0x83/0xd0
      [254042.600583]  entry_SYSCALL_64_fastpath+0x1e/0xad
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      aa51d08a
  4. 28 2月, 2017 4 次提交
  5. 24 2月, 2017 4 次提交
  6. 23 2月, 2017 2 次提交
  7. 08 2月, 2017 1 次提交
  8. 29 1月, 2017 3 次提交
  9. 12 1月, 2017 1 次提交
    • D
      block: Rename blk_queue_zone_size and bdev_zone_size · f99e8648
      Damien Le Moal 提交于
      All block device data fields and functions returning a number of 512B
      sectors are by convention named xxx_sectors while names in the form
      xxx_size are generally used for a number of bytes. The blk_queue_zone_size
      and bdev_zone_size functions were not following this convention so rename
      them.
      
      No functional change is introduced by this patch.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      
      Collapsed the two patches, they were nonsensically split and broke
      bisection.
      Signed-off-by: NJens Axboe <axboe@fb.com>
      f99e8648
  10. 08 1月, 2017 1 次提交
  11. 08 12月, 2016 2 次提交
  12. 06 12月, 2016 1 次提交
  13. 26 11月, 2016 2 次提交
  14. 24 11月, 2016 12 次提交
    • J
      f2fs: remove checkpoint in f2fs_freeze · b4b9d34c
      Jaegeuk Kim 提交于
      The generic freeze_super() calls sync_filesystems() before f2fs_freeze().
      So, basically we don't need to do checkpoint in f2fs_freeze(). But, in xfs/068,
      it triggers circular locking problem below due to gc_mutex for checkpoint.
      
      ======================================================
      [ INFO: possible circular locking dependency detected ]
      4.9.0-rc1+ #132 Tainted: G           OE
      -------------------------------------------------------
      
      1. wait for __sb_start_write() by
      
       [<ffffffff9845f353>] dump_stack+0x85/0xc2
       [<ffffffff980e80bf>] print_circular_bug+0x1cf/0x230
       [<ffffffff980eb4d0>] __lock_acquire+0x19e0/0x1bc0
       [<ffffffff980ebdcb>] lock_acquire+0x11b/0x220
       [<ffffffffc08c7c3b>] ? f2fs_drop_inode+0x9b/0x160 [f2fs]
       [<ffffffff9826bdd0>] __sb_start_write+0x130/0x200
       [<ffffffffc08c7c3b>] ? f2fs_drop_inode+0x9b/0x160 [f2fs]
       [<ffffffffc08c7c3b>] f2fs_drop_inode+0x9b/0x160 [f2fs]
       [<ffffffff98289991>] iput+0x171/0x2c0
       [<ffffffffc08cfccf>] f2fs_sync_inode_meta+0x3f/0xf0 [f2fs]
       [<ffffffffc08cfe04>] block_operations+0x84/0x110 [f2fs]
       [<ffffffffc08cff78>] write_checkpoint+0xe8/0xf20 [f2fs]
       [<ffffffff980e979d>] ? trace_hardirqs_on+0xd/0x10
       [<ffffffffc08c6de9>] ? f2fs_sync_fs+0x79/0x190 [f2fs]
       [<ffffffff9803e9d9>] ? sched_clock+0x9/0x10
       [<ffffffffc08c6de9>] ? f2fs_sync_fs+0x79/0x190 [f2fs]
       [<ffffffffc08c6df5>] f2fs_sync_fs+0x85/0x190 [f2fs]
       [<ffffffff982a4f90>] ? do_fsync+0x70/0x70
       [<ffffffff982a4f90>] ? do_fsync+0x70/0x70
       [<ffffffff982a4fb0>] sync_fs_one_sb+0x20/0x30
       [<ffffffff9826ca3e>] iterate_supers+0xae/0x100
       [<ffffffff982a50b5>] sys_sync+0x55/0x90
       [<ffffffff9890b345>] entry_SYSCALL_64_fastpath+0x23/0xc6
      
      2. wait for sbi->gc_mutex by
      
       [<ffffffff980ebdcb>] lock_acquire+0x11b/0x220
       [<ffffffff989063d6>] mutex_lock_nested+0x76/0x3f0
       [<ffffffffc08c6de9>] f2fs_sync_fs+0x79/0x190 [f2fs]
       [<ffffffffc08c7a6c>] f2fs_freeze+0x1c/0x20 [f2fs]
       [<ffffffff9826b6ef>] freeze_super+0xcf/0x190
       [<ffffffff9827eebc>] do_vfs_ioctl+0x53c/0x6a0
       [<ffffffff9827f099>] SyS_ioctl+0x79/0x90
       [<ffffffff9890b345>] entry_SYSCALL_64_fastpath+0x23/0xc6
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      b4b9d34c
    • D
      f2fs: Cache zoned block devices zone type · 178053e2
      Damien Le Moal 提交于
      With the zoned block device feature enabled, section discard
      need to do a zone reset for sections contained in sequential
      zones, and a regular discard (if supported) for sections
      stored in conventional zones. Avoid the need for a costly
      report zones to obtain a section zone type when discarding it
      by caching the types of the device zones in the super block
      information. This cache is initialized at mount time for mounts
      with the zoned block device feature enabled.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      178053e2
    • D
      f2fs: Do not allow adaptive mode for host-managed zoned block devices · 3adc57e9
      Damien Le Moal 提交于
      The LFS mode is mandatory for host-managed zoned block devices as
      update in place optimizations are not possible for segments in
      sequential zones.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      3adc57e9
    • D
      f2fs: Always enable discard for zoned blocks devices · 96ba2dec
      Damien Le Moal 提交于
      Zone write pointer reset acts as discard for zoned block
      devices. So if the zoned block device feature is enabled,
      always declare that discard is enabled, even if the device
      does not actually support the command.
      For the same reason, prevent the use the "nodicard" mount
      option.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      96ba2dec
    • D
      f2fs: Suppress discard warning message for zoned block devices · 0ab02998
      Damien Le Moal 提交于
      For zoned block devices, discard is replaced by zone reset. So
      do not warn if the device does not supports discard.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      0ab02998
    • D
      f2fs: Check zoned block feature for host-managed zoned block devices · d1b959c8
      Damien Le Moal 提交于
      The F2FS_FEATURE_BLKZONED feature indicates that the drive was formatted
       with zone alignment optimization. This is optional for host-aware
      devices, but mandatory for host-managed zoned block devices.
      So check that the feature is set in this latter case.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      d1b959c8
    • D
      f2fs: Use generic zoned block device terminology · 0bfd7a09
      Damien Le Moal 提交于
      SMR stands for "Shingled Magnetic Recording" which makes sense
      only for hard disk drives (spinning rust). The ZBC/ZAC standards
      enable management of SMR disks, but solid state drives may also
      support those standards. So rename the HMSMR feature to BLKZONED
      to avoid a HDD centric terminology. For the same reason, rename
      f2fs_sb_mounted_hmsmr to f2fs_sb_mounted_blkzoned.
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      0bfd7a09
    • D
      f2fs: Add missing break in switch-case · 487df616
      Damien Le Moal 提交于
      Signed-off-by: NDamien Le Moal <damien.lemoal@wdc.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      487df616
    • J
      f2fs: avoid infinite loop in the EIO case on recover_orphan_inodes · 09922800
      Jaegeuk Kim 提交于
      This patch should fix an infinite loop case below.
      
      F2FS-fs : inject IO error in f2fs_read_end_io+0xf3/0x120 [f2fs]
      F2FS-fs (nvme0n1p1): recover_orphan_inode: orphan failed (ino=39ac1a), run fsck to fix.
      ...
      [<ffffffffc0b11ede>] sync_meta_pages+0xae/0x270 [f2fs]
      [<ffffffffc0b288dd>] ? flush_sit_entries+0x8d/0x960 [f2fs]
      [<ffffffffc0b13801>] write_checkpoint+0x361/0xf20 [f2fs]
      [<ffffffffb40e979d>] ? trace_hardirqs_on+0xd/0x10
      [<ffffffffc0b0a199>] ? f2fs_sync_fs+0x79/0x190 [f2fs]
      [<ffffffffc0b0a1a5>] f2fs_sync_fs+0x85/0x190 [f2fs]
      [<ffffffffc0b2560e>] f2fs_balance_fs_bg+0x7e/0x1c0 [f2fs]
      [<ffffffffc0b216c4>] f2fs_write_node_pages+0x34/0x320 [f2fs]
      [<ffffffffb41dff21>] do_writepages+0x21/0x30
      [<ffffffffb429edb1>] __writeback_single_inode+0x61/0x760
      [<ffffffffb490a937>] ? _raw_spin_unlock+0x27/0x40
      [<ffffffffb42a0805>] writeback_single_inode+0xd5/0x190
      [<ffffffffb42a0959>] write_inode_now+0x99/0xc0
      [<ffffffffb4289a16>] iput+0x1f6/0x2c0
      [<ffffffffc0b0e3be>] f2fs_fill_super+0xe0e/0x1300 [f2fs]
      [<ffffffffb426c394>] ? sget_userns+0x4f4/0x530
      [<ffffffffb426c692>] mount_bdev+0x182/0x1b0
      [<ffffffffc0b0d5b0>] ? f2fs_commit_super+0x100/0x100 [f2fs]
      [<ffffffffc0b0a375>] f2fs_mount+0x15/0x20 [f2fs]
      [<ffffffffb426d038>] mount_fs+0x38/0x170
      [<ffffffffb428ec9b>] vfs_kern_mount+0x6b/0x160
      [<ffffffffb4291d9e>] do_mount+0x1be/0xd60
      [<ffffffffb4291a57>] ? copy_mount_options+0xb7/0x220
      [<ffffffffb4292c54>] SyS_mount+0x94/0xd0
      [<ffffffffb490b345>] entry_SYSCALL_64_fastpath+0x23/0xc6
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      09922800
    • J
      f2fs: remove percpu_count due to performance regression · 35782b23
      Jaegeuk Kim 提交于
      This patch removes percpu_count usage due to performance regression in iozone.
      
      Fixes: 523be8a6 ("f2fs: use percpu_counter for page counters")
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      35782b23
    • J
      f2fs: keep dirty inodes selectively for checkpoint · 7c45729a
      Jaegeuk Kim 提交于
      This is to avoid no free segment bug during checkpoint caused by a number of
      dirty inodes.
      
      The case was reported by Chao like this.
      1. mount with lazytime option
      2. fill 4k file until disk is full
      3. sync filesystem
      4. read all files in the image
      5. umount
      
      In this case, we actually don't need to flush dirty inode to inode page during
      checkpoint.
      Reviewed-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      7c45729a
    • C
      f2fs: fix to release discard entries during checkpoint · 2dd15654
      Chao Yu 提交于
      In f2fs_fill_super, if there is any IO error occurs during recovery,
      cached discard entries will be leaked, in order to avoid this, make
      write_checkpoint() handle memory release by itself, besides, move
      clear_prefree_segments to write_checkpoint for readability.
      Signed-off-by: NChao Yu <yuchao0@huawei.com>
      Signed-off-by: NJaegeuk Kim <jaegeuk@kernel.org>
      2dd15654
  15. 01 11月, 2016 1 次提交
  16. 01 10月, 2016 2 次提交