From: David Sterba <dsterba@suse.com>
To: torvalds@linux-foundation.org
Cc: David Sterba <dsterba@suse.com>,
linux-btrfs@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: [GIT PULL] Btrfs updates for 7.1
Date: Fri, 10 Apr 2026 03:15:45 +0200 [thread overview]
Message-ID: <cover.1775782425.git.dsterba@suse.com> (raw)
Hi,
please pull the following btrfs updates. Thanks.
User visible changes:
- move shutdown ioctl support out of experimental features, a forced stop
of filesystem operation until the next unmount; additionally there's a
super block operation to forcibly remove a device from under the
filesystem that could lead to a shutdown or not if the redundancy allows
that
- report filesystem shutdown using fserror mechanism
- tree-checker updates:
- verify free space info, extent and bitmap items
- verify remap-tree items and related data in block group items
Performance improvements:
- speed up clearing first extent in the tracked range (+10% throughput on
sample workload)
- reduce COW rewrites of extent buffers during the same transaction
- avoid taking big device lock to update device stats during transaction
commit
- fix unnecessary flush on close when truncating empty files (observed
in practice on a backup application)
- prevent direct reclaim during compressed readahead to avoid stalls
under memory pressure
Notable fixes:
- fix chunk allocation strategy on RAID1-like block groups with
disproportionate device sizes, this could lead to ENOSPC due to skewed
reservation estimates
- adjust metadata reservation overcommit ratio to be less aggressive and
also try to flush if possible, this avoids ENOSPC and potential
transaction aborts in some edge cases (that are otherwise hard to
reproduce)
- fix silent IO error in encoded writes and ordered extent split in zoned
mode, the error was not correctly propagated to the address space and
could lead to zeroed ranges
- don't mark inline files NOCOMPRESS unexpectedly, the intent was to do
that for single block writes of regular files
- fix deadlock between reflink and transaction commit when using
flushoncommit
- fix overly strict item check of a running dev-replace operation
Core:
- zoned mode space reservation fixes:
- cap delayed refs metadata reservation to avoid overcommit
- update logic to reclaim partially unusable zones
- add another state to flush and reclaim partially used zone
- limit number of zones reclaimed in one go to avoid blocking other
operations
- don't let log trees consume global reserve on overcommit and fall back
to transaction commit
- revalidate extent buffer when checking its up-to-date status
- add self tests for zoned mode block group specifics
- reduce atomic allocations in some qgroup paths
- avoid unnecessary root node COW during snapshotting
- start new transaction in block group relocation conditionally
- faster check of NOCOW files on currently snapshotted root
- change how compressed bio size is tracked from bio and reduce the
structure size
- new tracepoint for search slot restart tracking
- checksum list manipulation improvements
- type, parameter cleanups, refactoring
- error handling improvements, transaction abort call adjustments
----------------------------------------------------------------
The following changes since commit 591cd656a1bf5ea94a222af5ef2ee76df029c1d2:
Linux 7.0-rc7 (2026-04-05 15:26:23 -0700)
are available in the Git repository at:
git://git.kernel.org/pub/scm/linux/kernel/git/kdave/linux.git tags/for-7.1-tag
for you to fetch changes up to fc3d53288158d68444eed059adb734709b855bbf:
btrfs: btrfs_log_dev_io_error() on all bio errors (2026-04-07 20:00:29 +0200)
----------------------------------------------------------------
Alexey Velichayshiy (1):
btrfs: remove redundant nowait check in lock_extent_direct()
Boris Burkov (1):
btrfs: btrfs_log_dev_io_error() on all bio errors
Chen Guan Jie (1):
btrfs: check snapshot_force_cow earlier in can_nocow_file_extent()
Chen Ni (1):
btrfs: remove duplicate include of delayed-inode.h in disk-io.c
Dave Chen (3):
btrfs: fix unnecessary flush on close when truncating zero-sized files
btrfs: use BTRFS_FS_UPDATE_UUID_TREE_GEN flag for UUID tree rescan check
btrfs: skip clearing EXTENT_DEFRAG for NOCOW ordered extents
David Sterba (9):
btrfs: remove duplicate calculation of eb offset in btrfs_bin_search()
btrfs: unify types for binary search variables
btrfs: rename local variable for offset in folio
btrfs: read eb folio index right before loops
btrfs: use common eb range validation in read_extent_buffer_to_user_nofault()
btrfs: lzo: inline read/write length helpers
btrfs: zlib: drop redundant folio address variable
btrfs: zlib: don't cache sectorsize in a local variable
btrfs: zstd: don't cache sectorsize in a local variable
Filipe Manana (46):
btrfs: pass boolean literals as the last argument to inc_block_group_ro()
btrfs: remove duplicate system chunk array max size overflow check
btrfs: move min sys chunk array size check to validate_sys_chunk_array()
btrfs: be less aggressive with metadata overcommit when we can do full flushing
btrfs: don't allow log trees to consume global reserve or overcommit metadata
btrfs: update comment for BTRFS_RESERVE_NO_FLUSH
btrfs: mark all error and warning checks as unlikely in btrfs_validate_super()
btrfs: pass transaction handle to write_all_supers()
btrfs: abort transaction on error in write_all_supers()
btrfs: tag error branches as unlikely during super block writes
btrfs: remove max_mirrors argument from write_all_supers()
btrfs: set written super flag once in write_all_supers()
btrfs: remove duplicated eb uptodate check in btrfs_buffer_uptodate()
btrfs: use the helper extent_buffer_uptodate() everywhere
btrfs: remove redundant extent_buffer_uptodate() checks after read_tree_block()
btrfs: avoid starting new transaction and commit in relocate_block_group()
btrfs: remove pointless out label in qgroup_account_snapshot()
btrfs: pass literal booleans to functions that take boolean arguments
btrfs: remove bogus root search condition in load_extent_tree_free()
btrfs: avoid unnecessary root node COW during snapshotting
btrfs: constify arguments of some functions
btrfs: stop printing condition result in assertion failure messages
btrfs: pass a btrfs inode to tree-log.c:fill_inode_item()
btrfs: stop checking for -EEXIST return value from btrfs_uuid_tree_add()
btrfs: remove duplicated uuid tree existence check in btrfs_uuid_tree_add()
btrfs: remove pointless error check in btrfs_check_dir_item_collision()
btrfs: optimize clearing all bits from the last extent record in an io tree
btrfs: turn extent_io_tree_panic() into a macro for better error reporting
btrfs: tag as unlikely branches that call extent_io_tree_panic()
btrfs: make add_extent_changeset() only return errors or success
btrfs: use extent_io_tree_panic() instead of BUG_ON()
btrfs: change last argument of add_extent_changeset() to boolean
btrfs: remove wake parameter from clear_state_bit()
btrfs: avoid unnecessary wake ups on io trees when there are no waiters
btrfs: free cached state outside critical section in wait_extent_bit()
btrfs: panic instead of warn when splitting extent state not in the tree
btrfs: optimize clearing all bits from first extent record in an io tree
btrfs: remove unused qgroup functions for pertrans reservation and freeing
btrfs: collapse __btrfs_qgroup_free_meta() into btrfs_qgroup_free_meta_prealloc()
btrfs: collapse __btrfs_qgroup_reserve_meta() into btrfs_qgroup_reserve_meta_prealloc()
btrfs: unexport btrfs_qgroup_reserve_meta()
btrfs: avoid taking the device_list_mutex in btrfs_run_dev_stats()
btrfs: fix deadlock between reflink and transaction commit when using flushoncommit
btrfs: make btrfs_free_log() and btrfs_free_log_root_tree() return void
btrfs: tag as unlikely if statements that check for fs in error state
btrfs: remove duplicate journal_info reset on failure to commit transaction
Guangshuo Li (2):
btrfs: fix double free in create_space_info_sub_group() error path
btrfs: fix double free in create_space_info() error path
JP Kobryn (Meta) (1):
btrfs: prevent direct reclaim during compressed readahead
Jiasheng Jiang (1):
btrfs: zoned: remove redundant space_info lock and variable in do_allocation_zoned()
Johannes Thumshirn (8):
btrfs: zoned: cap delayed refs metadata reservation to avoid overcommit
btrfs: zoned: move partially zone_unusable block groups to reclaim list
btrfs: zoned: add zone reclaim flush state for DATA space_info
btrfs: change return type of cache_save_setup to void
btrfs: move reclaiming of a single block group into its own function
btrfs: create btrfs_reclaim_block_groups()
btrfs: zoned: limit number of zones reclaimed in flush_space()
btrfs: decrease indentation of find_free_extent_update_loop
Leo Martins (3):
btrfs: inhibit extent buffer writeback to prevent COW amplification
btrfs: add tracepoint for search slot restart tracking
btrfs: avoid GFP_ATOMIC allocations in qgroup free paths
Mark Harmstone (4):
btrfs: fix placement of unlikely() in btrfs_insert_one_raid_extent()
btrfs: tree-checker: add checker for items in remap tree
btrfs: tree-checker: check remap-tree flags in btrfs_check_chunk_valid()
btrfs: tree-checker: add remap-tree checks to check_block_group_item()
Michal Grzedzicki (1):
btrfs: fix silent IO error loss in encoded writes and zoned split
Miquel Sabaté Solà (2):
btrfs: replace kcalloc() calls to kzalloc_objs()
btrfs: report filesystem shutdown via fserror
Naohiro Aota (1):
btrfs: tests: zoned: add tests cases for zoned code
Philipp Hahn (1):
btrfs: prefer IS_ERR_OR_NULL() over manual NULL check
Qu Wenruo (26):
btrfs: introduce the device layout aware per-profile available space
btrfs: update per-profile available estimation
btrfs: use per-profile available space in calc_available_free_space()
btrfs: fix the inline compressed extent check in inode_need_compress()
btrfs: rename btrfs_ordered_extent::list to csum_list
btrfs: make add_pending_csums() to take an ordered extent as parameter
btrfs: rename btrfs_csum_file_blocks() to btrfs_insert_data_csums()
btrfs: remove out-of-date comments in btree_writepages()
btrfs: remove the btrfs_inode parameter from btrfs_remove_ordered_extent()
btrfs: remove folio parameter from ordered io related functions
btrfs: do not mark inode incompressible after inline attempt fails
btrfs: introduce a common helper to calculate the size of a bio
btrfs: reduce the size of compressed_bio
btrfs: do compressed bio size roundup and zeroing in one go
btrfs: extract the max compression chunk size into a macro
btrfs: remove the alignment check in end_bbio_data_write()
btrfs: move the mapping_set_error() out of the loop in end_bbio_data_write()
btrfs: extract inlined creation into a dedicated delalloc helper
btrfs: tree-checker: introduce checks for FREE_SPACE_INFO
btrfs: tree-checker: introduce checks for FREE_SPACE_EXTENT
btrfs: check type flags in alloc_ordered_extent()
btrfs: output more info when duplicated ordered extent is found
btrfs: remove atomic parameter from btrfs_buffer_uptodate()
btrfs: move shutdown and remove_bdev callbacks out of experimental features
btrfs: only invalidate btree inode pages after all ebs are released
btrfs: do not reject a valid running dev-replace
Teng Liu (1):
btrfs: replace BUG_ON() with error return in cache_save_setup()
Yochai Eisenrich (1):
btrfs: fix btrfs_ioctl_space_info() slot_count TOCTOU which can lead to info-leak
ZhengYuan Huang (2):
btrfs: tree-checker: introduce checks for FREE_SPACE_BITMAP
btrfs: revalidate cached tree blocks on the uptodate path
fs/btrfs/Kconfig | 2 -
fs/btrfs/Makefile | 4 +
fs/btrfs/backref.c | 10 -
fs/btrfs/bio.c | 12 +-
fs/btrfs/block-group.c | 335 +++++++++++---------
fs/btrfs/block-group.h | 1 +
fs/btrfs/block-rsv.c | 25 ++
fs/btrfs/compression.c | 45 ++-
fs/btrfs/compression.h | 8 +-
fs/btrfs/ctree.c | 47 +--
fs/btrfs/delayed-inode.c | 3 +-
fs/btrfs/delayed-ref.c | 28 ++
fs/btrfs/dev-replace.c | 4 +-
fs/btrfs/dir-item.c | 4 +-
fs/btrfs/direct-io.c | 11 +-
fs/btrfs/disk-io.c | 247 +++++++--------
fs/btrfs/disk-io.h | 7 +-
fs/btrfs/extent-io-tree.c | 184 ++++++++---
fs/btrfs/extent-tree.c | 119 ++++---
fs/btrfs/extent_io.c | 186 +++++++----
fs/btrfs/extent_io.h | 31 +-
fs/btrfs/file-item.c | 6 +-
fs/btrfs/file-item.h | 6 +-
fs/btrfs/file.c | 6 +-
fs/btrfs/fs.h | 9 +-
fs/btrfs/inode.c | 316 ++++++++++---------
fs/btrfs/ioctl.c | 9 +-
fs/btrfs/lzo.c | 41 +--
fs/btrfs/messages.c | 2 +-
fs/btrfs/messages.h | 8 +-
fs/btrfs/misc.h | 18 +-
fs/btrfs/ordered-data.c | 69 ++--
fs/btrfs/ordered-data.h | 66 ++--
fs/btrfs/print-tree.c | 4 -
fs/btrfs/qgroup.c | 42 ++-
fs/btrfs/qgroup.h | 42 +--
fs/btrfs/raid-stripe-tree.c | 2 +-
fs/btrfs/raid56.c | 17 +-
fs/btrfs/reflink.c | 49 ++-
fs/btrfs/relocation.c | 12 +-
fs/btrfs/scrub.c | 24 +-
fs/btrfs/send.c | 6 +-
fs/btrfs/space-info.c | 69 ++--
fs/btrfs/space-info.h | 22 +-
fs/btrfs/super.c | 6 +-
fs/btrfs/super.h | 2 +-
fs/btrfs/tests/btrfs-tests.c | 3 +
fs/btrfs/tests/btrfs-tests.h | 10 +
fs/btrfs/tests/zoned-tests.c | 675 ++++++++++++++++++++++++++++++++++++++++
fs/btrfs/transaction.c | 90 +++---
fs/btrfs/transaction.h | 3 +
fs/btrfs/tree-checker.c | 247 +++++++++++++++
fs/btrfs/tree-log.c | 75 +++--
fs/btrfs/tree-log.h | 5 +-
fs/btrfs/tree-mod-log.c | 8 +-
fs/btrfs/uuid-tree.c | 7 +-
fs/btrfs/volumes.c | 225 +++++++++++++-
fs/btrfs/volumes.h | 34 ++
fs/btrfs/zlib.c | 26 +-
fs/btrfs/zoned.c | 17 +-
fs/btrfs/zstd.c | 20 +-
include/trace/events/btrfs.h | 24 ++
include/uapi/linux/btrfs_tree.h | 3 +-
63 files changed, 2559 insertions(+), 1079 deletions(-)
create mode 100644 fs/btrfs/tests/zoned-tests.c
reply other threads:[~2026-04-10 1:15 UTC|newest]
Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=cover.1775782425.git.dsterba@suse.com \
--to=dsterba@suse.com \
--cc=linux-btrfs@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@linux-foundation.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox