Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp639569ybz; Wed, 22 Apr 2020 05:17:43 -0700 (PDT) X-Google-Smtp-Source: APiQypJR2i4ORYGY2z97waPNe57XguJWFBm9ZPwketB0HqXFasI6vBV4vCbxShW4NvyU2XkMNDiX X-Received: by 2002:a50:99c4:: with SMTP id n4mr23777004edb.187.1587557863474; Wed, 22 Apr 2020 05:17:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587557863; cv=none; d=google.com; s=arc-20160816; b=TDsCLnpk6Yw7zuF0J9FhHL8mfMGZpwrt/UMcL4/6SVHdxQWUyRQMh5my3NIfLhQhxH TfTWQsRy+QHYNn/aYHiajgUSUKi+jm5JHGBENMnhrhadgHJi98JoLQYIPRgWJMCHcN9M ZeVXHUOsZXJWZSpc5me/gR6BwctLtT7BssSlG8c9FWshvPK7dmJvfEo/VTQLjf5WX+RP K0MzN+mBhZzpwj4BA5/5LLQBcd25QmcWtpU9eDKV8xm+qkI/KWKn6kNLi9tlLCMQBJJG HZxDUOSd1RR0Fn6mlSqUWar6q5YlNduU26zxAJUOP0Q3rlHGk7nKQLiNjFeFm2EPUm3t FSfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=PqYiDYj7dJSu0TQRbes1PIn/ppGkdIgq+ng8V8ukmRE=; b=d9xqswnl6Yhe9By7ox1BUFFpsFe/Zd7sjDu9FnlNVHjU8j8W2cJ/0Frs8Qmi80MWYQ tXgXBBD5He3FNEUSmMJiSQEMI4SJY5OnFKDinjD3zVpmSXoV+92wlPyZhETtmDybU2Ot 4DOJZHhGQ/Ynhb4b1FsPjVmfQsE0scHpP55EFdSIaTWZM+lPAyVDyM0SxFt+LXnAjpFV uAajlnbbHi/1vz8W5gmtrYECB29Nl0a3JVVJXMcKpiJ1wmlx3Ap+ALUaWAfv2ZmflMXz EO2UB8evYzfGBB8Gbv1ebvFwrJjgeIp+2nokVkayRNJj8dNTOV8F6mrGinGqu45rTIEM ykjw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rjfIAQyj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f8si3480335edj.479.2020.04.22.05.17.18; Wed, 22 Apr 2020 05:17:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rjfIAQyj; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726371AbgDVJ7T (ORCPT + 99 others); Wed, 22 Apr 2020 05:59:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:45530 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726285AbgDVJ7P (ORCPT ); Wed, 22 Apr 2020 05:59:15 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2A1822076C; Wed, 22 Apr 2020 09:59:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587549554; bh=ZfU77++yMcL770c3ZrBqDkny1zBJBG8/lLNTflP8DkQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rjfIAQyjR1xgGY7ZkUw3NOEhKcvl2Ya2b37oD52q1zGaneqQYu2chICTa/FEFB9cz jFyPtLX8/2BMNcXrwJNxc53YuxwV1QTj3YpUYOvd6vxxZs9l64iuToTcj6nrAHe0dS RBrItKrDYJ1kpCATb8KSWxaFN1ksI3v1W1FkMsrc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Josef Bacik , David Sterba , Sasha Levin Subject: [PATCH 4.4 012/100] btrfs: track reloc roots based on their commit root bytenr Date: Wed, 22 Apr 2020 11:55:42 +0200 Message-Id: <20200422095025.154423768@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200422095022.476101261@linuxfoundation.org> References: <20200422095022.476101261@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Josef Bacik [ Upstream commit ea287ab157c2816bf12aad4cece41372f9d146b4 ] We always search the commit root of the extent tree for looking up back references, however we track the reloc roots based on their current bytenr. This is wrong, if we commit the transaction between relocating tree blocks we could end up in this code in build_backref_tree if (key.objectid == key.offset) { /* * Only root blocks of reloc trees use backref * pointing to itself. */ root = find_reloc_root(rc, cur->bytenr); ASSERT(root); cur->root = root; break; } find_reloc_root() is looking based on the bytenr we had in the commit root, but if we've COWed this reloc root we will not find that bytenr, and we will trip over the ASSERT(root). Fix this by using the commit_root->start bytenr for indexing the commit root. Then we change the __update_reloc_root() caller to be used when we switch the commit root for the reloc root during commit. This fixes the panic I was seeing when we started throttling relocation for delayed refs. Signed-off-by: Josef Bacik Signed-off-by: David Sterba Signed-off-by: Sasha Levin --- fs/btrfs/relocation.c | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/fs/btrfs/relocation.c b/fs/btrfs/relocation.c index 246754b31619e..df04309390bba 100644 --- a/fs/btrfs/relocation.c +++ b/fs/btrfs/relocation.c @@ -1289,7 +1289,7 @@ static int __must_check __add_reloc_root(struct btrfs_root *root) if (!node) return -ENOMEM; - node->bytenr = root->node->start; + node->bytenr = root->commit_root->start; node->data = root; spin_lock(&rc->reloc_root_tree.lock); @@ -1321,10 +1321,11 @@ static void __del_reloc_root(struct btrfs_root *root) if (rc && root->node) { spin_lock(&rc->reloc_root_tree.lock); rb_node = tree_search(&rc->reloc_root_tree.rb_root, - root->node->start); + root->commit_root->start); if (rb_node) { node = rb_entry(rb_node, struct mapping_node, rb_node); rb_erase(&node->rb_node, &rc->reloc_root_tree.rb_root); + RB_CLEAR_NODE(&node->rb_node); } spin_unlock(&rc->reloc_root_tree.lock); if (!node) @@ -1342,7 +1343,7 @@ static void __del_reloc_root(struct btrfs_root *root) * helper to update the 'address of tree root -> reloc tree' * mapping */ -static int __update_reloc_root(struct btrfs_root *root, u64 new_bytenr) +static int __update_reloc_root(struct btrfs_root *root) { struct rb_node *rb_node; struct mapping_node *node = NULL; @@ -1350,7 +1351,7 @@ static int __update_reloc_root(struct btrfs_root *root, u64 new_bytenr) spin_lock(&rc->reloc_root_tree.lock); rb_node = tree_search(&rc->reloc_root_tree.rb_root, - root->node->start); + root->commit_root->start); if (rb_node) { node = rb_entry(rb_node, struct mapping_node, rb_node); rb_erase(&node->rb_node, &rc->reloc_root_tree.rb_root); @@ -1362,7 +1363,7 @@ static int __update_reloc_root(struct btrfs_root *root, u64 new_bytenr) BUG_ON((struct btrfs_root *)node->data != root); spin_lock(&rc->reloc_root_tree.lock); - node->bytenr = new_bytenr; + node->bytenr = root->node->start; rb_node = tree_insert(&rc->reloc_root_tree.rb_root, node->bytenr, &node->rb_node); spin_unlock(&rc->reloc_root_tree.lock); @@ -1503,6 +1504,7 @@ int btrfs_update_reloc_root(struct btrfs_trans_handle *trans, } if (reloc_root->commit_root != reloc_root->node) { + __update_reloc_root(reloc_root); btrfs_set_root_node(root_item, reloc_root->node); free_extent_buffer(reloc_root->commit_root); reloc_root->commit_root = btrfs_root_node(reloc_root); @@ -4578,11 +4580,6 @@ int btrfs_reloc_cow_block(struct btrfs_trans_handle *trans, BUG_ON(rc->stage == UPDATE_DATA_PTRS && root->root_key.objectid == BTRFS_DATA_RELOC_TREE_OBJECTID); - if (root->root_key.objectid == BTRFS_TREE_RELOC_OBJECTID) { - if (buf == root->node) - __update_reloc_root(root, cow->start); - } - level = btrfs_header_level(buf); if (btrfs_header_generation(buf) <= btrfs_root_last_snapshot(&root->root_item)) -- 2.20.1