]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - fs/btrfs/transaction.h
Btrfs: Split the extent_map code into two parts
[linux-2.6-omap-h63xx.git] / fs / btrfs / transaction.h
index d5f491d3757eae1ee7a04bf96483f3d3f6f7f8ed..c3172ddb332116bfcf20347948fc547e1a1e29d5 100644 (file)
  * Boston, MA 021110-1307, USA.
  */
 
-#ifndef __TRANSACTION__
-#define __TRANSACTION__
+#ifndef __BTRFS_TRANSACTION__
+#define __BTRFS_TRANSACTION__
 #include "btrfs_inode.h"
+#include "ordered-data.h"
 
 struct btrfs_transaction {
        u64 transid;
        unsigned long num_writers;
+       unsigned long num_joined;
        int in_commit;
        int use_count;
        int commit_done;
        struct list_head list;
-       struct radix_tree_root dirty_pages;
+       struct extent_io_tree dirty_pages;
        unsigned long start_time;
+       struct btrfs_ordered_inode_tree ordered_inode_tree;
        wait_queue_head_t writer_wait;
        wait_queue_head_t commit_wait;
+       struct list_head pending_snapshots;
 };
 
 struct btrfs_trans_handle {
@@ -43,6 +47,12 @@ struct btrfs_trans_handle {
        u64 alloc_exclude_nr;
 };
 
+struct btrfs_pending_snapshot {
+       struct btrfs_root *root;
+       char *name;
+       struct list_head list;
+};
+
 
 static inline void btrfs_set_trans_block_group(struct btrfs_trans_handle *trans,
                                               struct inode *inode)
@@ -57,6 +67,12 @@ static inline void btrfs_update_inode_block_group(struct
        BTRFS_I(inode)->block_group = trans->block_group;
 }
 
+static inline void btrfs_set_inode_last_trans(struct btrfs_trans_handle *trans,
+                                             struct inode *inode)
+{
+       BTRFS_I(inode)->last_trans = trans->transaction->transid;
+}
+
 int btrfs_end_transaction(struct btrfs_trans_handle *trans,
                          struct btrfs_root *root);
 struct btrfs_trans_handle *btrfs_start_transaction(struct btrfs_root *root,
@@ -66,14 +82,23 @@ int btrfs_write_and_wait_transaction(struct btrfs_trans_handle *trans,
 int btrfs_commit_tree_roots(struct btrfs_trans_handle *trans,
                            struct btrfs_root *root);
 
+#if LINUX_VERSION_CODE <= KERNEL_VERSION(2,6,18)
+void btrfs_transaction_cleaner(void *p);
+#else
 void btrfs_transaction_cleaner(struct work_struct *work);
+#endif
+
 void btrfs_transaction_flush_work(struct btrfs_root *root);
 void btrfs_transaction_queue_work(struct btrfs_root *root, int delay);
 void btrfs_init_transaction_sys(void);
 void btrfs_exit_transaction_sys(void);
-int btrfs_add_dead_root(struct btrfs_root *root, struct list_head *dead_list);
+int btrfs_add_dead_root(struct btrfs_root *root, struct btrfs_root *latest,
+                       struct list_head *dead_list);
 int btrfs_defrag_dirty_roots(struct btrfs_fs_info *info);
 int btrfs_defrag_root(struct btrfs_root *root, int cacheonly);
 int btrfs_clean_old_snapshots(struct btrfs_root *root);
-
+int btrfs_commit_transaction(struct btrfs_trans_handle *trans,
+                            struct btrfs_root *root);
+int btrfs_write_ordered_inodes(struct btrfs_trans_handle *trans,
+                               struct btrfs_root *root);
 #endif