summaryrefslogtreecommitdiffstats
path: root/etc
diff options
context:
space:
mode:
authorrmacklem <rmacklem@FreeBSD.org>2011-04-26 00:22:17 +0000
committerrmacklem <rmacklem@FreeBSD.org>2011-04-26 00:22:17 +0000
commit617fb5f51700207d1e18631393930ccbcff389db (patch)
treede06a474f87dccafec1e8653aebc5b96e755ca06 /etc
parentebe803c4913a501588fff3a8fb3afd3c96f618e6 (diff)
downloadFreeBSD-src-617fb5f51700207d1e18631393930ccbcff389db.zip
FreeBSD-src-617fb5f51700207d1e18631393930ccbcff389db.tar.gz
Update the /etc/rc.d scripts for mountd and nfsd so they
can use the "-o" option to force the old NFS server to run. Running the old NFS server is enabled by setting oldnfs_server_enable="YES". The scripts will only enable providing service for NFSv4 if nfsv4_server_enable="YES" is set. Reviewed by: dougb (rc)
Diffstat (limited to 'etc')
-rw-r--r--etc/defaults/rc.conf1
-rwxr-xr-xetc/rc.d/mountd7
-rwxr-xr-xetc/rc.d/nfsd39
3 files changed, 30 insertions, 17 deletions
diff --git a/etc/defaults/rc.conf b/etc/defaults/rc.conf
index 51fdf25..21007d6 100644
--- a/etc/defaults/rc.conf
+++ b/etc/defaults/rc.conf
@@ -323,6 +323,7 @@ amd_map_program="NO" # Can be set to "ypcat -k amd.master"
nfs_client_enable="NO" # This host is an NFS client (or NO).
nfs_access_cache="60" # Client cache timeout in seconds
nfs_server_enable="NO" # This host is an NFS server (or NO).
+oldnfs_server_enable="NO" # Run the old NFS server (YES/NO).
nfs_server_flags="-u -t -n 4" # Flags to nfsd (if enabled).
mountd_enable="NO" # Run mountd (or NO).
mountd_flags="-r" # Flags to mountd (if NFS server enabled).
diff --git a/etc/rc.d/mountd b/etc/rc.d/mountd
index e893e98..1fad302 100755
--- a/etc/rc.d/mountd
+++ b/etc/rc.d/mountd
@@ -37,11 +37,10 @@ mountd_precmd()
fi
fi
- # If nfsv4_server_enable is yes, force use of the experimental
- # server
+ # If oldnfs_server_enable is yes, force use of the old NFS server
#
- if checkyesno nfsv4_server_enable; then
- rc_flags="-e ${rc_flags}"
+ if checkyesno oldnfs_server_enable; then
+ rc_flags="-o ${rc_flags}"
fi
if checkyesno zfs_enable; then
diff --git a/etc/rc.d/nfsd b/etc/rc.d/nfsd
index bbfe563..402ba2d 100755
--- a/etc/rc.d/nfsd
+++ b/etc/rc.d/nfsd
@@ -19,19 +19,8 @@ sig_stop="USR1"
nfsd_precmd()
{
- if checkyesno nfsv4_server_enable; then
- # If nfsv4_server_enable is yes, force use
- # of the experimental server
- #
- rc_flags="-e ${nfs_server_flags}"
-
- if ! checkyesno nfsuserd_enable && \
- ! /etc/rc.d/nfsuserd forcestatus 1>/dev/null 2>&1
- then
- force_depend nfsuserd || return 1
- fi
- else
- rc_flags="${nfs_server_flags}"
+ if checkyesno oldnfs_server_enable; then
+ rc_flags="-o ${nfs_server_flags}"
if ! sysctl vfs.nfsrv >/dev/null 2>&1; then
force_depend nfsserver || return 1
@@ -41,6 +30,30 @@ nfsd_precmd()
echo 'NFS on reserved port only=YES'
sysctl vfs.nfsrv.nfs_privport=1 > /dev/null
fi
+ else
+ rc_flags="${nfs_server_flags}"
+
+ # Load the modules now, so that the vfs.newnfs sysctl
+ # oids are available.
+ load_kld nfsd
+
+ if checkyesno nfs_reserved_port_only; then
+ echo 'NFS on reserved port only=YES'
+ sysctl vfs.newnfs.nfs_privport=1 > /dev/null
+ fi
+
+ if checkyesno nfsv4_server_enable; then
+ if ! checkyesno nfsuserd_enable && \
+ ! /etc/rc.d/nfsuserd forcestatus 1>/dev/null 2>&1
+ then
+ if ! force_depend nfsuserd; then
+ err 1 "Cannot run nfsuserd"
+ fi
+ fi
+ else
+ echo 'NFSv4 is disabled'
+ sysctl vfs.newnfs.server_max_nfsvers=3 > /dev/null
+ fi
fi
if ! checkyesno rpcbind_enable && \
OpenPOWER on IntegriCloud