1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- // SPDX-License-Identifier: GPL-2.0+
- /*
- * Copyright (C) 2017 Oracle. All Rights Reserved.
- * Author: Darrick J. Wong <[email protected]>
- */
- #ifndef __XFS_SCRUB_BTREE_H__
- #define __XFS_SCRUB_BTREE_H__
- /* btree scrub */
- /* Check for btree operation errors. */
- bool xchk_btree_process_error(struct xfs_scrub *sc,
- struct xfs_btree_cur *cur, int level, int *error);
- /* Check for btree xref operation errors. */
- bool xchk_btree_xref_process_error(struct xfs_scrub *sc,
- struct xfs_btree_cur *cur, int level, int *error);
- /* Check for btree corruption. */
- void xchk_btree_set_corrupt(struct xfs_scrub *sc,
- struct xfs_btree_cur *cur, int level);
- /* Check for btree xref discrepancies. */
- void xchk_btree_xref_set_corrupt(struct xfs_scrub *sc,
- struct xfs_btree_cur *cur, int level);
- struct xchk_btree;
- typedef int (*xchk_btree_rec_fn)(
- struct xchk_btree *bs,
- const union xfs_btree_rec *rec);
- struct xchk_btree {
- /* caller-provided scrub state */
- struct xfs_scrub *sc;
- struct xfs_btree_cur *cur;
- xchk_btree_rec_fn scrub_rec;
- const struct xfs_owner_info *oinfo;
- void *private;
- /* internal scrub state */
- union xfs_btree_rec lastrec;
- struct list_head to_check;
- /* this element must come last! */
- union xfs_btree_key lastkey[];
- };
- /*
- * Calculate the size of a xchk_btree structure. There are nlevels-1 slots for
- * keys because we track leaf records separately in lastrec.
- */
- static inline size_t
- xchk_btree_sizeof(unsigned int nlevels)
- {
- return struct_size((struct xchk_btree *)NULL, lastkey, nlevels - 1);
- }
- int xchk_btree(struct xfs_scrub *sc, struct xfs_btree_cur *cur,
- xchk_btree_rec_fn scrub_fn, const struct xfs_owner_info *oinfo,
- void *private);
- #endif /* __XFS_SCRUB_BTREE_H__ */
|