UML mount failure with Linux 6.11
Karel Zak
kzak at redhat.com
Tue Nov 12 12:10:15 PST 2024
Hi,
On Mon, Nov 11, 2024 at 09:16:18AM GMT, Hongbo Li wrote:
> We are discussing about the hostfs mount with new mount API in [1]. And may
> need your help.
>
> After finishing the conversion to the new mount API for hostfs, it
> encountered a situation where the old version supported only one mount
> option, and the whole mount option was used as the root path (it is also
> valid for the path to contain commas). But when switching to the new mount
> API, the option part will be split using commas (if I'm not mistaken, this
> step would be done in libmount), which could potentially split a complete
> path into multiple parts, and the call fsconfig syscall to set the mount
> options for underline filesystems. This is different from the original
> intention of hostfs. And this kind of situation is not common in other
> filesystems.
The options has been always parsed by mount(8) and it's very fragile
to assume that kernel get as in the original order (etc.).
For decades, commas have been supported in mount options. For example,
SeLinux uses them frequently in context settings. All you need to do
is use quotes, but be careful because the shell will strip them off.
Therefore, double quoting is required.
mount -o 'rw,bbb="this,is,value",ccc'
It's also supported in fstab, just use name="v,a,l,u,e"
You can try it:
# strace -e fsconfig mount -t tmpfs -o 'rw,bbb="this,is,value",ccc' tmpfs /dontexist
fsconfig(3, FSCONFIG_SET_STRING, "source", "tmpfs", 0) = 0
fsconfig(3, FSCONFIG_SET_FLAG, "rw", NULL, 0) = 0
fsconfig(3, FSCONFIG_SET_STRING, "bbb", "this,is,value", 0) = -1 EINVAL
You can see the expected result when using fsconfig().
Karel
--
Karel Zak <kzak at redhat.com>
http://karelzak.blogspot.com
More information about the linux-um
mailing list