common.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /*
  2. * Copyright (C) 2017 Oracle. All Rights Reserved.
  3. *
  4. * Author: Darrick J. Wong <darrick.wong@oracle.com>
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License
  8. * as published by the Free Software Foundation; either version 2
  9. * of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it would be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write the Free Software Foundation,
  18. * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. #ifndef __XFS_SCRUB_COMMON_H__
  21. #define __XFS_SCRUB_COMMON_H__
  22. /*
  23. * We /could/ terminate a scrub/repair operation early. If we're not
  24. * in a good place to continue (fatal signal, etc.) then bail out.
  25. * Note that we're careful not to make any judgements about *error.
  26. */
  27. static inline bool
  28. xfs_scrub_should_terminate(
  29. struct xfs_scrub_context *sc,
  30. int *error)
  31. {
  32. if (fatal_signal_pending(current)) {
  33. if (*error == 0)
  34. *error = -EAGAIN;
  35. return true;
  36. }
  37. return false;
  38. }
  39. /*
  40. * Grab an empty transaction so that we can re-grab locked buffers if
  41. * one of our btrees turns out to be cyclic.
  42. */
  43. static inline int
  44. xfs_scrub_trans_alloc(
  45. struct xfs_scrub_metadata *sm,
  46. struct xfs_mount *mp,
  47. struct xfs_trans **tpp)
  48. {
  49. return xfs_trans_alloc_empty(mp, tpp);
  50. }
  51. bool xfs_scrub_process_error(struct xfs_scrub_context *sc, xfs_agnumber_t agno,
  52. xfs_agblock_t bno, int *error);
  53. bool xfs_scrub_fblock_process_error(struct xfs_scrub_context *sc, int whichfork,
  54. xfs_fileoff_t offset, int *error);
  55. bool xfs_scrub_xref_process_error(struct xfs_scrub_context *sc,
  56. xfs_agnumber_t agno, xfs_agblock_t bno, int *error);
  57. bool xfs_scrub_fblock_xref_process_error(struct xfs_scrub_context *sc,
  58. int whichfork, xfs_fileoff_t offset, int *error);
  59. void xfs_scrub_block_set_preen(struct xfs_scrub_context *sc,
  60. struct xfs_buf *bp);
  61. void xfs_scrub_ino_set_preen(struct xfs_scrub_context *sc, xfs_ino_t ino);
  62. void xfs_scrub_block_set_corrupt(struct xfs_scrub_context *sc,
  63. struct xfs_buf *bp);
  64. void xfs_scrub_ino_set_corrupt(struct xfs_scrub_context *sc, xfs_ino_t ino);
  65. void xfs_scrub_fblock_set_corrupt(struct xfs_scrub_context *sc, int whichfork,
  66. xfs_fileoff_t offset);
  67. void xfs_scrub_block_xref_set_corrupt(struct xfs_scrub_context *sc,
  68. struct xfs_buf *bp);
  69. void xfs_scrub_ino_xref_set_corrupt(struct xfs_scrub_context *sc,
  70. xfs_ino_t ino);
  71. void xfs_scrub_fblock_xref_set_corrupt(struct xfs_scrub_context *sc,
  72. int whichfork, xfs_fileoff_t offset);
  73. void xfs_scrub_ino_set_warning(struct xfs_scrub_context *sc, xfs_ino_t ino);
  74. void xfs_scrub_fblock_set_warning(struct xfs_scrub_context *sc, int whichfork,
  75. xfs_fileoff_t offset);
  76. void xfs_scrub_set_incomplete(struct xfs_scrub_context *sc);
  77. int xfs_scrub_checkpoint_log(struct xfs_mount *mp);
  78. /* Are we set up for a cross-referencing check? */
  79. bool xfs_scrub_should_check_xref(struct xfs_scrub_context *sc, int *error,
  80. struct xfs_btree_cur **curpp);
  81. /* Setup functions */
  82. int xfs_scrub_setup_fs(struct xfs_scrub_context *sc, struct xfs_inode *ip);
  83. int xfs_scrub_setup_ag_allocbt(struct xfs_scrub_context *sc,
  84. struct xfs_inode *ip);
  85. int xfs_scrub_setup_ag_iallocbt(struct xfs_scrub_context *sc,
  86. struct xfs_inode *ip);
  87. int xfs_scrub_setup_ag_rmapbt(struct xfs_scrub_context *sc,
  88. struct xfs_inode *ip);
  89. int xfs_scrub_setup_ag_refcountbt(struct xfs_scrub_context *sc,
  90. struct xfs_inode *ip);
  91. int xfs_scrub_setup_inode(struct xfs_scrub_context *sc,
  92. struct xfs_inode *ip);
  93. int xfs_scrub_setup_inode_bmap(struct xfs_scrub_context *sc,
  94. struct xfs_inode *ip);
  95. int xfs_scrub_setup_inode_bmap_data(struct xfs_scrub_context *sc,
  96. struct xfs_inode *ip);
  97. int xfs_scrub_setup_directory(struct xfs_scrub_context *sc,
  98. struct xfs_inode *ip);
  99. int xfs_scrub_setup_xattr(struct xfs_scrub_context *sc,
  100. struct xfs_inode *ip);
  101. int xfs_scrub_setup_symlink(struct xfs_scrub_context *sc,
  102. struct xfs_inode *ip);
  103. int xfs_scrub_setup_parent(struct xfs_scrub_context *sc,
  104. struct xfs_inode *ip);
  105. #ifdef CONFIG_XFS_RT
  106. int xfs_scrub_setup_rt(struct xfs_scrub_context *sc, struct xfs_inode *ip);
  107. #else
  108. static inline int
  109. xfs_scrub_setup_rt(struct xfs_scrub_context *sc, struct xfs_inode *ip)
  110. {
  111. return -ENOENT;
  112. }
  113. #endif
  114. #ifdef CONFIG_XFS_QUOTA
  115. int xfs_scrub_setup_quota(struct xfs_scrub_context *sc, struct xfs_inode *ip);
  116. #else
  117. static inline int
  118. xfs_scrub_setup_quota(struct xfs_scrub_context *sc, struct xfs_inode *ip)
  119. {
  120. return -ENOENT;
  121. }
  122. #endif
  123. void xfs_scrub_ag_free(struct xfs_scrub_context *sc, struct xfs_scrub_ag *sa);
  124. int xfs_scrub_ag_init(struct xfs_scrub_context *sc, xfs_agnumber_t agno,
  125. struct xfs_scrub_ag *sa);
  126. int xfs_scrub_ag_read_headers(struct xfs_scrub_context *sc, xfs_agnumber_t agno,
  127. struct xfs_buf **agi, struct xfs_buf **agf,
  128. struct xfs_buf **agfl);
  129. void xfs_scrub_ag_btcur_free(struct xfs_scrub_ag *sa);
  130. int xfs_scrub_ag_btcur_init(struct xfs_scrub_context *sc,
  131. struct xfs_scrub_ag *sa);
  132. int xfs_scrub_walk_agfl(struct xfs_scrub_context *sc,
  133. int (*fn)(struct xfs_scrub_context *, xfs_agblock_t bno,
  134. void *),
  135. void *priv);
  136. int xfs_scrub_count_rmap_ownedby_ag(struct xfs_scrub_context *sc,
  137. struct xfs_btree_cur *cur,
  138. struct xfs_owner_info *oinfo,
  139. xfs_filblks_t *blocks);
  140. int xfs_scrub_setup_ag_btree(struct xfs_scrub_context *sc,
  141. struct xfs_inode *ip, bool force_log);
  142. int xfs_scrub_get_inode(struct xfs_scrub_context *sc, struct xfs_inode *ip_in);
  143. int xfs_scrub_setup_inode_contents(struct xfs_scrub_context *sc,
  144. struct xfs_inode *ip, unsigned int resblks);
  145. void xfs_scrub_buffer_recheck(struct xfs_scrub_context *sc, struct xfs_buf *bp);
  146. #endif /* __XFS_SCRUB_COMMON_H__ */