From: Qu Wenruo <quwenruo.btrfs@gmx.com>
To: dsterba@suse.cz
Cc: kreijack@inwind.it, Mark Harmstone <maharmstone@fb.com>,
linux-btrfs@vger.kernel.org
Subject: Re: [PATCH v5] btrfs-progs: add --subvol option to mkfs.btrfs
Date: Thu, 15 Aug 2024 07:41:03 +0930 [thread overview]
Message-ID: <93991cfd-8a39-4178-b8ff-a5edd445410a@gmx.com> (raw)
In-Reply-To: <20240814215703.GB25962@suse.cz>
在 2024/8/15 07:27, David Sterba 写道:
[...]
>>
>> You ignored all the things like owner/group/privilege bits and maybe
>> even xattrs (for SELINUX) that will be needed.
>
> There are probably two main use cases:
>
> - create something simple, with files copied from a directory and now
> newly also to make some directories subvolumes
>
> - create a filesystem where any detail can be specified, like uid/gid,
> access rights, ACL, XATTR, ...
>
> So far the focus is on option 1 and it seems we have the most common use
> covered. For option 2 the command line options are probably the wron
> interface.
Nope, the current implementation (inherited from the --rootdir option)
handles both.
We have everything, except the hardlinks, copied from the rootdir,
including uid/gid/access mode, XATTR.
>
> I suggest to use an approach using a list of definitions, e.g. in a
> file, where each line says what should be done on the filesystem. This
> is not a new idea, XFS has a protofile, which is ancient and we don't
> have to copy the exact format, but it's the same idea.
I think it's asking for problems that is already resolved.
The current rootdir is already providing every functionality, except
subvolume related ones (subvolume, snapshot, default subvolume etc).
And Mark's excellent work handles the missing subvolume part, and he is
also working on the default subvolume part too.
So far I really see no reason to introduce a completely new and complex
(and conflicting with --rootdir) interface, while everything can be done
by --rootdir + --subvol already.
The only exception is snapshot, but for mkosi usage, I didn't see much
need for a snapshot.
Thanks,
Qu
>
> The structure is like this:
> COMMAND OPTIONS...
>
> and we can define anything, like "ROOTDIR dir" that will mimick the
> --rootdir option, but also "CHMOD RWX PATH", to do mkfs-emulated
> "chmod RWX PATH". And custom commands like default subvolume.
>
> This is obviously more work than option 1 so does not need to be
> implemented right now. For the command-line options the most common use
> case should work. If we allow to take the proto file from stdin it can
> be created on the fly too.
next prev parent reply other threads:[~2024-08-14 22:11 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-08 17:17 [PATCH v5] btrfs-progs: add --subvol option to mkfs.btrfs Mark Harmstone
2024-08-09 19:31 ` David Sterba
2024-08-10 9:53 ` Goffredo Baroncelli
2024-08-10 22:40 ` Qu Wenruo
2024-08-12 11:42 ` Goffredo Baroncelli
2024-08-12 14:39 ` Mark Harmstone
2024-08-12 22:08 ` Qu Wenruo
2024-08-14 21:57 ` David Sterba
2024-08-14 22:11 ` Qu Wenruo [this message]
2024-08-14 22:20 ` David Sterba
2024-08-13 0:52 ` Anand Jain
2024-08-13 10:38 ` Mark Harmstone
2024-08-14 21:47 ` 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=93991cfd-8a39-4178-b8ff-a5edd445410a@gmx.com \
--to=quwenruo.btrfs@gmx.com \
--cc=dsterba@suse.cz \
--cc=kreijack@inwind.it \
--cc=linux-btrfs@vger.kernel.org \
--cc=maharmstone@fb.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