block-rsv.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573
  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(fs_info,
  148. space_info,
  149. num_bytes);
  150. }
  151. if (qgroup_to_release_ret)
  152. *qgroup_to_release_ret = qgroup_to_release;
  153. return ret;
  154. }
  155. int btrfs_block_rsv_migrate(struct btrfs_block_rsv *src,
  156. struct btrfs_block_rsv *dst, u64 num_bytes,
  157. bool update_size)
  158. {
  159. int ret;
  160. ret = btrfs_block_rsv_use_bytes(src, num_bytes);
  161. if (ret)
  162. return ret;
  163. btrfs_block_rsv_add_bytes(dst, num_bytes, update_size);
  164. return 0;
  165. }
  166. void btrfs_init_block_rsv(struct btrfs_block_rsv *rsv, enum btrfs_rsv_type type)
  167. {
  168. memset(rsv, 0, sizeof(*rsv));
  169. spin_lock_init(&rsv->lock);
  170. rsv->type = type;
  171. }
  172. void btrfs_init_metadata_block_rsv(struct btrfs_fs_info *fs_info,
  173. struct btrfs_block_rsv *rsv,
  174. enum btrfs_rsv_type type)
  175. {
  176. btrfs_init_block_rsv(rsv, type);
  177. rsv->space_info = btrfs_find_space_info(fs_info,
  178. BTRFS_BLOCK_GROUP_METADATA);
  179. }
  180. struct btrfs_block_rsv *btrfs_alloc_block_rsv(struct btrfs_fs_info *fs_info,
  181. enum btrfs_rsv_type type)
  182. {
  183. struct btrfs_block_rsv *block_rsv;
  184. block_rsv = kmalloc(sizeof(*block_rsv), GFP_NOFS);
  185. if (!block_rsv)
  186. return NULL;
  187. btrfs_init_metadata_block_rsv(fs_info, block_rsv, type);
  188. return block_rsv;
  189. }
  190. void btrfs_free_block_rsv(struct btrfs_fs_info *fs_info,
  191. struct btrfs_block_rsv *rsv)
  192. {
  193. if (!rsv)
  194. return;
  195. btrfs_block_rsv_release(fs_info, rsv, (u64)-1, NULL);
  196. kfree(rsv);
  197. }
  198. int btrfs_block_rsv_add(struct btrfs_fs_info *fs_info,
  199. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  200. enum btrfs_reserve_flush_enum flush)
  201. {
  202. int ret;
  203. if (num_bytes == 0)
  204. return 0;
  205. ret = btrfs_reserve_metadata_bytes(fs_info, block_rsv->space_info,
  206. num_bytes, flush);
  207. if (!ret)
  208. btrfs_block_rsv_add_bytes(block_rsv, num_bytes, true);
  209. return ret;
  210. }
  211. int btrfs_block_rsv_check(struct btrfs_block_rsv *block_rsv, int min_percent)
  212. {
  213. u64 num_bytes = 0;
  214. int ret = -ENOSPC;
  215. spin_lock(&block_rsv->lock);
  216. num_bytes = mult_perc(block_rsv->size, min_percent);
  217. if (block_rsv->reserved >= num_bytes)
  218. ret = 0;
  219. spin_unlock(&block_rsv->lock);
  220. return ret;
  221. }
  222. int btrfs_block_rsv_refill(struct btrfs_fs_info *fs_info,
  223. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  224. enum btrfs_reserve_flush_enum flush)
  225. {
  226. int ret = -ENOSPC;
  227. if (!block_rsv)
  228. return 0;
  229. spin_lock(&block_rsv->lock);
  230. if (block_rsv->reserved >= num_bytes)
  231. ret = 0;
  232. else
  233. num_bytes -= block_rsv->reserved;
  234. spin_unlock(&block_rsv->lock);
  235. if (!ret)
  236. return 0;
  237. ret = btrfs_reserve_metadata_bytes(fs_info, block_rsv->space_info,
  238. num_bytes, flush);
  239. if (!ret) {
  240. btrfs_block_rsv_add_bytes(block_rsv, num_bytes, false);
  241. return 0;
  242. }
  243. return ret;
  244. }
  245. u64 btrfs_block_rsv_release(struct btrfs_fs_info *fs_info,
  246. struct btrfs_block_rsv *block_rsv, u64 num_bytes,
  247. u64 *qgroup_to_release)
  248. {
  249. struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv;
  250. struct btrfs_block_rsv *delayed_rsv = &fs_info->delayed_refs_rsv;
  251. struct btrfs_block_rsv *target = NULL;
  252. /*
  253. * If we are a delayed block reserve then push to the global rsv,
  254. * otherwise dump into the global delayed reserve if it is not full.
  255. */
  256. if (block_rsv->type == BTRFS_BLOCK_RSV_DELOPS)
  257. target = global_rsv;
  258. else if (block_rsv != global_rsv && !btrfs_block_rsv_full(delayed_rsv))
  259. target = delayed_rsv;
  260. if (target && block_rsv->space_info != target->space_info)
  261. target = NULL;
  262. return block_rsv_release_bytes(fs_info, block_rsv, target, num_bytes,
  263. qgroup_to_release);
  264. }
  265. int btrfs_block_rsv_use_bytes(struct btrfs_block_rsv *block_rsv, u64 num_bytes)
  266. {
  267. int ret = -ENOSPC;
  268. spin_lock(&block_rsv->lock);
  269. if (block_rsv->reserved >= num_bytes) {
  270. block_rsv->reserved -= num_bytes;
  271. if (block_rsv->reserved < block_rsv->size)
  272. block_rsv->full = false;
  273. ret = 0;
  274. }
  275. spin_unlock(&block_rsv->lock);
  276. return ret;
  277. }
  278. void btrfs_block_rsv_add_bytes(struct btrfs_block_rsv *block_rsv,
  279. u64 num_bytes, bool update_size)
  280. {
  281. spin_lock(&block_rsv->lock);
  282. block_rsv->reserved += num_bytes;
  283. if (update_size)
  284. block_rsv->size += num_bytes;
  285. else if (block_rsv->reserved >= block_rsv->size)
  286. block_rsv->full = true;
  287. spin_unlock(&block_rsv->lock);
  288. }
  289. void btrfs_update_global_block_rsv(struct btrfs_fs_info *fs_info)
  290. {
  291. struct btrfs_block_rsv *block_rsv = &fs_info->global_block_rsv;
  292. struct btrfs_space_info *sinfo = block_rsv->space_info;
  293. struct btrfs_root *root, *tmp;
  294. u64 num_bytes = btrfs_root_used(&fs_info->tree_root->root_item);
  295. unsigned int min_items = 1;
  296. /*
  297. * The global block rsv is based on the size of the extent tree, the
  298. * checksum tree and the root tree. If the fs is empty we want to set
  299. * it to a minimal amount for safety.
  300. *
  301. * We also are going to need to modify the minimum of the tree root and
  302. * any global roots we could touch.
  303. */
  304. read_lock(&fs_info->global_root_lock);
  305. rbtree_postorder_for_each_entry_safe(root, tmp, &fs_info->global_root_tree,
  306. rb_node) {
  307. if (btrfs_root_id(root) == BTRFS_EXTENT_TREE_OBJECTID ||
  308. btrfs_root_id(root) == BTRFS_CSUM_TREE_OBJECTID ||
  309. btrfs_root_id(root) == BTRFS_FREE_SPACE_TREE_OBJECTID) {
  310. num_bytes += btrfs_root_used(&root->root_item);
  311. min_items++;
  312. }
  313. }
  314. read_unlock(&fs_info->global_root_lock);
  315. if (btrfs_fs_compat_ro(fs_info, BLOCK_GROUP_TREE)) {
  316. num_bytes += btrfs_root_used(&fs_info->block_group_root->root_item);
  317. min_items++;
  318. }
  319. if (btrfs_fs_incompat(fs_info, RAID_STRIPE_TREE)) {
  320. num_bytes += btrfs_root_used(&fs_info->stripe_root->root_item);
  321. min_items++;
  322. }
  323. /*
  324. * But we also want to reserve enough space so we can do the fallback
  325. * global reserve for an unlink, which is an additional
  326. * BTRFS_UNLINK_METADATA_UNITS items.
  327. *
  328. * But we also need space for the delayed ref updates from the unlink,
  329. * so add BTRFS_UNLINK_METADATA_UNITS units for delayed refs, one for
  330. * each unlink metadata item.
  331. */
  332. min_items += BTRFS_UNLINK_METADATA_UNITS;
  333. num_bytes = max_t(u64, num_bytes,
  334. btrfs_calc_insert_metadata_size(fs_info, min_items) +
  335. btrfs_calc_delayed_ref_bytes(fs_info,
  336. BTRFS_UNLINK_METADATA_UNITS));
  337. spin_lock(&sinfo->lock);
  338. spin_lock(&block_rsv->lock);
  339. block_rsv->size = min_t(u64, num_bytes, SZ_512M);
  340. if (block_rsv->reserved < block_rsv->size) {
  341. num_bytes = block_rsv->size - block_rsv->reserved;
  342. btrfs_space_info_update_bytes_may_use(fs_info, sinfo,
  343. num_bytes);
  344. block_rsv->reserved = block_rsv->size;
  345. } else if (block_rsv->reserved > block_rsv->size) {
  346. num_bytes = block_rsv->reserved - block_rsv->size;
  347. btrfs_space_info_update_bytes_may_use(fs_info, sinfo,
  348. -num_bytes);
  349. block_rsv->reserved = block_rsv->size;
  350. btrfs_try_granting_tickets(fs_info, sinfo);
  351. }
  352. block_rsv->full = (block_rsv->reserved == block_rsv->size);
  353. if (block_rsv->size >= sinfo->total_bytes)
  354. sinfo->force_alloc = CHUNK_ALLOC_FORCE;
  355. spin_unlock(&block_rsv->lock);
  356. spin_unlock(&sinfo->lock);
  357. }
  358. void btrfs_init_root_block_rsv(struct btrfs_root *root)
  359. {
  360. struct btrfs_fs_info *fs_info = root->fs_info;
  361. switch (btrfs_root_id(root)) {
  362. case BTRFS_CSUM_TREE_OBJECTID:
  363. case BTRFS_EXTENT_TREE_OBJECTID:
  364. case BTRFS_FREE_SPACE_TREE_OBJECTID:
  365. case BTRFS_BLOCK_GROUP_TREE_OBJECTID:
  366. case BTRFS_RAID_STRIPE_TREE_OBJECTID:
  367. root->block_rsv = &fs_info->delayed_refs_rsv;
  368. break;
  369. case BTRFS_ROOT_TREE_OBJECTID:
  370. case BTRFS_DEV_TREE_OBJECTID:
  371. case BTRFS_QUOTA_TREE_OBJECTID:
  372. root->block_rsv = &fs_info->global_block_rsv;
  373. break;
  374. case BTRFS_CHUNK_TREE_OBJECTID:
  375. root->block_rsv = &fs_info->chunk_block_rsv;
  376. break;
  377. default:
  378. root->block_rsv = NULL;
  379. break;
  380. }
  381. }
  382. void btrfs_init_global_block_rsv(struct btrfs_fs_info *fs_info)
  383. {
  384. struct btrfs_space_info *space_info;
  385. space_info = btrfs_find_space_info(fs_info, BTRFS_BLOCK_GROUP_SYSTEM);
  386. fs_info->chunk_block_rsv.space_info = space_info;
  387. space_info = btrfs_find_space_info(fs_info, BTRFS_BLOCK_GROUP_METADATA);
  388. fs_info->global_block_rsv.space_info = space_info;
  389. fs_info->trans_block_rsv.space_info = space_info;
  390. fs_info->empty_block_rsv.space_info = space_info;
  391. fs_info->delayed_block_rsv.space_info = space_info;
  392. fs_info->delayed_refs_rsv.space_info = space_info;
  393. btrfs_update_global_block_rsv(fs_info);
  394. }
  395. void btrfs_release_global_block_rsv(struct btrfs_fs_info *fs_info)
  396. {
  397. btrfs_block_rsv_release(fs_info, &fs_info->global_block_rsv, (u64)-1,
  398. NULL);
  399. WARN_ON(fs_info->trans_block_rsv.size > 0);
  400. WARN_ON(fs_info->trans_block_rsv.reserved > 0);
  401. WARN_ON(fs_info->chunk_block_rsv.size > 0);
  402. WARN_ON(fs_info->chunk_block_rsv.reserved > 0);
  403. WARN_ON(fs_info->delayed_block_rsv.size > 0);
  404. WARN_ON(fs_info->delayed_block_rsv.reserved > 0);
  405. WARN_ON(fs_info->delayed_refs_rsv.reserved > 0);
  406. WARN_ON(fs_info->delayed_refs_rsv.size > 0);
  407. }
  408. static struct btrfs_block_rsv *get_block_rsv(
  409. const struct btrfs_trans_handle *trans,
  410. const struct btrfs_root *root)
  411. {
  412. struct btrfs_fs_info *fs_info = root->fs_info;
  413. struct btrfs_block_rsv *block_rsv = NULL;
  414. if (test_bit(BTRFS_ROOT_SHAREABLE, &root->state) ||
  415. (root == fs_info->uuid_root) ||
  416. (trans->adding_csums && btrfs_root_id(root) == BTRFS_CSUM_TREE_OBJECTID))
  417. block_rsv = trans->block_rsv;
  418. if (!block_rsv)
  419. block_rsv = root->block_rsv;
  420. if (!block_rsv)
  421. block_rsv = &fs_info->empty_block_rsv;
  422. return block_rsv;
  423. }
  424. struct btrfs_block_rsv *btrfs_use_block_rsv(struct btrfs_trans_handle *trans,
  425. struct btrfs_root *root,
  426. u32 blocksize)
  427. {
  428. struct btrfs_fs_info *fs_info = root->fs_info;
  429. struct btrfs_block_rsv *block_rsv;
  430. struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv;
  431. int ret;
  432. bool global_updated = false;
  433. block_rsv = get_block_rsv(trans, root);
  434. if (unlikely(btrfs_block_rsv_size(block_rsv) == 0))
  435. goto try_reserve;
  436. again:
  437. ret = btrfs_block_rsv_use_bytes(block_rsv, blocksize);
  438. if (!ret)
  439. return block_rsv;
  440. if (block_rsv->failfast)
  441. return ERR_PTR(ret);
  442. if (block_rsv->type == BTRFS_BLOCK_RSV_GLOBAL && !global_updated) {
  443. global_updated = true;
  444. btrfs_update_global_block_rsv(fs_info);
  445. goto again;
  446. }
  447. /*
  448. * The global reserve still exists to save us from ourselves, so don't
  449. * warn_on if we are short on our delayed refs reserve.
  450. */
  451. if (block_rsv->type != BTRFS_BLOCK_RSV_DELREFS &&
  452. btrfs_test_opt(fs_info, ENOSPC_DEBUG)) {
  453. static DEFINE_RATELIMIT_STATE(_rs,
  454. DEFAULT_RATELIMIT_INTERVAL * 10,
  455. /*DEFAULT_RATELIMIT_BURST*/ 1);
  456. if (__ratelimit(&_rs))
  457. WARN(1, KERN_DEBUG
  458. "BTRFS: block rsv %d returned %d\n",
  459. block_rsv->type, ret);
  460. }
  461. try_reserve:
  462. ret = btrfs_reserve_metadata_bytes(fs_info, block_rsv->space_info,
  463. blocksize, BTRFS_RESERVE_NO_FLUSH);
  464. if (!ret)
  465. return block_rsv;
  466. /*
  467. * If we couldn't reserve metadata bytes try and use some from
  468. * the global reserve if its space type is the same as the global
  469. * reservation.
  470. */
  471. if (block_rsv->type != BTRFS_BLOCK_RSV_GLOBAL &&
  472. block_rsv->space_info == global_rsv->space_info) {
  473. ret = btrfs_block_rsv_use_bytes(global_rsv, blocksize);
  474. if (!ret)
  475. return global_rsv;
  476. }
  477. /*
  478. * All hope is lost, but of course our reservations are overly
  479. * pessimistic, so instead of possibly having an ENOSPC abort here, try
  480. * one last time to force a reservation if there's enough actual space
  481. * on disk to make the reservation.
  482. */
  483. ret = btrfs_reserve_metadata_bytes(fs_info, block_rsv->space_info, blocksize,
  484. BTRFS_RESERVE_FLUSH_EMERGENCY);
  485. if (!ret)
  486. return block_rsv;
  487. return ERR_PTR(ret);
  488. }
  489. int btrfs_check_trunc_cache_free_space(const struct btrfs_fs_info *fs_info,
  490. struct btrfs_block_rsv *rsv)
  491. {
  492. u64 needed_bytes;
  493. int ret;
  494. /* 1 for slack space, 1 for updating the inode */
  495. needed_bytes = btrfs_calc_insert_metadata_size(fs_info, 1) +
  496. btrfs_calc_metadata_size(fs_info, 1);
  497. spin_lock(&rsv->lock);
  498. if (rsv->reserved < needed_bytes)
  499. ret = -ENOSPC;
  500. else
  501. ret = 0;
  502. spin_unlock(&rsv->lock);
  503. return ret;
  504. }