From: David Sterba <dsterba@suse.cz>
To: Marcos Paulo de Souza <marcos@mpdesouza.com>
Cc: dsterba@suse.com, wqu@suse.com, linux-btrfs@vger.kernel.org,
Marcos Paulo de Souza <mpdesouza@suse.com>
Subject: Re: [PATCH v4 00/11] btrfs-progs: mkfs: Quota support through -Q|--quota
Date: Mon, 25 May 2020 16:43:11 +0200 [thread overview]
Message-ID: <20200525144311.GV18421@twin.jikos.cz> (raw)
In-Reply-To: <20200318202148.14828-1-marcos@mpdesouza.com>
On Wed, Mar 18, 2020 at 05:21:37PM -0300, Marcos Paulo de Souza wrote:
> From: Marcos Paulo de Souza <mpdesouza@suse.com>
>
> Hi guys,
>
> This if the forth version of this patchset. The last submission of these patches
> was in 2018[1]. This version is based on top on the current devel branch, with
> minor cleanups, minor conflicts and only a real fix in patch 0008. I would like
> to ask you guys to review these patches, since v3 didn't receive any feedback at
> the time.
>
> I only added my SoB in three patches, which were those were I needed a manual
> intervention, or a specific fix as I mentioned.
>
> Thanks for your review,
> Marcos
>
> Original cover letter for Wenruo:
> This patchset adds quota support, which means the result fs will have
> quota enabled by default, and its accounting is already consistent, no
> manually rescan or quota enable is needed.
>
> The overall design of such support is:
> 1) Create needed tree
> Both btrfs_root and real root item and tree root leaf.
> For this, a new infrastructure, btrfs_create_tree(), is added for
> this.
>
> 2) Fill quota root with basic skeleton
> Only 3 items are really needed
> a) global quota status item
> b) quota info for specified qgroup
> c) quota limit for specified qgroup
>
> Currently we insert all qgroup items for all existing file trees.
> If we're going to support extra subvolume at mkfs time, just pass the
> subvolume id into insert_qgroup_items().
>
> The content doesn't matter at all.
>
> 3) Repair qgroups using infrastructure from qgroup-verify
> In fact, qgroup repair is just offline rescan.
> Although the original qgroup-verify infrastructure is mostly noisy,
> modify it a little to make it silent to function as offline quota
> rescan.
>
> And such support is mainly designed for developers and QA guys.
>
> As to enable quota, before we must normally mount the fs, enable quota
> (and rescan if needed).
> This ioctl based procedure is not common, and fstests doesn't provide
> such support.
> (Not to mention sometimes rescan itself can be buggy)
>
> There are several attempts to make fstests to support it, but due to
> different reasons, all these attempts failed.
>
> To make it easier to test all existing test cases with btrfs quota
> enabled, the current best method is to support quota at mkfs time, and
> here comes the patchset.
>
> [1]: https://lore.kernel.org/linux-btrfs/20180807081938.21348-1-wqu@suse.com/T/#m107735cecbf4729b599e6e4eee0a54802909b30d
>
> Qu Wenruo (11):
> btrfs-progs: qgroup-verify: Avoid NULL pointer dereference for later
> silent qgroup repair
> btrfs-progs: qgroup-verify: Also repair qgroup status version
> btrfs-progs: qgroup-verify: Use fs_info->readonly to check if we
> should repair qgroups
> btrfs-progs: qgroup-verify: Move qgroup classification out of
> report_qgroups
> btrfs-progs: qgroup-verify: Allow repair_qgroups function to do silent
> repair
> btrfs-progs: ctree: Introduce function to create an empty tree
> btrfs-progs: mkfs: Introduce function to insert qgroup info and limit
> items
> btrfs-progs: mkfs: Introduce function to setup quota root and rescan
I've applied the above with some fixes to devel.
> btrfs-progs: mkfs: Introduce mkfs time quota support
> btrfs-progs: test/mkfs: Add test case for -Q|--quota option
> btrfs-progs: test/mkfs: Add test case for --rootdir and --quota
The option name needs to be -R as used to be in V2 of Qu's original
patchset. I don't know why this got changed to the single purpose -Q but
-R will be used to specifiy runtime options, similar to what -O does
now.
prev parent reply other threads:[~2020-05-25 14:44 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-03-18 20:21 [PATCH v4 00/11] btrfs-progs: mkfs: Quota support through -Q|--quota Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 01/11] btrfs-progs: qgroup-verify: Avoid NULL pointer dereference for later silent qgroup repair Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 02/11] btrfs-progs: qgroup-verify: Also repair qgroup status version Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 03/11] btrfs-progs: qgroup-verify: Use fs_info->readonly to check if we should repair qgroups Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 04/11] btrfs-progs: qgroup-verify: Move qgroup classification out of report_qgroups Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 05/11] btrfs-progs: qgroup-verify: Allow repair_qgroups function to do silent repair Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 06/11] btrfs-progs: ctree: Introduce function to create an empty tree Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 07/11] btrfs-progs: mkfs: Introduce function to insert qgroup info and limit items Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 08/11] btrfs-progs: mkfs: Introduce function to setup quota root and rescan Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 09/11] btrfs-progs: mkfs: Introduce mkfs time quota support Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 10/11] btrfs-progs: test/mkfs: Add test case for -Q|--quota option Marcos Paulo de Souza
2020-03-18 20:21 ` [PATCH v4 11/11] btrfs-progs: test/mkfs: Add test case for --rootdir and --quota Marcos Paulo de Souza
2020-05-25 14:43 ` David Sterba [this message]
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=20200525144311.GV18421@twin.jikos.cz \
--to=dsterba@suse.cz \
--cc=dsterba@suse.com \
--cc=linux-btrfs@vger.kernel.org \
--cc=marcos@mpdesouza.com \
--cc=mpdesouza@suse.com \
--cc=wqu@suse.com \
/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).