4c233b5c4f
Currently, online scrub reuses the xfs_readdir code to walk every entry in a directory. This isn't awesome for performance, since we end up cycling the directory ILOCK needlessly and coding around the particular quirks of the VFS dir_context interface. Create a streamlined version of readdir that keeps the ILOCK (since the walk function isn't going to copy stuff to userspace), skips a whole lot of directory walk cursor checks (since we start at 0 and walk to the end) and has a sane way to return error codes. Note: Porting the dotdot checking code is left for a subsequent patch. Signed-off-by: Darrick J. Wong <djwong@kernel.org> Reviewed-by: Dave Chinner <dchinner@redhat.com>
20 lines
640 B
C
20 lines
640 B
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Copyright (C) 2022-2023 Oracle. All Rights Reserved.
|
|
* Author: Darrick J. Wong <djwong@kernel.org>
|
|
*/
|
|
#ifndef __XFS_SCRUB_READDIR_H__
|
|
#define __XFS_SCRUB_READDIR_H__
|
|
|
|
typedef int (*xchk_dirent_fn)(struct xfs_scrub *sc, struct xfs_inode *dp,
|
|
xfs_dir2_dataptr_t dapos, const struct xfs_name *name,
|
|
xfs_ino_t ino, void *priv);
|
|
|
|
int xchk_dir_walk(struct xfs_scrub *sc, struct xfs_inode *dp,
|
|
xchk_dirent_fn dirent_fn, void *priv);
|
|
|
|
int xchk_dir_lookup(struct xfs_scrub *sc, struct xfs_inode *dp,
|
|
const struct xfs_name *name, xfs_ino_t *ino);
|
|
|
|
#endif /* __XFS_SCRUB_READDIR_H__ */
|