freebsd-dev/contrib/dracut/90zfs
наб 3399a30ee0
contrib: dracut: fix race with root=zfs:dset when necessities required
This had always worked in my testing, but a user on hardware reported
this to happen 100%, and I reproduced it once with cold VM host caches.

dracut-zfs-generator runs as a systemd generator, i.e. at Some
Relatively Early Time; if root= is a fixed dataset, it tries to
"solve [necessities] statically at generation time".

If by that point zfs-import.target hasn't popped (because the import is
taking a non-negligible amount of time for whatever reason), it'll see
no children for the root datase, and as such generate no mounts.

This has never had any right to work. No-one caught this earlier because
it's just that much more convenient to have root=zfs:AUTO, which orders
itself properly.

To fix this, always run zfs-nonroot-necessities.service;
this additionally simplifies the implementation by:
  * making BOOTFS from zfs-env-bootfs.service be the real, canonical,
    root dataset name, not just "whatever the first bootfs is",
    and only set it if we're ZFS-booting
  * zfs-{rollback,snapshot}-bootfs.service can use this instead of
    re-implementing it
  * having zfs-env-bootfs.service also set BOOTFSFLAGS
  * this means the sysroot.mount drop-in can be fixed text
  * zfs-nonroot-necessities.service can also be constant and always
    enabled, because it's conditioned on BOOTFS being set

There is no longer any code generated at run-time
(the sysroot.mount drop-in is an unavoidable gratuitous cp).

The flow of BOOTFS{,FLAGS} from zfs-env-bootfs.service to sysroot.mount
is not noted explicitly in dracut.zfs(7), because (a) at some point it's
just visual noise and (b) it's already ordered via d-p-m.s from z-i.t.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz>
Closes #14690
2023-03-31 09:47:48 -07:00
..
export-zfs.sh.in contrib/dracut: zfs-lib: export_all: replace with inline zpool export -a 2022-03-03 10:45:24 -08:00
import-opts-generator.sh.in Pass --enable=all to shellcheck within contrib/ 2021-11-30 10:23:10 -08:00
module-setup.sh.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
mount-zfs.sh.in dracut: fix typo in mount-zfs.sh.in 2022-06-29 15:33:38 -07:00
parse-zfs.sh.in contrib; dracut: centralise root= parsing, actually support root=s 2022-04-20 16:44:47 -07:00
zfs-env-bootfs.service.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
zfs-generator.sh.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
zfs-lib.sh.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
zfs-load-key.sh.in contrib: dracut: Do not timeout waiting for pw 2023-01-05 12:07:43 -08:00
zfs-needshutdown.sh.in contrib: dracut: zfs-needshutdown: don't list 2022-04-20 16:45:39 -07:00
zfs-nonroot-necessities.service.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
zfs-rollback-bootfs.service.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00
zfs-snapshot-bootfs.service.in contrib: dracut: fix race with root=zfs:dset when necessities required 2023-03-31 09:47:48 -07:00