space-info.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef BTRFS_SPACE_INFO_H
  3. #define BTRFS_SPACE_INFO_H
  4. struct btrfs_space_info {
  5. spinlock_t lock;
  6. u64 total_bytes; /* total bytes in the space,
  7. this doesn't take mirrors into account */
  8. u64 bytes_used; /* total bytes used,
  9. this doesn't take mirrors into account */
  10. u64 bytes_pinned; /* total bytes pinned, will be freed when the
  11. transaction finishes */
  12. u64 bytes_reserved; /* total bytes the allocator has reserved for
  13. current allocations */
  14. u64 bytes_may_use; /* number of bytes that may be used for
  15. delalloc/allocations */
  16. u64 bytes_readonly; /* total bytes that are read only */
  17. u64 max_extent_size; /* This will hold the maximum extent size of
  18. the space info if we had an ENOSPC in the
  19. allocator. */
  20. unsigned int full:1; /* indicates that we cannot allocate any more
  21. chunks for this space */
  22. unsigned int chunk_alloc:1; /* set if we are allocating a chunk */
  23. unsigned int flush:1; /* set if we are trying to make space */
  24. unsigned int force_alloc; /* set if we need to force a chunk
  25. alloc for this space */
  26. u64 disk_used; /* total bytes used on disk */
  27. u64 disk_total; /* total bytes on disk, takes mirrors into
  28. account */
  29. u64 flags;
  30. /*
  31. * bytes_pinned is kept in line with what is actually pinned, as in
  32. * we've called update_block_group and dropped the bytes_used counter
  33. * and increased the bytes_pinned counter. However this means that
  34. * bytes_pinned does not reflect the bytes that will be pinned once the
  35. * delayed refs are flushed, so this counter is inc'ed every time we
  36. * call btrfs_free_extent so it is a realtime count of what will be
  37. * freed once the transaction is committed. It will be zeroed every
  38. * time the transaction commits.
  39. */
  40. struct percpu_counter total_bytes_pinned;
  41. struct list_head list;
  42. /* Protected by the spinlock 'lock'. */
  43. struct list_head ro_bgs;
  44. struct list_head priority_tickets;
  45. struct list_head tickets;
  46. /*
  47. * tickets_id just indicates the next ticket will be handled, so note
  48. * it's not stored per ticket.
  49. */
  50. u64 tickets_id;
  51. struct rw_semaphore groups_sem;
  52. /* for block groups in our same type */
  53. struct list_head block_groups[BTRFS_NR_RAID_TYPES];
  54. wait_queue_head_t wait;
  55. struct kobject kobj;
  56. struct kobject *block_group_kobjs[BTRFS_NR_RAID_TYPES];
  57. };
  58. struct reserve_ticket {
  59. u64 bytes;
  60. int error;
  61. bool steal;
  62. struct list_head list;
  63. wait_queue_head_t wait;
  64. };
  65. static inline bool btrfs_mixed_space_info(struct btrfs_space_info *space_info)
  66. {
  67. return ((space_info->flags & BTRFS_BLOCK_GROUP_METADATA) &&
  68. (space_info->flags & BTRFS_BLOCK_GROUP_DATA));
  69. }
  70. /*
  71. *
  72. * Declare a helper function to detect underflow of various space info members
  73. */
  74. #define DECLARE_SPACE_INFO_UPDATE(name, trace_name) \
  75. static inline void \
  76. btrfs_space_info_update_##name(struct btrfs_fs_info *fs_info, \
  77. struct btrfs_space_info *sinfo, \
  78. s64 bytes) \
  79. { \
  80. const u64 abs_bytes = (bytes < 0) ? -bytes : bytes; \
  81. lockdep_assert_held(&sinfo->lock); \
  82. trace_update_##name(fs_info, sinfo, sinfo->name, bytes); \
  83. trace_btrfs_space_reservation(fs_info, trace_name, \
  84. sinfo->flags, abs_bytes, \
  85. bytes > 0); \
  86. if (bytes < 0 && sinfo->name < -bytes) { \
  87. WARN_ON(1); \
  88. sinfo->name = 0; \
  89. return; \
  90. } \
  91. sinfo->name += bytes; \
  92. }
  93. DECLARE_SPACE_INFO_UPDATE(bytes_may_use, "space_info");
  94. DECLARE_SPACE_INFO_UPDATE(bytes_pinned, "pinned");
  95. int btrfs_init_space_info(struct btrfs_fs_info *fs_info);
  96. void btrfs_update_space_info(struct btrfs_fs_info *info, u64 flags,
  97. u64 total_bytes, u64 bytes_used,
  98. u64 bytes_readonly,
  99. struct btrfs_space_info **space_info);
  100. struct btrfs_space_info *btrfs_find_space_info(struct btrfs_fs_info *info,
  101. u64 flags);
  102. u64 btrfs_space_info_used(struct btrfs_space_info *s_info,
  103. bool may_use_included);
  104. void btrfs_clear_space_info_full(struct btrfs_fs_info *info);
  105. void btrfs_dump_space_info(struct btrfs_fs_info *fs_info,
  106. struct btrfs_space_info *info, u64 bytes,
  107. int dump_block_groups);
  108. int btrfs_reserve_metadata_bytes(struct btrfs_root *root,
  109. struct btrfs_block_rsv *block_rsv,
  110. u64 orig_bytes,
  111. enum btrfs_reserve_flush_enum flush);
  112. void btrfs_try_granting_tickets(struct btrfs_fs_info *fs_info,
  113. struct btrfs_space_info *space_info);
  114. int btrfs_can_overcommit(struct btrfs_fs_info *fs_info,
  115. struct btrfs_space_info *space_info, u64 bytes,
  116. enum btrfs_reserve_flush_enum flush);
  117. static inline void btrfs_space_info_free_bytes_may_use(
  118. struct btrfs_fs_info *fs_info,
  119. struct btrfs_space_info *space_info,
  120. u64 num_bytes)
  121. {
  122. spin_lock(&space_info->lock);
  123. btrfs_space_info_update_bytes_may_use(fs_info, space_info, -num_bytes);
  124. btrfs_try_granting_tickets(fs_info, space_info);
  125. spin_unlock(&space_info->lock);
  126. }
  127. #endif /* BTRFS_SPACE_INFO_H */