trace.c 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2017 Oracle. All Rights Reserved.
  4. * Author: Darrick J. Wong <darrick.wong@oracle.com>
  5. */
  6. #include "xfs.h"
  7. #include "xfs_fs.h"
  8. #include "xfs_shared.h"
  9. #include "xfs_format.h"
  10. #include "xfs_log_format.h"
  11. #include "xfs_trans_resv.h"
  12. #include "xfs_mount.h"
  13. #include "xfs_defer.h"
  14. #include "xfs_da_format.h"
  15. #include "xfs_inode.h"
  16. #include "xfs_btree.h"
  17. #include "xfs_trans.h"
  18. #include "xfs_bit.h"
  19. #include "scrub/xfs_scrub.h"
  20. #include "scrub/scrub.h"
  21. #include "scrub/common.h"
  22. /* Figure out which block the btree cursor was pointing to. */
  23. static inline xfs_fsblock_t
  24. xchk_btree_cur_fsbno(
  25. struct xfs_btree_cur *cur,
  26. int level)
  27. {
  28. if (level < cur->bc_nlevels && cur->bc_bufs[level])
  29. return XFS_DADDR_TO_FSB(cur->bc_mp, cur->bc_bufs[level]->b_bn);
  30. else if (level == cur->bc_nlevels - 1 &&
  31. cur->bc_flags & XFS_BTREE_LONG_PTRS)
  32. return XFS_INO_TO_FSB(cur->bc_mp, cur->bc_private.b.ip->i_ino);
  33. else if (!(cur->bc_flags & XFS_BTREE_LONG_PTRS))
  34. return XFS_AGB_TO_FSB(cur->bc_mp, cur->bc_private.a.agno, 0);
  35. return NULLFSBLOCK;
  36. }
  37. /*
  38. * We include this last to have the helpers above available for the trace
  39. * event implementations.
  40. */
  41. #define CREATE_TRACE_POINTS
  42. #include "scrub/trace.h"