hc
2023-12-09 b22da3d8526a935aa31e086e63f60ff3246cb61c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// SPDX-License-Identifier: GPL-2.0+
/*
 * Copyright (C) 2018 Oracle.  All Rights Reserved.
 * Author: Darrick J. Wong <darrick.wong@oracle.com>
 */
#ifndef __XFS_SCRUB_REPAIR_H__
#define __XFS_SCRUB_REPAIR_H__
 
#include "xfs_quota_defs.h"
 
static inline int xrep_notsupported(struct xfs_scrub *sc)
{
   return -EOPNOTSUPP;
}
 
#ifdef CONFIG_XFS_ONLINE_REPAIR
 
/* Repair helpers */
 
int xrep_attempt(struct xfs_inode *ip, struct xfs_scrub *sc);
void xrep_failure(struct xfs_mount *mp);
int xrep_roll_ag_trans(struct xfs_scrub *sc);
bool xrep_ag_has_space(struct xfs_perag *pag, xfs_extlen_t nr_blocks,
       enum xfs_ag_resv_type type);
xfs_extlen_t xrep_calc_ag_resblks(struct xfs_scrub *sc);
int xrep_alloc_ag_block(struct xfs_scrub *sc,
       const struct xfs_owner_info *oinfo, xfs_fsblock_t *fsbno,
       enum xfs_ag_resv_type resv);
int xrep_init_btblock(struct xfs_scrub *sc, xfs_fsblock_t fsb,
       struct xfs_buf **bpp, xfs_btnum_t btnum,
       const struct xfs_buf_ops *ops);
 
struct xbitmap;
 
int xrep_fix_freelist(struct xfs_scrub *sc, bool can_shrink);
int xrep_invalidate_blocks(struct xfs_scrub *sc, struct xbitmap *btlist);
int xrep_reap_extents(struct xfs_scrub *sc, struct xbitmap *exlist,
       const struct xfs_owner_info *oinfo, enum xfs_ag_resv_type type);
 
struct xrep_find_ag_btree {
   /* in: rmap owner of the btree we're looking for */
   uint64_t            rmap_owner;
 
   /* in: buffer ops */
   const struct xfs_buf_ops    *buf_ops;
 
   /* out: the highest btree block found and the tree height */
   xfs_agblock_t            root;
   unsigned int            height;
};
 
int xrep_find_ag_btree_roots(struct xfs_scrub *sc, struct xfs_buf *agf_bp,
       struct xrep_find_ag_btree *btree_info, struct xfs_buf *agfl_bp);
void xrep_force_quotacheck(struct xfs_scrub *sc, xfs_dqtype_t type);
int xrep_ino_dqattach(struct xfs_scrub *sc);
 
/* Metadata repairers */
 
int xrep_probe(struct xfs_scrub *sc);
int xrep_superblock(struct xfs_scrub *sc);
int xrep_agf(struct xfs_scrub *sc);
int xrep_agfl(struct xfs_scrub *sc);
int xrep_agi(struct xfs_scrub *sc);
 
#else
 
static inline int xrep_attempt(
   struct xfs_inode    *ip,
   struct xfs_scrub    *sc)
{
   return -EOPNOTSUPP;
}
 
static inline void xrep_failure(struct xfs_mount *mp) {}
 
static inline xfs_extlen_t
xrep_calc_ag_resblks(
   struct xfs_scrub    *sc)
{
   return 0;
}
 
#define xrep_probe            xrep_notsupported
#define xrep_superblock            xrep_notsupported
#define xrep_agf            xrep_notsupported
#define xrep_agfl            xrep_notsupported
#define xrep_agi            xrep_notsupported
 
#endif /* CONFIG_XFS_ONLINE_REPAIR */
 
#endif    /* __XFS_SCRUB_REPAIR_H__ */