Commit | Line | Data |
---|---|---|
6cbd5570 CM |
1 | /* |
2 | * Copyright (C) 2007 Oracle. All rights reserved. | |
3 | * | |
4 | * This program is free software; you can redistribute it and/or | |
5 | * modify it under the terms of the GNU General Public | |
6 | * License v2 as published by the Free Software Foundation. | |
7 | * | |
8 | * This program is distributed in the hope that it will be useful, | |
9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
11 | * General Public License for more details. | |
12 | * | |
13 | * You should have received a copy of the GNU General Public | |
14 | * License along with this program; if not, write to the | |
15 | * Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
16 | * Boston, MA 021110-1307, USA. | |
17 | */ | |
18 | ||
dc17ff8f CM |
19 | #ifndef __BTRFS_TRANSACTION__ |
20 | #define __BTRFS_TRANSACTION__ | |
31f3c99b | 21 | #include "btrfs_inode.h" |
56bec294 | 22 | #include "delayed-ref.h" |
e089f05c | 23 | |
79154b1b CM |
24 | struct btrfs_transaction { |
25 | u64 transid; | |
b7ec40d7 CM |
26 | /* |
27 | * total writers in this transaction, it must be zero before the | |
28 | * transaction can end | |
29 | */ | |
13c5a93e | 30 | atomic_t num_writers; |
a4abeea4 | 31 | atomic_t use_count; |
b7ec40d7 | 32 | |
15ee9bc7 | 33 | unsigned long num_joined; |
a4abeea4 JB |
34 | |
35 | spinlock_t commit_lock; | |
79154b1b | 36 | int in_commit; |
79154b1b | 37 | int commit_done; |
f9295749 | 38 | int blocked; |
8fd17795 | 39 | struct list_head list; |
d1310b2e | 40 | struct extent_io_tree dirty_pages; |
08607c1b | 41 | unsigned long start_time; |
79154b1b CM |
42 | wait_queue_head_t writer_wait; |
43 | wait_queue_head_t commit_wait; | |
3063d29f | 44 | struct list_head pending_snapshots; |
56bec294 | 45 | struct btrfs_delayed_ref_root delayed_refs; |
49b25e05 | 46 | int aborted; |
79154b1b CM |
47 | }; |
48 | ||
e089f05c CM |
49 | struct btrfs_trans_handle { |
50 | u64 transid; | |
f0486c68 | 51 | u64 bytes_reserved; |
2a1eb461 | 52 | unsigned long use_count; |
e089f05c CM |
53 | unsigned long blocks_reserved; |
54 | unsigned long blocks_used; | |
56bec294 | 55 | unsigned long delayed_ref_updates; |
f0486c68 YZ |
56 | struct btrfs_transaction *transaction; |
57 | struct btrfs_block_rsv *block_rsv; | |
2a1eb461 | 58 | struct btrfs_block_rsv *orig_rsv; |
49b25e05 | 59 | int aborted; |
e089f05c CM |
60 | }; |
61 | ||
3063d29f | 62 | struct btrfs_pending_snapshot { |
3de4586c | 63 | struct dentry *dentry; |
3063d29f | 64 | struct btrfs_root *root; |
a22285a6 YZ |
65 | struct btrfs_root *snap; |
66 | /* block reservation for the operation */ | |
67 | struct btrfs_block_rsv block_rsv; | |
68 | /* extra metadata reseration for relocation */ | |
69 | int error; | |
b83cc969 | 70 | bool readonly; |
3063d29f CM |
71 | struct list_head list; |
72 | }; | |
73 | ||
15ee9bc7 JB |
74 | static inline void btrfs_set_inode_last_trans(struct btrfs_trans_handle *trans, |
75 | struct inode *inode) | |
76 | { | |
77 | BTRFS_I(inode)->last_trans = trans->transaction->transid; | |
257c62e1 | 78 | BTRFS_I(inode)->last_sub_trans = BTRFS_I(inode)->root->log_transid; |
15ee9bc7 JB |
79 | } |
80 | ||
79154b1b CM |
81 | int btrfs_end_transaction(struct btrfs_trans_handle *trans, |
82 | struct btrfs_root *root); | |
0af3d00b JB |
83 | int btrfs_end_transaction_nolock(struct btrfs_trans_handle *trans, |
84 | struct btrfs_root *root); | |
79154b1b | 85 | struct btrfs_trans_handle *btrfs_start_transaction(struct btrfs_root *root, |
a22285a6 | 86 | int num_items); |
7a7eaa40 JB |
87 | struct btrfs_trans_handle *btrfs_join_transaction(struct btrfs_root *root); |
88 | struct btrfs_trans_handle *btrfs_join_transaction_nolock(struct btrfs_root *root); | |
89 | struct btrfs_trans_handle *btrfs_start_ioctl_transaction(struct btrfs_root *root); | |
46204592 | 90 | int btrfs_wait_for_commit(struct btrfs_root *root, u64 transid); |
79154b1b CM |
91 | int btrfs_write_and_wait_transaction(struct btrfs_trans_handle *trans, |
92 | struct btrfs_root *root); | |
08607c1b | 93 | |
5d4f98a2 | 94 | int btrfs_add_dead_root(struct btrfs_root *root); |
e9d0b13b CM |
95 | int btrfs_defrag_root(struct btrfs_root *root, int cacheonly); |
96 | int btrfs_clean_old_snapshots(struct btrfs_root *root); | |
5f39d397 CM |
97 | int btrfs_commit_transaction(struct btrfs_trans_handle *trans, |
98 | struct btrfs_root *root); | |
bb9c12c9 SW |
99 | int btrfs_commit_transaction_async(struct btrfs_trans_handle *trans, |
100 | struct btrfs_root *root, | |
101 | int wait_for_unblock); | |
89ce8a63 CM |
102 | int btrfs_end_transaction_throttle(struct btrfs_trans_handle *trans, |
103 | struct btrfs_root *root); | |
16cdcec7 MX |
104 | int btrfs_end_transaction_dmeta(struct btrfs_trans_handle *trans, |
105 | struct btrfs_root *root); | |
8929ecfa YZ |
106 | int btrfs_should_end_transaction(struct btrfs_trans_handle *trans, |
107 | struct btrfs_root *root); | |
ab78c84d | 108 | void btrfs_throttle(struct btrfs_root *root); |
5d4f98a2 YZ |
109 | int btrfs_record_root_in_trans(struct btrfs_trans_handle *trans, |
110 | struct btrfs_root *root); | |
d0c803c4 | 111 | int btrfs_write_and_wait_marked_extents(struct btrfs_root *root, |
8cef4e16 | 112 | struct extent_io_tree *dirty_pages, int mark); |
690587d1 | 113 | int btrfs_write_marked_extents(struct btrfs_root *root, |
8cef4e16 | 114 | struct extent_io_tree *dirty_pages, int mark); |
690587d1 | 115 | int btrfs_wait_marked_extents(struct btrfs_root *root, |
8cef4e16 | 116 | struct extent_io_tree *dirty_pages, int mark); |
8929ecfa | 117 | int btrfs_transaction_blocked(struct btrfs_fs_info *info); |
f36f3042 | 118 | int btrfs_transaction_in_commit(struct btrfs_fs_info *info); |
49b25e05 | 119 | void put_transaction(struct btrfs_transaction *transaction); |
e089f05c | 120 | #endif |