Vivek Goyal wrote on Mon, Jun 14, 2021 at 10:28:04AM -0400: > I am not a big fan of nobdev_filesystems array but I really don't feel > comfortable opening up this code by default to all filesystems having > flag FS_REQUIRES_DEV. Use cases of this code path are not well documented > and something somewhere will be broken and called regression. > > I think nobdev_filesystems is sort of a misfit. Even mtd, ubi, cifs > and nfs are nobdev filesystems but they are not covered by this. I think it's fine being able to have these root mounted both ways, then eventually removing the old fs-specific options after a period of deprecation to have a unique and simple interface. Maybe it's just a bit of a dream big attitude :-) > > I'd bite the bullet and use FS_REQUIRES_DEV (and move this part of the > > code just a bit below after the root_wait check just in case it matters, > > Problem with moving this below root_wait check is that if user boots > with root_wait option for virtiofs/9p, it will loop infitely. Reason > being that ROOT_DEV=0 and device will never show up. Hm, well, then don't use root_wait?! would be my first reaction. The reason I suggested to move below would be that there might be filesystems which handle both a block device and no block device, and for these we wouldn't want to break root_wait which would become kind of a switch saying "this really is a block device usecase even if the fs doesn't require dev" -- that's also the reason I was mostly optimistic even if we make it generic for all filesystems, there'd be this way out even if the thing is compiled in. Ultimately if we go through the explicit whitelist that's not required anyway, and in that case it's probably better to check before as you've said. > I am assuming that for out use cases, device will need to be present > at the time of boot. We can't have a notion of waiting for device to > show up. > > > but at that point if something would mount with /dev/root but not with > > the raw root=argument then they probably do require a device!) > > > > It could also be gated by a config option like e.g. CONFIG_ROOT_NFS and > > others all are to make sure it doesn't impact anyone who doesn't want to > > be impacted - I'm sure some people want to make sure their device > > doesn't boot off a weird root if someone manages to change kernel params > > so would want a way of disabling the option... > > I guess I could do that. Given more than one filesystem will use this > option (virtiofs and 9p to begin with), so we will have to have a > config option name which is little more generic and not filesystem > specific like CONFIG_ROOT_NFS or CONFIG_ROOT_CIFS. Well there's the builtin check you added, and there's the ability to root boot from it that's historically always been separated. The builtin checks you added actually doesn't matter all that much to me. I mean, it'll pass this step, but fail as it cannot mount later anyway, and it was an explicit request to have this filesystem in the command line: you've changed an error that says "I cannot mount 9p!" to "I cannot find root-device!" so it's not really a big deal. What I was advocating for is the whole feature being gated by some option - my example with an embdedded device having 9p builtin (because for some reason they have everything builtin) but not wanting to boot on a tcp 9p rootfs still stands even if we're limiting this to a few filesystems. If you're keeping the idea of tags CONFIG_ROOT_TAGS ? > > Also, matter-of-factedly, how is this going to be picked up? > > Is the plan to send it directly to Linus as part of the next virtiofs > > PR? Going through Al Viro? > > I was hoping that this patch can be routed through Al Viro. Sounds good to me as well - I've upgraded him to To: to get his attention. (v2 has been sent as "[PATCH v2 0/2] Add support to boot virtiofs and 9pfs as rootfs"; I'll review/retest in the next few days) -- Dominique