[PATCH v3 0/4] xfs: fix AIL push use-after-free during shutdown
From: Yuto Ohnuki
Date: Sun Mar 08 2026 - 14:28:32 EST
When a filesystem is shut down, background inode reclaim and the xfsaild
can race to abort and free dirty inodes. Since commit 90c60e164012
("xfs: xfs_iflush() is no longer necessary"), xfs_inode_item_push() no
longer holds ILOCK_SHARED while flushing, removing the protection that
prevented the inode from being reclaimed during the flush.
This results in use-after-free when dereferencing log items after
iop_push() returns, or when reacquiring the AIL lock via lip->li_ailp.
This series fixes the issue by:
1. Reordering unmount to stop reclaim before pushing the AIL
2. Factoring the push loop into a helper for readability
3. Capturing log item fields before push callbacks for tracepoints
4. Saving the ailp pointer before dropping the AIL lock
Changes in v3:
- Split into 4 patches as suggested by Dave Chinner
- Moved UAF-unsafe point comments to after xfs_buf_relse()
- Passed ailp instead of dev to tracepoints
- Moved xfs_ail_push_class definition after xfs_log_item_class events
- Factored xfsaild_push() loop body into xfsaild_process_logitem()
- Added xfsaild_push_item() header comment describing post-return lifetime
- Link to v2: https://lore.kernel.org/all/20260305185836.56478-2-ytohnuki@xxxxxxxxxx/
Changes in v2:
- Reordered xfs_unmount_flush_inodes() to stop reclaim before pushing
AIL suggested by Dave Chinner
- Introduced xfs_ail_push_class trace event to avoid dereferencing
freed log items in tracepoints
- Added comments documenting that log items must not be referenced
after iop_push() returns
- Saved ailp pointer in local variables in push functions
- Link to v1: https://lore.kernel.org/all/20260304162405.58017-2-ytohnuki@xxxxxxxxxx/
Yuto Ohnuki (4):
xfs: stop reclaim before pushing AIL during unmount
xfs: refactor xfsaild_push loop into helper
xfs: avoid dereferencing log items after push callbacks
xfs: save ailp before dropping the AIL lock in push callbacks
fs/xfs/xfs_dquot_item.c | 9 ++-
fs/xfs/xfs_inode_item.c | 9 ++-
fs/xfs/xfs_mount.c | 4 +-
fs/xfs/xfs_trace.h | 36 ++++++++++--
fs/xfs/xfs_trans_ail.c | 124 +++++++++++++++++++++++-----------------
5 files changed, 120 insertions(+), 62 deletions(-)
--
2.50.1
Amazon Web Services EMEA SARL, 38 avenue John F. Kennedy, L-1855 Luxembourg, R.C.S. Luxembourg B186284
Amazon Web Services EMEA SARL, Irish Branch, One Burlington Plaza, Burlington Road, Dublin 4, Ireland, branch registration number 908705