1. 23 Apr, 2024 6 commits
  2. 22 Apr, 2024 22 commits
  3. 20 Apr, 2024 1 commit
    • Dave Chinner's avatar
      xfs: fix CIL sparse lock context warnings · 2c03d956
      Dave Chinner authored
      Sparse reports:
      
      fs/xfs/xfs_log_cil.c:1127:1: warning: context imbalance in 'xlog_cil_push_work' - different lock contexts for basic block
      fs/xfs/xfs_log_cil.c:1380:1: warning: context imbalance in 'xlog_cil_push_background' - wrong count at exit
      fs/xfs/xfs_log_cil.c:1623:9: warning: context imbalance in 'xlog_cil_commit' - unexpected unlock
      
      xlog_cil_push_background() has a locking annotations for an rw_sem.
      Sparse does not track lock contexts for rw_sems, so the
      annotation generates false warnings. Remove the annotation.
      
      xlog_wait_on_iclog() drops the log->l_ic_loglock. The function has a
      sparse annotation, but the prototype in xfs_log_priv.h does not.
      Hence the warning from xlog_cil_push_work() which calls
      xlog_wait_on_iclog(). Add the missing annotation.
      Signed-off-by: default avatarDave Chinner <dchinner@redhat.com>
      Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      2c03d956
  4. 16 Apr, 2024 11 commits
    • Chandan Babu R's avatar
      Merge tag 'retain-ilock-during-dir-ops-6.10_2024-04-15' of... · 9cb5f15d
      Chandan Babu R authored
      Merge tag 'retain-ilock-during-dir-ops-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: retain ILOCK during directory updates
      
      This series changes the directory update code to retain the ILOCK on all
      files involved in a rename until the end of the operation.  The upcoming
      parent pointers patchset applies parent pointers in a separate chained
      update from the actual directory update, which is why it is now
      necessary to keep the ILOCK instead of dropping it after the first
      transaction in the chain.
      
      As a side effect, we no longer need to hold the IOLOCK during an rmapbt
      scan of inodes to serialize the scan with ongoing directory updates.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'retain-ilock-during-dir-ops-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: unlock new repair tempfiles after creation
        xfs: don't pick up IOLOCK during rmapbt repair scan
        xfs: Hold inode locks in xfs_rename
        xfs: Hold inode locks in xfs_trans_alloc_dir
        xfs: Hold inode locks in xfs_ialloc
        xfs: Increase XFS_QM_TRANS_MAXDQS to 5
        xfs: Increase XFS_DEFER_OPS_NR_INODES to 5
      9cb5f15d
    • Chandan Babu R's avatar
      Merge tag 'online-fsck-design-6.10_2024-04-15' of... · f910defd
      Chandan Babu R authored
      Merge tag 'online-fsck-design-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: design documentation for online fsck, part 2
      
      This series updates the design documentation for online fsck to reflect
      the final design of the parent pointers feature as well as the
      implementation of online fsck for the new metadata.
      
      This has been running on the djcloud for months with no problems.  Enjoy!
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'online-fsck-design-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        docs: describe xfs directory tree online fsck
        docs: update offline parent pointer repair strategy
        docs: update online directory and parent pointer repair sections
        docs: update the parent pointers documentation to the final version
      f910defd
    • Chandan Babu R's avatar
      Merge tag 'discard-relax-locks-6.10_2024-04-15' of... · 6ad1b914
      Chandan Babu R authored
      Merge tag 'discard-relax-locks-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: less heavy locks during fstrim
      
      Congratulations!  You have made it to the final patchset of the main
      online fsck feature!  This patchset fixes some stalling behavior that I
      observed when running FITRIM against large flash-based filesystems with
      very heavily fragmented free space data.  In summary -- the current
      fstrim implementation optimizes for trimming the largest free extents
      first, and holds the AGF lock for the duration of the operation.  This
      is great if fstrim is being run as a foreground process by a sysadmin.
      
      For xfs_scrub, however, this isn't so good -- we don't really want to
      block on one huge kernel call while reporting no progress information.
      We don't want to hold the AGF so long that background processes stall.
      These problems are easily fixable by issuing smaller FITRIM calls, but
      there's still the problem of walking the entire cntbt.  To solve that
      second problem, we introduce a new sub-AG FITRIM implementation.  To
      solve the first problem, make it relax the AGF periodically.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'discard-relax-locks-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: fix performance problems when fstrimming a subset of a fragmented AG
      6ad1b914
    • Chandan Babu R's avatar
      Merge tag 'inode-repair-improvements-6.10_2024-04-15' of... · 9ba8e658
      Chandan Babu R authored
      Merge tag 'inode-repair-improvements-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: inode-related repair fixes
      
      While doing QA of the online fsck code, I made a few observations:
      First, nobody was checking that the di_onlink field is actually zero;
      Second, that allocating a temporary file for repairs can fail (and
      thus bring down the entire fs) if the inode cluster is corrupt; and
      Third, that file link counts do not pin at ~0U to prevent integer
      overflows.  Fourth, the x{chk,rep}_metadata_inode_fork functions
      should be subclassing the main scrub context, not modifying the
      parent's setup willy-nilly.
      
      This scattered patchset fixes those three problems.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'inode-repair-improvements-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: create subordinate scrub contexts for xchk_metadata_inode_subtype
        xfs: pin inodes that would otherwise overflow link count
        xfs: try to avoid allocating from sick inode clusters
        xfs: check unused nlink fields in the ondisk inode
      9ba8e658
    • Chandan Babu R's avatar
      Merge tag 'repair-iunlink-6.10_2024-04-15' of... · 1eef0125
      Chandan Babu R authored
      Merge tag 'repair-iunlink-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: online fsck of iunlink buckets
      
      This series enhances the AGI scrub code to check the unlinked inode
      bucket lists for errors, and fixes them if necessary.  Now that iunlink
      pointer updates are virtual log items, we can batch updates pretty
      efficiently in the logging code.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-iunlink-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: repair AGI unlinked inode bucket lists
        xfs: hoist AGI repair context to a heap object
        xfs: check AGI unlinked inode buckets
      1eef0125
    • Chandan Babu R's avatar
      Merge tag 'repair-symlink-6.10_2024-04-15' of... · 0313dd8f
      Chandan Babu R authored
      Merge tag 'repair-symlink-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: online repair of symbolic links
      
      The patches in this set adds the ability to repair the target buffer of
      a symbolic link, using the same salvage, rebuild, and swap strategy used
      everywhere else.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-symlink-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: online repair of symbolic links
        xfs: pass the owner to xfs_symlink_write_target
        xfs: expose xfs_bmap_local_to_extents for online repair
      0313dd8f
    • Chandan Babu R's avatar
      Merge tag 'repair-orphanage-6.10_2024-04-15' of... · 067d3f71
      Chandan Babu R authored
      Merge tag 'repair-orphanage-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: move orphan files to lost and found
      
      Orphaned files are defined to be files with nonzero ondisk link count
      but no observable parent directory.  This series enables online repair
      to reparent orphaned files into the filesystem directory tree, and wires
      up this reparenting ability into the directory, file link count, and
      parent pointer repair functions.  This is how we fix files with positive
      link count that are not reachable through the directory tree.
      
      This patch will also create the orphanage directory (lost+found) if it
      is not present.  In contrast to xfs_repair, we follow e2fsck in creating
      the lost+found without group or other-owner access to avoid accidental
      disclosure of files that were previously hidden by an 0700 directory.
      That's silly security, but people have been known to do it.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-orphanage-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: ensure dentry consistency when the orphanage adopts a file
        xfs: move files to orphanage instead of letting nlinks drop to zero
        xfs: move orphan files to the orphanage
      067d3f71
    • Chandan Babu R's avatar
      Merge tag 'repair-dirs-6.10_2024-04-15' of... · 9e6b93b7
      Chandan Babu R authored
      Merge tag 'repair-dirs-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: online repair of directories
      
      This series employs atomic extent swapping to enable safe reconstruction
      of directory data.  For now, XFS does not support reverse directory
      links (aka parent pointers), so we can only salvage the dirents of a
      directory and construct a new structure.
      
      Directory repair therefore consists of five main parts:
      
      First, we walk the existing directory to salvage as many entries as we
      can, by adding them as new directory entries to the repair temp dir.
      
      Second, we validate the parent pointer found in the directory.  If one
      was not found, we scan the entire filesystem looking for a potential
      parent.
      
      Third, we use atomic extent swaps to exchange the entire data fork
      between the two directories.
      
      Fourth, we reap the old directory blocks as carefully as we can.
      
      To wrap up the directory repair code, we need to add to the regular
      filesystem the ability to free all the data fork blocks in a directory.
      This does not change anything with normal directories, since they must
      still unlink and shrink one entry at a time.  However, this will
      facilitate freeing of partially-inactivated temporary directories during
      log recovery.
      
      The second half of this patchset implements repairs for the dotdot
      entries of directories.  For now there is only rudimentary support for
      this, because there are no directory parent pointers, so the best we can
      do is scanning the filesystem and the VFS dcache for answers.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-dirs-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: ask the dentry cache if it knows the parent of a directory
        xfs: online repair of parent pointers
        xfs: scan the filesystem to repair a directory dotdot entry
        xfs: online repair of directories
        xfs: inactivate directory data blocks
      9e6b93b7
    • Chandan Babu R's avatar
      Merge tag 'repair-unlinked-inode-state-6.10_2024-04-15' of... · 902603bf
      Chandan Babu R authored
      Merge tag 'repair-unlinked-inode-state-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: online repair of inode unlinked state
      
      This series adds some logic to the inode scrubbers so that they can
      detect and deal with consistency errors between the link count and the
      per-inode unlinked list state.  The helpers needed to do this are
      presented here because they are a prequisite for rebuildng directories,
      since we need to get a rebuilt non-empty directory off the unlinked
      list.
      
      Note that this patchset does not provide comprehensive reconstruction of
      the AGI unlinked list; that is coming in a subsequent patchset.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-unlinked-inode-state-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: update the unlinked list when repairing link counts
        xfs: ensure unlinked list state is consistent with nlink during scrub
      902603bf
    • Chandan Babu R's avatar
      Merge tag 'repair-xattrs-6.10_2024-04-15' of... · 5f3e9511
      Chandan Babu R authored
      Merge tag 'repair-xattrs-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: online repair of extended attributes
      
      This series employs atomic extent swapping to enable safe reconstruction
      of extended attribute data attached to a file.  Because xattrs do not
      have any redundant information to draw off of, we can at best salvage
      as much data as we can and build a new structure.
      
      Rebuilding an extended attribute structure consists of these three
      steps:
      
      First, we walk the existing attributes to salvage as many of them as we
      can, by adding them as new attributes attached to the repair tempfile.
      We need to add a new xfile-based data structure to hold blobs of
      arbitrary length to stage the xattr names and values.
      
      Second, we write the salvaged attributes to a temporary file, and use
      atomic extent swaps to exchange the entire attribute fork between the
      two files.
      
      Finally, we reap the old xattr blocks (which are now in the temporary
      file) as carefully as we can.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'repair-xattrs-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: create an xattr iteration function for scrub
        xfs: flag empty xattr leaf blocks for optimization
        xfs: scrub should set preen if attr leaf has holes
        xfs: repair extended attributes
        xfs: use atomic extent swapping to fix user file fork data
        xfs: create a blob array data structure
        xfs: enable discarding of folios backing an xfile
      5f3e9511
    • Chandan Babu R's avatar
      Merge tag 'dirattr-validate-owners-6.10_2024-04-15' of... · fb1f7c66
      Chandan Babu R authored
      Merge tag 'dirattr-validate-owners-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux into xfs-6.10-mergeA
      
      xfs: set and validate dir/attr block owners
      
      There are a couple of significant changes that need to be made to the
      directory and xattr code before we can support online repairs of those
      data structures.
      
      The first change is because online repair is designed to use libxfs to
      create a replacement dir/xattr structure in a temporary file, and use
      atomic extent swapping to commit the corrected structure.  To avoid the
      performance hit of walking every block of the new structure to rewrite
      the owner number before the swap, we instead change libxfs to allow
      callers of the dir and xattr code the ability to set an explicit owner
      number to be written into the header fields of any new blocks that are
      created.  For regular operation this will be the directory inode number.
      
      The second change is to update the dir/xattr code to actually *check*
      the owner number in each block that is read off the disk, since we don't
      currently do that.
      Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
      Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
      
      * tag 'dirattr-validate-owners-6.10_2024-04-15' of https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux:
        xfs: validate explicit directory free block owners
        xfs: validate explicit directory block buffer owners
        xfs: validate explicit directory data buffer owners
        xfs: validate directory leaf buffer owners
        xfs: validate dabtree node buffer owners
        xfs: validate attr remote value buffer owners
        xfs: validate attr leaf buffer owners
        xfs: reduce indenting in xfs_attr_node_list
        xfs: use the xfs_da_args owner field to set new dir/attr block owner
        xfs: add an explicit owner field to xfs_da_args
      fb1f7c66