diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2020-01-28 14:53:31 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2020-01-28 14:53:31 -0800 | 
| commit | 81a046b18b331ed6192e6fd9ff6d12a1f18058cf (patch) | |
| tree | 1d20ebe76c82cc2be603a0a4836d08ba9ec63ee0 /fs/btrfs/tests/btrfs-tests.c | |
| parent | 511fdb78442229ac11057b4a55c3f03c253c062f (diff) | |
| parent | 4e19443da1941050b346f8fc4c368aa68413bc88 (diff) | |
Merge tag 'for-5.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux
Pull btrfs updates from David Sterba:
 "Features, highlights:
   - async discard
       - "mount -o discard=async" to enable it
       - freed extents are not discarded immediatelly, but grouped
         together and trimmed later, with IO rate limiting
       - the "sync" mode submits short extents that could have been
         ignored completely by the device, for SATA prior to 3.1 the
         requests are unqueued and have a big impact on performance
       - the actual discard IO requests have been moved out of
         transaction commit to a worker thread, improving commit latency
       - IO rate and request size can be tuned by sysfs files, for now
         enabled only with CONFIG_BTRFS_DEBUG as we might need to
         add/delete the files and don't have a stable-ish ABI for
         general use, defaults are conservative
   - export device state info in sysfs, eg. missing, writeable
   - no discard of extents known to be untouched on disk (eg. after
     reservation)
   - device stats reset is logged with process name and PID that called
     the ioctl
  Fixes:
   - fix missing hole after hole punching and fsync when using NO_HOLES
   - writeback: range cyclic mode could miss some dirty pages and lead
     to OOM
   - two more corner cases for metadata_uuid change after power loss
     during the change
   - fix infinite loop during fsync after mix of rename operations
  Core changes:
   - qgroup assign returns ENOTCONN when quotas not enabled, used to
     return EINVAL that was confusing
   - device closing does not need to allocate memory anymore
   - snapshot aware code got removed, disabled for years due to
     performance problems, reimplmentation will allow to select wheter
     defrag breaks or does not break COW on shared extents
   - tree-checker:
       - check leaf chunk item size, cross check against number of
         stripes
       - verify location keys for DIR_ITEM, DIR_INDEX and XATTR items
   - new self test for physical -> logical mapping code, used for super
     block range exclusion
   - assertion helpers/macros updated to avoid objtool "unreachable
     code" reports on older compilers or config option combinations"
* tag 'for-5.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux: (84 commits)
  btrfs: free block groups after free'ing fs trees
  btrfs: Fix split-brain handling when changing FSID to metadata uuid
  btrfs: Handle another split brain scenario with metadata uuid feature
  btrfs: Factor out metadata_uuid code from find_fsid.
  btrfs: Call find_fsid from find_fsid_inprogress
  Btrfs: fix infinite loop during fsync after rename operations
  btrfs: set trans->drity in btrfs_commit_transaction
  btrfs: drop log root for dropped roots
  btrfs: sysfs, add devid/dev_state kobject and device attributes
  btrfs: Refactor btrfs_rmap_block to improve readability
  btrfs: Add self-tests for btrfs_rmap_block
  btrfs: selftests: Add support for dummy devices
  btrfs: Move and unexport btrfs_rmap_block
  btrfs: separate definition of assertion failure handlers
  btrfs: device stats, log when stats are zeroed
  btrfs: fix improper setting of scanned for range cyclic write cache pages
  btrfs: safely advance counter when looking up bio csums
  btrfs: remove unused member btrfs_device::work
  btrfs: remove unnecessary wrapper get_alloc_profile
  btrfs: add correction to handle -1 edge case in async discard
  ...
Diffstat (limited to 'fs/btrfs/tests/btrfs-tests.c')
| -rw-r--r-- | fs/btrfs/tests/btrfs-tests.c | 29 | 
1 files changed, 29 insertions, 0 deletions
| diff --git a/fs/btrfs/tests/btrfs-tests.c b/fs/btrfs/tests/btrfs-tests.c index a7aca4141788..c12b91ff5f56 100644 --- a/fs/btrfs/tests/btrfs-tests.c +++ b/fs/btrfs/tests/btrfs-tests.c @@ -86,6 +86,27 @@ static void btrfs_destroy_test_fs(void)  	unregister_filesystem(&test_type);  } +struct btrfs_device *btrfs_alloc_dummy_device(struct btrfs_fs_info *fs_info) +{ +	struct btrfs_device *dev; + +	dev = kzalloc(sizeof(*dev), GFP_KERNEL); +	if (!dev) +		return ERR_PTR(-ENOMEM); + +	extent_io_tree_init(NULL, &dev->alloc_state, 0, NULL); +	INIT_LIST_HEAD(&dev->dev_list); +	list_add(&dev->dev_list, &fs_info->fs_devices->devices); + +	return dev; +} + +static void btrfs_free_dummy_device(struct btrfs_device *dev) +{ +	extent_io_tree_release(&dev->alloc_state); +	kfree(dev); +} +  struct btrfs_fs_info *btrfs_alloc_dummy_fs_info(u32 nodesize, u32 sectorsize)  {  	struct btrfs_fs_info *fs_info = kzalloc(sizeof(struct btrfs_fs_info), @@ -132,12 +153,14 @@ struct btrfs_fs_info *btrfs_alloc_dummy_fs_info(u32 nodesize, u32 sectorsize)  	INIT_LIST_HEAD(&fs_info->dirty_qgroups);  	INIT_LIST_HEAD(&fs_info->dead_roots);  	INIT_LIST_HEAD(&fs_info->tree_mod_seq_list); +	INIT_LIST_HEAD(&fs_info->fs_devices->devices);  	INIT_RADIX_TREE(&fs_info->buffer_radix, GFP_ATOMIC);  	INIT_RADIX_TREE(&fs_info->fs_roots_radix, GFP_ATOMIC);  	extent_io_tree_init(fs_info, &fs_info->freed_extents[0],  			    IO_TREE_FS_INFO_FREED_EXTENTS0, NULL);  	extent_io_tree_init(fs_info, &fs_info->freed_extents[1],  			    IO_TREE_FS_INFO_FREED_EXTENTS1, NULL); +	extent_map_tree_init(&fs_info->mapping_tree);  	fs_info->pinned_extents = &fs_info->freed_extents[0];  	set_bit(BTRFS_FS_STATE_DUMMY_FS_INFO, &fs_info->fs_state); @@ -150,6 +173,7 @@ void btrfs_free_dummy_fs_info(struct btrfs_fs_info *fs_info)  {  	struct radix_tree_iter iter;  	void **slot; +	struct btrfs_device *dev, *tmp;  	if (!fs_info)  		return; @@ -180,6 +204,11 @@ void btrfs_free_dummy_fs_info(struct btrfs_fs_info *fs_info)  	}  	spin_unlock(&fs_info->buffer_lock); +	btrfs_mapping_tree_free(&fs_info->mapping_tree); +	list_for_each_entry_safe(dev, tmp, &fs_info->fs_devices->devices, +				 dev_list) { +		btrfs_free_dummy_device(dev); +	}  	btrfs_free_qgroup_config(fs_info);  	btrfs_free_fs_roots(fs_info);  	cleanup_srcu_struct(&fs_info->subvol_srcu); | 
