]>
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; |
79154b1b CM |
46 | }; |
47 | ||
e089f05c CM |
48 | struct btrfs_trans_handle { |
49 | u64 transid; | |
f0486c68 | 50 | u64 bytes_reserved; |
2a1eb461 | 51 | unsigned long use_count; |
e089f05c CM |
52 | unsigned long blocks_reserved; |
53 | unsigned long blocks_used; | |
56bec294 | 54 | unsigned long delayed_ref_updates; |
f0486c68 YZ |
55 | struct btrfs_transaction *transaction; |
56 | struct btrfs_block_rsv *block_rsv; | |
2a1eb461 | 57 | struct btrfs_block_rsv *orig_rsv; |
e089f05c CM |
58 | }; |
59 | ||
3063d29f | 60 | struct btrfs_pending_snapshot { |
3de4586c | 61 | struct dentry *dentry; |
3063d29f | 62 | struct btrfs_root *root; |
a22285a6 YZ |
63 | struct btrfs_root *snap; |
64 | /* block reservation for the operation */ | |
65 | struct btrfs_block_rsv block_rsv; | |
66 | /* extra metadata reseration for relocation */ | |
67 | int error; | |
b83cc969 | 68 | bool readonly; |
3063d29f CM |
69 | struct list_head list; |
70 | }; | |
71 | ||
15ee9bc7 JB |
72 | static inline void btrfs_set_inode_last_trans(struct btrfs_trans_handle *trans, |
73 | struct inode *inode) | |
74 | { | |
75 | BTRFS_I(inode)->last_trans = trans->transaction->transid; | |
257c62e1 | 76 | BTRFS_I(inode)->last_sub_trans = BTRFS_I(inode)->root->log_transid; |
15ee9bc7 JB |
77 | } |
78 | ||
79154b1b CM |
79 | int btrfs_end_transaction(struct btrfs_trans_handle *trans, |
80 | struct btrfs_root *root); | |
0af3d00b JB |
81 | int btrfs_end_transaction_nolock(struct btrfs_trans_handle *trans, |
82 | struct btrfs_root *root); | |
79154b1b | 83 | struct btrfs_trans_handle *btrfs_start_transaction(struct btrfs_root *root, |
a22285a6 | 84 | int num_items); |
7a7eaa40 JB |
85 | struct btrfs_trans_handle *btrfs_join_transaction(struct btrfs_root *root); |
86 | struct btrfs_trans_handle *btrfs_join_transaction_nolock(struct btrfs_root *root); | |
87 | struct btrfs_trans_handle *btrfs_start_ioctl_transaction(struct btrfs_root *root); | |
46204592 | 88 | int btrfs_wait_for_commit(struct btrfs_root *root, u64 transid); |
79154b1b CM |
89 | int btrfs_write_and_wait_transaction(struct btrfs_trans_handle *trans, |
90 | struct btrfs_root *root); | |
08607c1b | 91 | |
5d4f98a2 | 92 | int btrfs_add_dead_root(struct btrfs_root *root); |
e9d0b13b CM |
93 | int btrfs_defrag_root(struct btrfs_root *root, int cacheonly); |
94 | int btrfs_clean_old_snapshots(struct btrfs_root *root); | |
5f39d397 CM |
95 | int btrfs_commit_transaction(struct btrfs_trans_handle *trans, |
96 | struct btrfs_root *root); | |
bb9c12c9 SW |
97 | int btrfs_commit_transaction_async(struct btrfs_trans_handle *trans, |
98 | struct btrfs_root *root, | |
99 | int wait_for_unblock); | |
89ce8a63 CM |
100 | int btrfs_end_transaction_throttle(struct btrfs_trans_handle *trans, |
101 | struct btrfs_root *root); | |
16cdcec7 MX |
102 | int btrfs_end_transaction_dmeta(struct btrfs_trans_handle *trans, |
103 | struct btrfs_root *root); | |
8929ecfa YZ |
104 | int btrfs_should_end_transaction(struct btrfs_trans_handle *trans, |
105 | struct btrfs_root *root); | |
ab78c84d | 106 | void btrfs_throttle(struct btrfs_root *root); |
5d4f98a2 YZ |
107 | int btrfs_record_root_in_trans(struct btrfs_trans_handle *trans, |
108 | struct btrfs_root *root); | |
d0c803c4 | 109 | int btrfs_write_and_wait_marked_extents(struct btrfs_root *root, |
8cef4e16 | 110 | struct extent_io_tree *dirty_pages, int mark); |
690587d1 | 111 | int btrfs_write_marked_extents(struct btrfs_root *root, |
8cef4e16 | 112 | struct extent_io_tree *dirty_pages, int mark); |
690587d1 | 113 | int btrfs_wait_marked_extents(struct btrfs_root *root, |
8cef4e16 | 114 | struct extent_io_tree *dirty_pages, int mark); |
8929ecfa | 115 | int btrfs_transaction_blocked(struct btrfs_fs_info *info); |
f36f3042 | 116 | int btrfs_transaction_in_commit(struct btrfs_fs_info *info); |
e089f05c | 117 | #endif |