mirror of
https://github.com/lkl/linux.git
synced 2025-12-19 08:03:01 +09:00
Merge tag 'for-6.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux
Pull btrfs updates from David Sterba:
"No new features, the bulk of the changes are fixes, refactoring and
cleanups. The notable fix is the scrub performance restoration after
rewrite in 6.4, though still only partial.
Fixes:
- scrub performance drop due to rewrite in 6.4 partially restored:
- do IO grouping by blg_plug/blk_unplug again
- avoid unnecessary tree searches when processing stripes, in
extent and checksum trees
- the drop is noticeable on fast PCIe devices, -66% and restored
to -33% of the original
- backports to 6.4 planned
- handle more corner cases of transaction commit during orphan
cleanup or delayed ref processing
- use correct fsid/metadata_uuid when validating super block
- copy directory permissions and time when creating a stub subvolume
Core:
- debugging feature integrity checker deprecated, to be removed in
6.7
- in zoned mode, zones are activated just before the write, making
error handling easier, now the overcommit mechanism can be enabled
again which improves performance by avoiding more frequent flushing
- v0 extent handling completely removed, deprecated long time ago
- error handling improvements
- tests:
- extent buffer bitmap tests
- pinned extent splitting tests
- cleanups and refactoring:
- compression writeback
- extent buffer bitmap
- space flushing, ENOSPC handling"
* tag 'for-6.6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux: (110 commits)
btrfs: zoned: skip splitting and logical rewriting on pre-alloc write
btrfs: tests: test invalid splitting when skipping pinned drop extent_map
btrfs: tests: add a test for btrfs_add_extent_mapping
btrfs: tests: add extent_map tests for dropping with odd layouts
btrfs: scrub: move write back of repaired sectors to scrub_stripe_read_repair_worker()
btrfs: scrub: don't go ordered workqueue for dev-replace
btrfs: scrub: fix grouping of read IO
btrfs: scrub: avoid unnecessary csum tree search preparing stripes
btrfs: scrub: avoid unnecessary extent tree search preparing stripes
btrfs: copy dir permission and time when creating a stub subvolume
btrfs: remove pointless empty list check when reading delayed dir indexes
btrfs: drop redundant check to use fs_devices::metadata_uuid
btrfs: compare the correct fsid/metadata_uuid in btrfs_validate_super
btrfs: use the correct superblock to compare fsid in btrfs_validate_super
btrfs: simplify memcpy either of metadata_uuid or fsid
btrfs: add a helper to read the superblock metadata_uuid
btrfs: remove v0 extent handling
btrfs: output extra debug info if we failed to find an inline backref
btrfs: move the !zoned assert into run_delalloc_cow
btrfs: consolidate the error handling in run_delalloc_nocow
...
This commit is contained in:
@@ -38,7 +38,6 @@ struct find_free_extent_ctl;
|
||||
__print_symbolic(type, \
|
||||
{ BTRFS_TREE_BLOCK_REF_KEY, "TREE_BLOCK_REF" }, \
|
||||
{ BTRFS_EXTENT_DATA_REF_KEY, "EXTENT_DATA_REF" }, \
|
||||
{ BTRFS_EXTENT_REF_V0_KEY, "EXTENT_REF_V0" }, \
|
||||
{ BTRFS_SHARED_BLOCK_REF_KEY, "SHARED_BLOCK_REF" }, \
|
||||
{ BTRFS_SHARED_DATA_REF_KEY, "SHARED_DATA_REF" })
|
||||
|
||||
@@ -2482,7 +2481,7 @@ DECLARE_EVENT_CLASS(btrfs_raid56_bio,
|
||||
__entry->offset, __entry->opf, __entry->physical, __entry->len)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_read_partial,
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_read,
|
||||
TP_PROTO(const struct btrfs_raid_bio *rbio,
|
||||
const struct bio *bio,
|
||||
const struct raid56_bio_trace_info *trace_info),
|
||||
@@ -2490,32 +2489,7 @@ DEFINE_EVENT(btrfs_raid56_bio, raid56_read_partial,
|
||||
TP_ARGS(rbio, bio, trace_info)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_write_stripe,
|
||||
TP_PROTO(const struct btrfs_raid_bio *rbio,
|
||||
const struct bio *bio,
|
||||
const struct raid56_bio_trace_info *trace_info),
|
||||
|
||||
TP_ARGS(rbio, bio, trace_info)
|
||||
);
|
||||
|
||||
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_scrub_write_stripe,
|
||||
TP_PROTO(const struct btrfs_raid_bio *rbio,
|
||||
const struct bio *bio,
|
||||
const struct raid56_bio_trace_info *trace_info),
|
||||
|
||||
TP_ARGS(rbio, bio, trace_info)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_scrub_read,
|
||||
TP_PROTO(const struct btrfs_raid_bio *rbio,
|
||||
const struct bio *bio,
|
||||
const struct raid56_bio_trace_info *trace_info),
|
||||
|
||||
TP_ARGS(rbio, bio, trace_info)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_scrub_read_recover,
|
||||
DEFINE_EVENT(btrfs_raid56_bio, raid56_write,
|
||||
TP_PROTO(const struct btrfs_raid_bio *rbio,
|
||||
const struct bio *bio,
|
||||
const struct raid56_bio_trace_info *trace_info),
|
||||
|
||||
Reference in New Issue
Block a user