linux-btrfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: robbieko <robbieko@synology.com>
To: dsterba@suse.cz, linux-btrfs@vger.kernel.org
Cc: linux-btrfs-owner@vger.kernel.org
Subject: Re: [PATCH] Btrfs : improve the speed of compare orphan item and dead roots with tree root when mount
Date: Tue, 05 May 2020 09:39:21 +0800	[thread overview]
Message-ID: <b0f35dbab104cc8119327343f157a48a@synology.com> (raw)
In-Reply-To: <31c590f2abee67d60ca8941f5e92e924@synology.com>

Hi

Does anyone have suggestions ?

Thanks.
Robbie Ko

robbieko 於 2020-04-28 11:12 寫到:
> David Sterba 於 2020-04-27 23:46 寫到:
>> On Mon, Apr 27, 2020 at 04:04:11PM +0800, robbieko wrote:
>>> From: Robbie Ko <robbieko@synology.com>
>>> 
>>> When mounting, we handle deleted subvol and orphan items.
>>> First, find add orphan roots, then add them to fs_root radix tree.
>>> Second, in tree-root, process each orphan item, skip if it is dead 
>>> root.
>>> 
>>> The original algorithm is based on the list of dead_roots,
>>> one by one to visit and check whether the objectid is consistent,
>>> the time complexity is O (n ^ 2).
>>> When processing 50000 deleted subvols, it takes about 120s.
>>> 
>>> We can quickly check whether the orphan item is dead root
>>> through the fs_roots radix tree.
>>> 
>>> Signed-off-by: Robbie Ko <robbieko@synology.com>
>>> ---
>>>  fs/btrfs/inode.c | 20 +++++++++-----------
>>>  1 file changed, 9 insertions(+), 11 deletions(-)
>>> 
>>> diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
>>> index 320d1062068d..1becf5c63e5a 100644
>>> --- a/fs/btrfs/inode.c
>>> +++ b/fs/btrfs/inode.c
>>> @@ -3000,18 +3000,16 @@ int btrfs_orphan_cleanup(struct btrfs_root 
>>> *root)
>>>  			 * orphan must not get deleted.
>>>  			 * find_dead_roots already ran before us, so if this
>>>  			 * is a snapshot deletion, we should find the root
>>> -			 * in the dead_roots list
>>> +			 * in the fs_roots radix tree.
>>>  			 */
>>> -			spin_lock(&fs_info->trans_lock);
>>> -			list_for_each_entry(dead_root, &fs_info->dead_roots,
>>> -					    root_list) {
>>> -				if (dead_root->root_key.objectid ==
>>> -				    found_key.objectid) {
>>> -					is_dead_root = 1;
>>> -					break;
>>> -				}
>>> -			}
>>> -			spin_unlock(&fs_info->trans_lock);
>>> +
>>> +			spin_lock(&fs_info->fs_roots_radix_lock);
>>> +			dead_root = radix_tree_lookup(&fs_info->fs_roots_radix,
>>> +							 (unsigned long)found_key.objectid);
>>> +			if (dead_root && btrfs_root_refs(&dead_root->root_item) == 0)
>>> +				is_dead_root = 1;
>>> +			spin_unlock(&fs_info->fs_roots_radix_lock);
>> 
>> The list uses fs_info::trans_lock and the radix uses
>> fs_roots_radix_lock. I'd like to know why you think it's safe.
>> 
>> The trans_lock is used for a lot of things, fs_roots_radix_lock is for
>> the radix tree insertion/deletion/update/lookup so it does not seem 
>> like
>> an equivalent change. It could be functionally equivalent due to some
>> other constraint, like that the number of references is 0 and the tree
>> won't be ever touched outside of the orphan cleanup process.
> 
> Because btrfs_find_orphan_roots has already ran before us,
> and added deleted subvol to fs_roots radix tree.
> 
> The fs root will only be removed from the fs_roots radix tree
> after the cleaner is processed, and the cleaner will only start
> execution after the mount is complete.
> 
> So we can directly find the root from the radix tree.
> 
>> 
>> btrfs_orphan_cleanup can be called during the whole filesystem mount
>> lifetime, so we can't rely on the mount time where nothing can 
>> iterfere.
> 
> Only "tree root" will be used in this section of code,
> and only mount time will be brought into tree root.


  reply	other threads:[~2020-05-05  1:39 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-04-27  8:04 [PATCH] Btrfs : improve the speed of compare orphan item and dead roots with tree root when mount robbieko
2020-04-27 15:46 ` David Sterba
2020-04-28  3:12   ` robbieko
2020-05-05  1:39     ` robbieko [this message]
2020-05-06 15:19       ` David Sterba

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=b0f35dbab104cc8119327343f157a48a@synology.com \
    --to=robbieko@synology.com \
    --cc=dsterba@suse.cz \
    --cc=linux-btrfs-owner@vger.kernel.org \
    --cc=linux-btrfs@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).