{
struct btrfs_root *root = BTRFS_I(inode)->root;
struct btrfs_trans_handle *trans;
- int ret;
+ int ret = 0;
+
+ if (wait) {
+ mutex_lock(&root->fs_info->fs_mutex);
+ trans = btrfs_start_transaction(root, 1);
+ ret = btrfs_commit_transaction(trans, root);
+ mutex_unlock(&root->fs_info->fs_mutex);
+ }
+ return ret;
+}
+
+static void btrfs_dirty_inode(struct inode *inode)
+{
+ struct btrfs_root *root = BTRFS_I(inode)->root;
+ struct btrfs_trans_handle *trans;
mutex_lock(&root->fs_info->fs_mutex);
trans = btrfs_start_transaction(root, 1);
- ret = btrfs_update_inode(trans, root, inode);
- if (wait)
- btrfs_commit_transaction(trans, root);
- else
- btrfs_end_transaction(trans, root);
+ btrfs_update_inode(trans, root, inode);
+ btrfs_end_transaction(trans, root);
mutex_unlock(&root->fs_info->fs_mutex);
- return ret;
}
static struct inode *btrfs_new_inode(struct btrfs_trans_handle *trans,
buf->f_type = BTRFS_SUPER_MAGIC;
return 0;
}
+
static struct file_system_type btrfs_fs_type = {
.owner = THIS_MODULE,
.name = "btrfs",
.write_super = btrfs_write_super,
.sync_fs = btrfs_sync_fs,
.write_inode = btrfs_write_inode,
+ .dirty_inode = btrfs_dirty_inode,
.alloc_inode = btrfs_alloc_inode,
.destroy_inode = btrfs_destroy_inode,
.statfs = btrfs_statfs,