block-rsv.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include "misc.h"
  3. #include "ctree.h"
  4. #include "block-rsv.h"
  5. #include "space-info.h"
  6. #include "transaction.h"
  7. #include "block-group.h"
  8. #include "fs.h"
  9. #include "accessors.h"
  10. /*
  11. * HOW DO BLOCK RESERVES WORK
  12. *
  13. * Think of block_rsv's as buckets for logically grouped metadata
  14. * reservations. Each block_rsv has a ->size and a ->reserved. ->size is
  15. * how large we want our block rsv to be, ->reserved is how much space is
  16. * currently reserved for this block reserve.
  17. *
  18. * ->failfast exists for the truncate case, and is described below.
  19. *
  20. * NORMAL OPERATION
  21. *
  22. * -> Reserve
  23. * Entrance: btrfs_block_rsv_add, btrfs_block_rsv_refill
  24. *
  25. * We call into btrfs_reserve_metadata_bytes() with our bytes, which is
  26. * accounted for in space_info->bytes_may_use, and then add the bytes to
  27. * ->reserved, and ->size in the case of btrfs_block_rsv_add.
  28. *
  29. * ->size is an over-estimation of how much we may use for a particular
  30. * operation.
  31. *
  32. * -> Use
  33. * Entrance: btrfs_use_block_rsv
  34. *
  35. * When we do a btrfs_alloc_tree_block() we call into btrfs_use_block_rsv()
  36. * to determine the appropriate block_rsv to use, and then verify that
  37. * ->reserved has enough space for our tree block allocation. Once
  38. * successful we subtract fs_info->nodesize from ->reserved.
  39. *
  40. * -> Finish
  41. * Entrance: btrfs_block_rsv_release
  42. *
  43. * We are finished with our operation, subtract our individual reservation
  44. * from ->size, and then subtract ->size from ->reserved and free up the
  45. * excess if there is any.
  46. *
  47. * There is some logic here to refill the delayed refs rsv or the global rsv
  48. * as needed, otherwise the excess is subtracted from
  49. * space_info->bytes_may_use.
  50. *
  51. * TYPES OF BLOCK RESERVES
  52. *
  53. * BLOCK_RSV_TRANS, BLOCK_RSV_DELOPS, BLOCK_RSV_CHUNK
  54. * These behave normally, as described above, just within the confines of the
  55. * lifetime of their particular operation (transaction for the whole trans
  56. * handle lifetime, for example).
  57. *
  58. * BLOCK_RSV_GLOBAL
  59. * It is impossible to properly account for all the space that may be required
  60. * to make our extent tree updates. This block reserve acts as an overflow
  61. * buffer in case our delayed refs reserve does not reserve enough space to
  62. * update the extent tree.
  63. *
  64. * We can steal from this in some cases as well, notably on evict() or
  65. * truncate() in order to help users recover from ENOSPC conditions.
  66. *
  67. * BLOCK_RSV_DELALLOC
  68. * The individual item sizes are determined by the per-inode size
  69. * calculations, which are described with the delalloc code. This is pretty
  70. * straightforward, it's just the calculation of ->size encodes a lot of
  71. * different items, and thus it gets used when updating inodes, inserting file
  72. * extents, and inserting checksums.
  73. *
  74. * BLOCK_RSV_DELREFS
  75. * We keep a running tally of how many delayed refs we have on the system.
  76. * We assume each one of these delayed refs are going to use a full
  77. * reservation. We use the transaction items and pre-reserve space for every
  78. * operation, and use this reservation to refill any gap between ->size and
  79. * ->reserved that may exist.
  80. *
  81. * From there it's straightforward, removing a delayed ref means we remove its
  82. * count from ->size and free up reservations as necessary. Since this is
  83. * the most dynamic block reserve in the system, we will try to refill this
  84. * block reserve first with any excess returned by any other block reserve.
  85. *
  86. * BLOCK_RSV_EMPTY
  87. * This is the fallback block reserve to make us try to reserve space if we
  88. * don't have a specific bucket for this allocation. It is mostly used for
  89. * updating the device tree and such, since that is a separate pool we're
  90. * content to just reserve space from the space_info on demand.
  91. *
  92. * BLOCK_RSV_TEMP
  93. * This is used by things like truncate and iput. We will temporarily
  94. * allocate a block reserve, set it to some size, and then truncate bytes
  95. * until we have no space left. With ->failfast set we'll simply return
  96. * ENOSPC from btrfs_use_block_rsv() to signal that we need to unwind and try
  97. * to make a new reservation. This is because these operations are
  98. * unbounded, so we want to do as much work as we can, and then back off and
  99. * re-reserve.
  100. */
  101. static u64 block_rsv_release_bytes(struct btrfs_fs_info *fs_info,
  102. struct btrfs_block_rsv *block_rsv,
  103. struct btrfs_block_rsv *dest, u64 num_bytes,
  104. u64 *qgroup_to_release_ret)
  105. {
  106. struct btrfs_space_info *space_info = block_rsv->space_info;
  107. u64 qgroup_to_release = 0;
  108. u64 ret;
  109. spin_lock(&block_rsv->lock);
  110. if (num_bytes == (u64)-1) {
  111. num_bytes = block_rsv->size;
  112. qgroup_to_release = block_rsv->qgroup_rsv_size;
  113. }
  114. block_rsv->size -= num_bytes;
  115. if (block_rsv->reserved >= block_rsv->size) {
  116. num_bytes = block_rsv->reserved - block_rsv->size;
  117. block_rsv->reserved = block_rsv->size;
  118. block_rsv->full = true;
  119. } else {
  120. num_bytes = 0;
  121. }
  122. if (qgroup_to_release_ret &&
  123. block_rsv->qgroup_rsv_reserved >= block_rsv->qgroup_rsv_size) {
  124. qgroup_to_release = block_rsv->qgroup_rsv_reserved -
  125. block_rsv->qgroup_rsv_size;
  126. block_rsv->qgroup_rsv_reserved = block_rsv->qgroup_rsv_size;
  127. } else {
  128. qgroup_to_release = 0;
  129. }
  130. spin_unlock(&block_rsv->lock);
  131. ret = num_bytes;
  132. if (num_bytes > 0) {
  133. if (dest) {
  134. spin_lock(&dest->lock);
  135. if (!dest->full) {
  136. u64 bytes_to_add;
  137. bytes_to_add = dest->size - dest->reserved;
  138. bytes_to_add = min(num_bytes, bytes_to_add);
  139. dest->reserved += bytes_to_add;
  140. if (dest->reserved >= dest->size)
  141. dest->full = true;
  142. num_bytes -= bytes_to_add;
  143. }
  144. spin_unlock(&dest->lock);
  145. }
  146. if (num_bytes)
  147. btrfs_space_info_free_bytes_may_use(space_info, num_bytes);
  148. }
  149. if (qgroup_to_release_ret)
  150. *qgroup_to_release_ret = qgroup_to_release;
  151. return ret;
  152. }
  153. int btrfs_block_rsv_migrate(struct btrfs_block_rsv *src,
  154. struct btrfs_block_rsv *dst, u64 num_bytes,
  155. bool update_size)
  156. {
  157. int ret;
  158. ret = btrfs_block_rsv_use_bytes(src, num_bytes);
  159. if (ret)
  160. return ret;
  161. btrfs_block_rsv_add_bytes(dst, num_bytes, update_size);
  162. return 0;
  163. }
  164. void btrfs_init_block_rsv(struct btrfs_block_rsv *rsv, enum btrfs_rsv_type type)
  165. {
  166. memset(rsv, 0, sizeof(*rsv));
  167. spin_lock_init(&rsv->lock);
  168. rsv->type = type;
  169. }
  170. void btrfs_init_metadata_block_rsv(struct btrfs_fs_info *fs_info,
  171. struct btrfs_block_rsv *rsv,
  172. enum btrfs_rsv_type type)
  173. {
  174. btrfs_init_block_rsv(rsv, type);
  175. rsv->space_info = btrfs_find_space_info(fs_info,
  176. BTRFS_BLOCK_GROUP_METADATA);
  177. }
  178. struct btrfs_block_rsv *btrfs_alloc_block_rsv(struct btrfs_fs_info *fs_info,
  179. enum btrfs_rsv_type type)
  180. {
  181. struct btrfs_block_rsv *block_rsv;
  182. block_rsv = kmalloc_obj(*block_rsv, GFP_NOFS);
  183. if (!block_rsv)
  184. return NULL;
  185. btrfs_init_metadata_block_rsv(fs_info, block_rsv, type);
  186. return block_rsv;
  187. }
  188. void btrfs_free_block_rsv(struct btrfs_fs_info *fs_info,
  189. struct btrfs_block_rsv *rsv)
  190. {
  191. if (!rsv)
  192. return;
  193. btrfs_block_rsv_release(fs_info, rsv, (u64)-1, NULL);
  194. kfree(rsv);
  195. }
  196. int btrfs_block_rsv_add(struct btrfs_fs_info *fs_info,
  197. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  198. enum btrfs_reserve_flush_enum flush)
  199. {
  200. int ret;
  201. if (num_bytes == 0)
  202. return 0;
  203. ret = btrfs_reserve_metadata_bytes(block_rsv->space_info, num_bytes, flush);
  204. if (!ret)
  205. btrfs_block_rsv_add_bytes(block_rsv, num_bytes, true);
  206. return ret;
  207. }
  208. int btrfs_block_rsv_check(struct btrfs_block_rsv *block_rsv, int min_percent)
  209. {
  210. u64 num_bytes = 0;
  211. int ret = -ENOSPC;
  212. spin_lock(&block_rsv->lock);
  213. num_bytes = mult_perc(block_rsv->size, min_percent);
  214. if (block_rsv->reserved >= num_bytes)
  215. ret = 0;
  216. spin_unlock(&block_rsv->lock);
  217. return ret;
  218. }
  219. int btrfs_block_rsv_refill(struct btrfs_fs_info *fs_info,
  220. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  221. enum btrfs_reserve_flush_enum flush)
  222. {
  223. int ret = -ENOSPC;
  224. if (!block_rsv)
  225. return 0;
  226. spin_lock(&block_rsv->lock);
  227. if (block_rsv->reserved >= num_bytes)
  228. ret = 0;
  229. else
  230. num_bytes -= block_rsv->reserved;
  231. spin_unlock(&block_rsv->lock);
  232. if (!ret)
  233. return 0;
  234. ret = btrfs_reserve_metadata_bytes(block_rsv->space_info, num_bytes, flush);
  235. if (!ret) {
  236. btrfs_block_rsv_add_bytes(block_rsv, num_bytes, false);
  237. return 0;
  238. }
  239. return ret;
  240. }
  241. u64 btrfs_block_rsv_release(struct btrfs_fs_info *fs_info,
  242. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  243. u64 *qgroup_to_release)
  244. {
  245. struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv;
  246. struct btrfs_block_rsv *delayed_rsv = &fs_info->delayed_refs_rsv;
  247. struct btrfs_block_rsv *target = NULL;
  248. /*
  249. * If we are a delayed refs block reserve then push to the global
  250. * reserve, otherwise dump into the global delayed refs reserve if it is
  251. * not full.
  252. */
  253. if (block_rsv->type == BTRFS_BLOCK_RSV_DELREFS)
  254. target = global_rsv;
  255. else if (block_rsv != global_rsv && !btrfs_block_rsv_full(delayed_rsv))
  256. target = delayed_rsv;
  257. if (target && block_rsv->space_info != target->space_info)
  258. target = NULL;
  259. return block_rsv_release_bytes(fs_info, block_rsv, target, num_bytes,
  260. qgroup_to_release);
  261. }
  262. int btrfs_block_rsv_use_bytes(struct btrfs_block_rsv *block_rsv, u64 num_bytes)
  263. {
  264. int ret = -ENOSPC;
  265. spin_lock(&block_rsv->lock);
  266. if (block_rsv->reserved >= num_bytes) {
  267. block_rsv->reserved -= num_bytes;
  268. if (block_rsv->reserved < block_rsv->size)
  269. block_rsv->full = false;
  270. ret = 0;
  271. }
  272. spin_unlock(&block_rsv->lock);
  273. return ret;
  274. }
  275. void btrfs_block_rsv_add_bytes(struct btrfs_block_rsv *block_rsv,
  276. u64 num_bytes, bool update_size)
  277. {
  278. spin_lock(&block_rsv->lock);
  279. block_rsv->reserved += num_bytes;
  280. if (update_size)
  281. block_rsv->size += num_bytes;
  282. else if (block_rsv->reserved >= block_rsv->size)
  283. block_rsv->full = true;
  284. spin_unlock(&block_rsv->lock);
  285. }
  286. void btrfs_update_global_block_rsv(struct btrfs_fs_info *fs_info)
  287. {
  288. struct btrfs_block_rsv *block_rsv = &fs_info->global_block_rsv;
  289. struct btrfs_space_info *sinfo = block_rsv->space_info;
  290. struct btrfs_root *root, *tmp;
  291. u64 num_bytes = btrfs_root_used(&fs_info->tree_root->root_item);
  292. unsigned int min_items = 1;
  293. /*
  294. * The global block rsv is based on the size of the extent tree, the
  295. * checksum tree and the root tree. If the fs is empty we want to set
  296. * it to a minimal amount for safety.
  297. *
  298. * We also are going to need to modify the minimum of the tree root and
  299. * any global roots we could touch.
  300. */
  301. read_lock(&fs_info->global_root_lock);
  302. rbtree_postorder_for_each_entry_safe(root, tmp, &fs_info->global_root_tree,
  303. rb_node) {
  304. if (btrfs_root_id(root) == BTRFS_EXTENT_TREE_OBJECTID ||
  305. btrfs_root_id(root) == BTRFS_CSUM_TREE_OBJECTID ||
  306. btrfs_root_id(root) == BTRFS_FREE_SPACE_TREE_OBJECTID) {
  307. num_bytes += btrfs_root_used(&root->root_item);
  308. min_items++;
  309. }
  310. }
  311. read_unlock(&fs_info->global_root_lock);
  312. if (btrfs_fs_compat_ro(fs_info, BLOCK_GROUP_TREE)) {
  313. num_bytes += btrfs_root_used(&fs_info->block_group_root->root_item);
  314. min_items++;
  315. }
  316. if (btrfs_fs_incompat(fs_info, RAID_STRIPE_TREE)) {
  317. num_bytes += btrfs_root_used(&fs_info->stripe_root->root_item);
  318. min_items++;
  319. }
  320. /*
  321. * But we also want to reserve enough space so we can do the fallback
  322. * global reserve for an unlink, which is an additional
  323. * BTRFS_UNLINK_METADATA_UNITS items.
  324. *
  325. * But we also need space for the delayed ref updates from the unlink,
  326. * so add BTRFS_UNLINK_METADATA_UNITS units for delayed refs, one for
  327. * each unlink metadata item.
  328. */
  329. min_items += BTRFS_UNLINK_METADATA_UNITS;
  330. num_bytes = max_t(u64, num_bytes,
  331. btrfs_calc_insert_metadata_size(fs_info, min_items) +
  332. btrfs_calc_delayed_ref_bytes(fs_info,
  333. BTRFS_UNLINK_METADATA_UNITS));
  334. spin_lock(&sinfo->lock);
  335. spin_lock(&block_rsv->lock);
  336. block_rsv->size = min_t(u64, num_bytes, SZ_512M);
  337. if (block_rsv->reserved < block_rsv->size) {
  338. num_bytes = block_rsv->size - block_rsv->reserved;
  339. btrfs_space_info_update_bytes_may_use(sinfo, num_bytes);
  340. block_rsv->reserved = block_rsv->size;
  341. } else if (block_rsv->reserved > block_rsv->size) {
  342. num_bytes = block_rsv->reserved - block_rsv->size;
  343. btrfs_space_info_update_bytes_may_use(sinfo, -num_bytes);
  344. block_rsv->reserved = block_rsv->size;
  345. btrfs_try_granting_tickets(sinfo);
  346. }
  347. block_rsv->full = (block_rsv->reserved == block_rsv->size);
  348. if (block_rsv->size >= sinfo->total_bytes)
  349. sinfo->force_alloc = CHUNK_ALLOC_FORCE;
  350. spin_unlock(&block_rsv->lock);
  351. spin_unlock(&sinfo->lock);
  352. }
  353. void btrfs_init_root_block_rsv(struct btrfs_root *root)
  354. {
  355. struct btrfs_fs_info *fs_info = root->fs_info;
  356. switch (btrfs_root_id(root)) {
  357. case BTRFS_CSUM_TREE_OBJECTID:
  358. case BTRFS_EXTENT_TREE_OBJECTID:
  359. case BTRFS_FREE_SPACE_TREE_OBJECTID:
  360. case BTRFS_BLOCK_GROUP_TREE_OBJECTID:
  361. case BTRFS_RAID_STRIPE_TREE_OBJECTID:
  362. root->block_rsv = &fs_info->delayed_refs_rsv;
  363. break;
  364. case BTRFS_ROOT_TREE_OBJECTID:
  365. case BTRFS_DEV_TREE_OBJECTID:
  366. case BTRFS_QUOTA_TREE_OBJECTID:
  367. root->block_rsv = &fs_info->global_block_rsv;
  368. break;
  369. case BTRFS_CHUNK_TREE_OBJECTID:
  370. root->block_rsv = &fs_info->chunk_block_rsv;
  371. break;
  372. case BTRFS_TREE_LOG_OBJECTID:
  373. root->block_rsv = &fs_info->treelog_rsv;
  374. break;
  375. case BTRFS_REMAP_TREE_OBJECTID:
  376. root->block_rsv = &fs_info->remap_block_rsv;
  377. break;
  378. default:
  379. root->block_rsv = NULL;
  380. break;
  381. }
  382. }
  383. void btrfs_init_global_block_rsv(struct btrfs_fs_info *fs_info)
  384. {
  385. struct btrfs_space_info *space_info;
  386. space_info = btrfs_find_space_info(fs_info, BTRFS_BLOCK_GROUP_SYSTEM);
  387. fs_info->chunk_block_rsv.space_info = space_info;
  388. space_info = btrfs_find_space_info(fs_info, BTRFS_BLOCK_GROUP_METADATA_REMAP);
  389. fs_info->remap_block_rsv.space_info = space_info;
  390. space_info = btrfs_find_space_info(fs_info, BTRFS_BLOCK_GROUP_METADATA);
  391. fs_info->global_block_rsv.space_info = space_info;
  392. fs_info->trans_block_rsv.space_info = space_info;
  393. fs_info->empty_block_rsv.space_info = space_info;
  394. fs_info->delayed_block_rsv.space_info = space_info;
  395. fs_info->delayed_refs_rsv.space_info = space_info;
  396. /* The treelog_rsv uses a dedicated space_info on the zoned mode. */
  397. if (!btrfs_is_zoned(fs_info)) {
  398. fs_info->treelog_rsv.space_info = space_info;
  399. } else {
  400. ASSERT(space_info->sub_group[0]->subgroup_id == BTRFS_SUB_GROUP_TREELOG);
  401. fs_info->treelog_rsv.space_info = space_info->sub_group[0];
  402. }
  403. btrfs_update_global_block_rsv(fs_info);
  404. }
  405. void btrfs_release_global_block_rsv(struct btrfs_fs_info *fs_info)
  406. {
  407. btrfs_block_rsv_release(fs_info, &fs_info->global_block_rsv, (u64)-1,
  408. NULL);
  409. WARN_ON(fs_info->trans_block_rsv.size > 0);
  410. WARN_ON(fs_info->trans_block_rsv.reserved > 0);
  411. WARN_ON(fs_info->chunk_block_rsv.size > 0);
  412. WARN_ON(fs_info->chunk_block_rsv.reserved > 0);
  413. WARN_ON(fs_info->remap_block_rsv.size > 0);
  414. WARN_ON(fs_info->remap_block_rsv.reserved > 0);
  415. WARN_ON(fs_info->delayed_block_rsv.size > 0);
  416. WARN_ON(fs_info->delayed_block_rsv.reserved > 0);
  417. WARN_ON(fs_info->delayed_refs_rsv.reserved > 0);
  418. WARN_ON(fs_info->delayed_refs_rsv.size > 0);
  419. }
  420. static struct btrfs_block_rsv *get_block_rsv(
  421. const struct btrfs_trans_handle *trans,
  422. const struct btrfs_root *root)
  423. {
  424. struct btrfs_fs_info *fs_info = root->fs_info;
  425. struct btrfs_block_rsv *block_rsv = NULL;
  426. if (test_bit(BTRFS_ROOT_SHAREABLE, &root->state) ||
  427. (root == fs_info->uuid_root) ||
  428. (trans->adding_csums && btrfs_root_id(root) == BTRFS_CSUM_TREE_OBJECTID))
  429. block_rsv = trans->block_rsv;
  430. if (!block_rsv)
  431. block_rsv = root->block_rsv;
  432. if (!block_rsv)
  433. block_rsv = &fs_info->empty_block_rsv;
  434. return block_rsv;
  435. }
  436. struct btrfs_block_rsv *btrfs_use_block_rsv(struct btrfs_trans_handle *trans,
  437. struct btrfs_root *root,
  438. u32 blocksize)
  439. {
  440. struct btrfs_fs_info *fs_info = root->fs_info;
  441. struct btrfs_block_rsv *block_rsv;
  442. struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv;
  443. int ret;
  444. bool global_updated = false;
  445. block_rsv = get_block_rsv(trans, root);
  446. if (unlikely(btrfs_block_rsv_size(block_rsv) == 0))
  447. goto try_reserve;
  448. again:
  449. ret = btrfs_block_rsv_use_bytes(block_rsv, blocksize);
  450. if (!ret)
  451. return block_rsv;
  452. if (block_rsv->failfast)
  453. return ERR_PTR(ret);
  454. if (block_rsv->type == BTRFS_BLOCK_RSV_GLOBAL && !global_updated) {
  455. global_updated = true;
  456. btrfs_update_global_block_rsv(fs_info);
  457. goto again;
  458. }
  459. /*
  460. * The global reserve still exists to save us from ourselves, so don't
  461. * warn_on if we are short on our delayed refs reserve.
  462. */
  463. if (block_rsv->type != BTRFS_BLOCK_RSV_DELREFS &&
  464. btrfs_test_opt(fs_info, ENOSPC_DEBUG)) {
  465. static DEFINE_RATELIMIT_STATE(_rs,
  466. DEFAULT_RATELIMIT_INTERVAL * 10,
  467. /*DEFAULT_RATELIMIT_BURST*/ 1);
  468. if (__ratelimit(&_rs))
  469. WARN(1, KERN_DEBUG
  470. "BTRFS: block rsv %d returned %d\n",
  471. block_rsv->type, ret);
  472. }
  473. try_reserve:
  474. ret = btrfs_reserve_metadata_bytes(block_rsv->space_info, blocksize,
  475. BTRFS_RESERVE_NO_FLUSH);
  476. if (!ret)
  477. return block_rsv;
  478. /*
  479. * If we couldn't reserve metadata bytes try and use some from
  480. * the global reserve if its space type is the same as the global
  481. * reservation.
  482. */
  483. if (block_rsv->type != BTRFS_BLOCK_RSV_GLOBAL &&
  484. block_rsv->space_info == global_rsv->space_info) {
  485. ret = btrfs_block_rsv_use_bytes(global_rsv, blocksize);
  486. if (!ret)
  487. return global_rsv;
  488. }
  489. /*
  490. * All hope is lost, but of course our reservations are overly
  491. * pessimistic, so instead of possibly having an ENOSPC abort here, try
  492. * one last time to force a reservation if there's enough actual space
  493. * on disk to make the reservation.
  494. */
  495. ret = btrfs_reserve_metadata_bytes(block_rsv->space_info, blocksize,
  496. BTRFS_RESERVE_FLUSH_EMERGENCY);
  497. if (!ret)
  498. return block_rsv;
  499. return ERR_PTR(ret);
  500. }
  501. int btrfs_check_trunc_cache_free_space(const struct btrfs_fs_info *fs_info,
  502. struct btrfs_block_rsv *rsv)
  503. {
  504. u64 needed_bytes;
  505. int ret;
  506. /* 1 for slack space, 1 for updating the inode */
  507. needed_bytes = btrfs_calc_insert_metadata_size(fs_info, 1) +
  508. btrfs_calc_metadata_size(fs_info, 1);
  509. spin_lock(&rsv->lock);
  510. if (rsv->reserved < needed_bytes)
  511. ret = -ENOSPC;
  512. else
  513. ret = 0;
  514. spin_unlock(&rsv->lock);
  515. return ret;
  516. }