struct btrfs_root *log,
                                       struct btrfs_path *path,
                                       u64 dirid, int del_all);
+static void wait_log_commit(struct btrfs_root *root, int transid);
 
 /*
  * tree logging is a special write ahead log used to make sure that
 {
        struct btrfs_fs_info *fs_info = root->fs_info;
        struct btrfs_root *tree_root = fs_info->tree_root;
+       const bool zoned = btrfs_is_zoned(fs_info);
        int ret = 0;
+       bool created = false;
 
        /*
         * First check if the log root tree was already created. If not, create
                mutex_lock(&tree_root->log_mutex);
                if (!fs_info->log_root_tree) {
                        ret = btrfs_init_log_root_tree(trans, fs_info);
-                       if (!ret)
+                       if (!ret) {
                                set_bit(BTRFS_ROOT_HAS_LOG_TREE, &tree_root->state);
+                               created = true;
+                       }
                }
                mutex_unlock(&tree_root->log_mutex);
                if (ret)
 
        mutex_lock(&root->log_mutex);
 
+again:
        if (root->log_root) {
+               int index = (root->log_transid + 1) % 2;
+
                if (btrfs_need_log_full_commit(trans)) {
                        ret = -EAGAIN;
                        goto out;
                }
 
+               if (zoned && atomic_read(&root->log_commit[index])) {
+                       wait_log_commit(root, root->log_transid - 1);
+                       goto again;
+               }
+
                if (!root->log_start_pid) {
                        clear_bit(BTRFS_ROOT_MULTI_LOG_TASKS, &root->state);
                        root->log_start_pid = current->pid;
                        set_bit(BTRFS_ROOT_MULTI_LOG_TASKS, &root->state);
                }
        } else {
+               /*
+                * This means fs_info->log_root_tree was already created
+                * for some other FS trees. Do the full commit not to mix
+                * nodes from multiple log transactions to do sequential
+                * writing.
+                */
+               if (zoned && !created) {
+                       ret = -EAGAIN;
+                       goto out;
+               }
+
                ret = btrfs_add_log_tree(trans, root);
                if (ret)
                        goto out;
  */
 static int join_running_log_trans(struct btrfs_root *root)
 {
+       const bool zoned = btrfs_is_zoned(root->fs_info);
        int ret = -ENOENT;
 
        if (!test_bit(BTRFS_ROOT_HAS_LOG_TREE, &root->state))
                return ret;
 
        mutex_lock(&root->log_mutex);
+again:
        if (root->log_root) {
+               int index = (root->log_transid + 1) % 2;
+
                ret = 0;
+               if (zoned && atomic_read(&root->log_commit[index])) {
+                       wait_log_commit(root, root->log_transid - 1);
+                       goto again;
+               }
                atomic_inc(&root->log_writers);
        }
        mutex_unlock(&root->log_mutex);