aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRick Macklem <rmacklem@FreeBSD.org>2022-01-23 22:17:40 +0000
committerRick Macklem <rmacklem@FreeBSD.org>2022-01-23 22:17:40 +0000
commitf72926eab00ccd956298e44831b519daa704a868 (patch)
tree3ae10dde5176ddb088f55fa96a7aa2047f221696
parent45f0e5710509c510955c56a1b3e7d0e392407b0d (diff)
downloadsrc-f72926eab00ccd956298e44831b519daa704a868.tar.gz
src-f72926eab00ccd956298e44831b519daa704a868.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 Differential Revision: https://reviews.freebsd.org/D33256 MFC after: 3 months
-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