summaryrefslogtreecommitdiffstats
path: root/sbin/mountd
diff options
context:
space:
mode:
authorpeter <peter@FreeBSD.org>2001-09-20 02:15:17 +0000
committerpeter <peter@FreeBSD.org>2001-09-20 02:15:17 +0000
commit0bbcfd5027b99755d085fbcf82c63b6738ff9b48 (patch)
tree394d58338bc461a547e1dbc3456031fdbe3f5a31 /sbin/mountd
parent56aeb25ed107e0ae1b55d9ba48a579d5f3109355 (diff)
downloadFreeBSD-src-0bbcfd5027b99755d085fbcf82c63b6738ff9b48.zip
FreeBSD-src-0bbcfd5027b99755d085fbcf82c63b6738ff9b48.tar.gz
Deal with module name changes and autoloading.
Diffstat (limited to 'sbin/mountd')
-rw-r--r--sbin/mountd/mountd.c23
1 files changed, 8 insertions, 15 deletions
diff --git a/sbin/mountd/mountd.c b/sbin/mountd/mountd.c
index 6c9fa0e..b3f220e 100644
--- a/sbin/mountd/mountd.c
+++ b/sbin/mountd/mountd.c
@@ -268,8 +268,7 @@ main(argc, argv)
int udpsock, tcpsock, udp6sock, tcp6sock;
int xcreated = 0, s;
int one = 1;
- int c, error, mib[3];
- struct vfsconf vfc;
+ int c, error;
udp6conf = tcp6conf = NULL;
udp6sock = tcp6sock = NULL;
@@ -285,15 +284,11 @@ main(argc, argv)
have_v6 = 0;
else
close(s);
- error = getvfsbyname("nfs", &vfc);
- if (error && vfsisloadable("nfs")) {
- if(vfsload("nfs"))
- err(1, "vfsload(nfs)");
- endvfsent(); /* flush cache */
- error = getvfsbyname("nfs", &vfc);
+ if (modfind("nfsserver") < 0) {
+ /* Not present in kernel, try loading it */
+ if (kldload("nfsserver") < 0 || modfind("nfsserver") < 0)
+ errx(1, "NFS server is not available or loadable");
}
- if (error)
- errx(1, "NFS support is not available in the running kernel");
while ((c = getopt(argc, argv, "2dlnr")) != -1)
switch (c) {
@@ -377,11 +372,9 @@ main(argc, argv)
skip_v6:
if (!resvport_only) {
- mib[0] = CTL_VFS;
- mib[1] = vfc.vfc_typenum;
- mib[2] = NFS_NFSPRIVPORT;
- if (sysctl(mib, 3, NULL, NULL, &resvport_only,
- sizeof(resvport_only)) != 0 && errno != ENOENT) {
+ if (sysctlbyname("vfs.nfsrv.nfs_privport", NULL, NULL,
+ &resvport_only, sizeof(resvport_only)) != 0 &&
+ errno != ENOENT) {
syslog(LOG_ERR, "sysctl: %m");
exit(1);
}
OpenPOWER on IntegriCloud