X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=transaction.h;h=470ee3de13584db003e954e8bcc71f23f883328b;hb=eb9dd12d0ed77aae427f7c348fd3cd1ab153ed9c;hp=ac026aad31f659b6205af081f06bc814e07d6479;hpb=07a4f1b81df6cd9b9e09773f680fc098faed310c;p=platform%2Fupstream%2Fbtrfs-progs.git diff --git a/transaction.h b/transaction.h index ac026aa..470ee3d 100644 --- a/transaction.h +++ b/transaction.h @@ -16,33 +16,30 @@ * Boston, MA 021110-1307, USA. */ -#ifndef __TRANSACTION__ -#define __TRANSACTION__ +#ifndef __BTRFS_TRANSACTION_H__ +#define __BTRFS_TRANSACTION_H__ + +#include "kerncompat.h" +#include "ctree.h" struct btrfs_trans_handle { + struct btrfs_fs_info *fs_info; u64 transid; + u64 alloc_exclude_start; + u64 alloc_exclude_nr; unsigned long blocks_reserved; unsigned long blocks_used; + struct btrfs_block_group_cache *block_group; }; -static inline struct btrfs_trans_handle * -btrfs_start_transaction(struct btrfs_root *root, int num_blocks) -{ - struct btrfs_fs_info *fs_info = root->fs_info; - struct btrfs_trans_handle *h = malloc(sizeof(*h)); - fs_info->running_transaction = h; - fs_info->generation++; - h->transid = fs_info->generation; - h->blocks_reserved = num_blocks; - h->blocks_used = 0; - return h; -} - -static inline void btrfs_free_transaction(struct btrfs_root *root, - struct btrfs_trans_handle *handle) -{ - memset(handle, 0, sizeof(*handle)); - free(handle); -} +struct btrfs_trans_handle* btrfs_start_transaction(struct btrfs_root *root, + int num_blocks); +int __commit_transaction(struct btrfs_trans_handle *trans, + struct btrfs_root *root); +int commit_tree_roots(struct btrfs_trans_handle *trans, + struct btrfs_fs_info *fs_info); +int btrfs_commit_transaction(struct btrfs_trans_handle *trans, + struct btrfs_root *root); +void btrfs_abort_transaction(struct btrfs_trans_handle *trans, int error); #endif