diff options
author | peter <peter@FreeBSD.org> | 2001-09-20 02:15:17 +0000 |
---|---|---|
committer | peter <peter@FreeBSD.org> | 2001-09-20 02:15:17 +0000 |
commit | 0bbcfd5027b99755d085fbcf82c63b6738ff9b48 (patch) | |
tree | 394d58338bc461a547e1dbc3456031fdbe3f5a31 /sbin/mountd | |
parent | 56aeb25ed107e0ae1b55d9ba48a579d5f3109355 (diff) | |
download | FreeBSD-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.c | 23 |
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); } |