|
@@ -20,13 +20,11 @@
|
|
#include <linux/slab.h>
|
|
#include <linux/slab.h>
|
|
#include <linux/blkdev.h>
|
|
#include <linux/blkdev.h>
|
|
#include <linux/list_sort.h>
|
|
#include <linux/list_sort.h>
|
|
-#include "ctree.h"
|
|
|
|
-#include "transaction.h"
|
|
|
|
|
|
+#include "tree-log.h"
|
|
#include "disk-io.h"
|
|
#include "disk-io.h"
|
|
#include "locking.h"
|
|
#include "locking.h"
|
|
#include "print-tree.h"
|
|
#include "print-tree.h"
|
|
#include "backref.h"
|
|
#include "backref.h"
|
|
-#include "tree-log.h"
|
|
|
|
#include "hash.h"
|
|
#include "hash.h"
|
|
|
|
|
|
/* magic values for the inode_only field in btrfs_log_inode:
|
|
/* magic values for the inode_only field in btrfs_log_inode:
|
|
@@ -144,12 +142,10 @@ static int start_log_trans(struct btrfs_trans_handle *trans,
|
|
|
|
|
|
mutex_lock(&root->log_mutex);
|
|
mutex_lock(&root->log_mutex);
|
|
if (root->log_root) {
|
|
if (root->log_root) {
|
|
- if (ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) ==
|
|
|
|
- trans->transid) {
|
|
|
|
|
|
+ if (btrfs_need_log_full_commit(root->fs_info, trans)) {
|
|
ret = -EAGAIN;
|
|
ret = -EAGAIN;
|
|
goto out;
|
|
goto out;
|
|
}
|
|
}
|
|
-
|
|
|
|
if (!root->log_start_pid) {
|
|
if (!root->log_start_pid) {
|
|
root->log_start_pid = current->pid;
|
|
root->log_start_pid = current->pid;
|
|
clear_bit(BTRFS_ROOT_MULTI_LOG_TASKS, &root->state);
|
|
clear_bit(BTRFS_ROOT_MULTI_LOG_TASKS, &root->state);
|
|
@@ -2512,8 +2508,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
}
|
|
}
|
|
|
|
|
|
/* bail out if we need to do a full commit */
|
|
/* bail out if we need to do a full commit */
|
|
- if (ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) ==
|
|
|
|
- trans->transid) {
|
|
|
|
|
|
+ if (btrfs_need_log_full_commit(root->fs_info, trans)) {
|
|
ret = -EAGAIN;
|
|
ret = -EAGAIN;
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
mutex_unlock(&root->log_mutex);
|
|
mutex_unlock(&root->log_mutex);
|
|
@@ -2534,8 +2529,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
blk_finish_plug(&plug);
|
|
blk_finish_plug(&plug);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
- ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) =
|
|
|
|
- trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
mutex_unlock(&root->log_mutex);
|
|
mutex_unlock(&root->log_mutex);
|
|
goto out;
|
|
goto out;
|
|
}
|
|
}
|
|
@@ -2578,8 +2572,8 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
list_del_init(&root_log_ctx.list);
|
|
list_del_init(&root_log_ctx.list);
|
|
|
|
|
|
blk_finish_plug(&plug);
|
|
blk_finish_plug(&plug);
|
|
- ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) =
|
|
|
|
- trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
|
|
+
|
|
if (ret != -ENOSPC) {
|
|
if (ret != -ENOSPC) {
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
mutex_unlock(&log_root_tree->log_mutex);
|
|
mutex_unlock(&log_root_tree->log_mutex);
|
|
@@ -2623,8 +2617,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
* now that we've moved on to the tree of log tree roots,
|
|
* now that we've moved on to the tree of log tree roots,
|
|
* check the full commit flag again
|
|
* check the full commit flag again
|
|
*/
|
|
*/
|
|
- if (ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) ==
|
|
|
|
- trans->transid) {
|
|
|
|
|
|
+ if (btrfs_need_log_full_commit(root->fs_info, trans)) {
|
|
blk_finish_plug(&plug);
|
|
blk_finish_plug(&plug);
|
|
btrfs_wait_marked_extents(log, &log->dirty_log_pages, mark);
|
|
btrfs_wait_marked_extents(log, &log->dirty_log_pages, mark);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
@@ -2638,8 +2631,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
EXTENT_DIRTY | EXTENT_NEW);
|
|
EXTENT_DIRTY | EXTENT_NEW);
|
|
blk_finish_plug(&plug);
|
|
blk_finish_plug(&plug);
|
|
if (ret) {
|
|
if (ret) {
|
|
- ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) =
|
|
|
|
- trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
btrfs_free_logged_extents(log, log_transid);
|
|
mutex_unlock(&log_root_tree->log_mutex);
|
|
mutex_unlock(&log_root_tree->log_mutex);
|
|
@@ -2668,8 +2660,7 @@ int btrfs_sync_log(struct btrfs_trans_handle *trans,
|
|
*/
|
|
*/
|
|
ret = write_ctree_super(trans, root->fs_info->tree_root, 1);
|
|
ret = write_ctree_super(trans, root->fs_info->tree_root, 1);
|
|
if (ret) {
|
|
if (ret) {
|
|
- ACCESS_ONCE(root->fs_info->last_trans_log_full_commit) =
|
|
|
|
- trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
goto out_wake_log_root;
|
|
goto out_wake_log_root;
|
|
}
|
|
}
|
|
@@ -2887,7 +2878,7 @@ fail:
|
|
out_unlock:
|
|
out_unlock:
|
|
mutex_unlock(&BTRFS_I(dir)->log_mutex);
|
|
mutex_unlock(&BTRFS_I(dir)->log_mutex);
|
|
if (ret == -ENOSPC) {
|
|
if (ret == -ENOSPC) {
|
|
- root->fs_info->last_trans_log_full_commit = trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
ret = 0;
|
|
ret = 0;
|
|
} else if (ret < 0)
|
|
} else if (ret < 0)
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
@@ -2920,7 +2911,7 @@ int btrfs_del_inode_ref_in_log(struct btrfs_trans_handle *trans,
|
|
dirid, &index);
|
|
dirid, &index);
|
|
mutex_unlock(&BTRFS_I(inode)->log_mutex);
|
|
mutex_unlock(&BTRFS_I(inode)->log_mutex);
|
|
if (ret == -ENOSPC) {
|
|
if (ret == -ENOSPC) {
|
|
- root->fs_info->last_trans_log_full_commit = trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
ret = 0;
|
|
ret = 0;
|
|
} else if (ret < 0 && ret != -ENOENT)
|
|
} else if (ret < 0 && ret != -ENOENT)
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
btrfs_abort_transaction(trans, root, ret);
|
|
@@ -4131,8 +4122,7 @@ static noinline int check_parent_dirs_for_sync(struct btrfs_trans_handle *trans,
|
|
* make sure any commits to the log are forced
|
|
* make sure any commits to the log are forced
|
|
* to be full commits
|
|
* to be full commits
|
|
*/
|
|
*/
|
|
- root->fs_info->last_trans_log_full_commit =
|
|
|
|
- trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
ret = 1;
|
|
ret = 1;
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
@@ -4178,6 +4168,10 @@ static int btrfs_log_inode_parent(struct btrfs_trans_handle *trans,
|
|
goto end_no_trans;
|
|
goto end_no_trans;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /*
|
|
|
|
+ * The prev transaction commit doesn't complete, we need do
|
|
|
|
+ * full commit by ourselves.
|
|
|
|
+ */
|
|
if (root->fs_info->last_trans_log_full_commit >
|
|
if (root->fs_info->last_trans_log_full_commit >
|
|
root->fs_info->last_trans_committed) {
|
|
root->fs_info->last_trans_committed) {
|
|
ret = 1;
|
|
ret = 1;
|
|
@@ -4247,7 +4241,7 @@ static int btrfs_log_inode_parent(struct btrfs_trans_handle *trans,
|
|
end_trans:
|
|
end_trans:
|
|
dput(old_parent);
|
|
dput(old_parent);
|
|
if (ret < 0) {
|
|
if (ret < 0) {
|
|
- root->fs_info->last_trans_log_full_commit = trans->transid;
|
|
|
|
|
|
+ btrfs_set_log_full_commit(root->fs_info, trans);
|
|
ret = 1;
|
|
ret = 1;
|
|
}
|
|
}
|
|
|
|
|