aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRick Macklem <rmacklem@FreeBSD.org>2022-01-23 22:17:40 +0000
committerRick Macklem <rmacklem@FreeBSD.org>2022-04-23 22:21:45 +0000
commit92ecb030d2547a95956b3a6e5240e895ad4eed4e (patch)
treecd96f72facb31bf550ce0f739cf9683c4bf5f250
parentd685aeacce8cb0739d1fd978310dd98adfe7d276 (diff)
downloadsrc-92ecb030d2547a95956b3a6e5240e895ad4eed4e.tar.gz
src-92ecb030d2547a95956b3a6e5240e895ad4eed4e.zip
mountd: Delay starting mountd until after mountlate
PR#254282 reports a problem where nullfs mounts cannot be exported via mountd for FreeBSD 13.0. The problem seems to be that, to do the nullfs mounts in /etc/fstab, they require the "late" mount option, so that the underlying filesystem is mounted (ZFS for the PR). Adding "mountlate" to the REQUIRE list in /etc/rc.d/mountd fixes the problem, but that results in a dependency cycle because /etc/rc.d/lockd specifies: REQUIRE: nfsd BEFORE: DAEMON --> which forces mountd to preceed DAEMON. This patch removes "nfsd" from REQUIRE for lockd and statd, then adds mountlate to REQUIRE for mountd, to fix this problem. Having lockd REQUIRE nfsd was done in the NetBSD code when it was pulled into FreeBSD and there does not seem to be a need for this. In case this causes problems, a long MFC has been specified. PR: 254282 (cherry picked from commit f72926eab00ccd956298e44831b519daa704a868)
-rwxr-xr-xlibexec/rc/rc.d/lockd2
-rwxr-xr-xlibexec/rc/rc.d/mountd2
-rwxr-xr-xlibexec/rc/rc.d/statd2
3 files changed, 3 insertions, 3 deletions
diff --git a/libexec/rc/rc.d/lockd b/libexec/rc/rc.d/lockd
index 565ba35164eb..894b3c136690 100755
--- a/libexec/rc/rc.d/lockd
+++ b/libexec/rc/rc.d/lockd
@@ -5,7 +5,7 @@
#
# PROVIDE: lockd
-# REQUIRE: nfsclient nfsd rpcbind statd
+# REQUIRE: nfsclient rpcbind statd
# BEFORE: DAEMON
# KEYWORD: nojail shutdown
diff --git a/libexec/rc/rc.d/mountd b/libexec/rc/rc.d/mountd
index ba573ad732cc..0c6e75f07d64 100755
--- a/libexec/rc/rc.d/mountd
+++ b/libexec/rc/rc.d/mountd
@@ -4,7 +4,7 @@
#
# PROVIDE: mountd
-# REQUIRE: NETWORKING rpcbind quota
+# REQUIRE: NETWORKING rpcbind quota mountlate
# KEYWORD: nojail shutdown
. /etc/rc.subr
diff --git a/libexec/rc/rc.d/statd b/libexec/rc/rc.d/statd
index 2ff8d45ffde9..e1150c67a16f 100755
--- a/libexec/rc/rc.d/statd
+++ b/libexec/rc/rc.d/statd
@@ -5,7 +5,7 @@
#
# PROVIDE: statd
-# REQUIRE: nfsclient nfsd rpcbind
+# REQUIRE: nfsclient rpcbind
# BEFORE: DAEMON
# KEYWORD: nojail shutdown