aboutsummaryrefslogtreecommitdiff
path: root/sys/nfs
diff options
context:
space:
mode:
authorIan Lepore <ian@FreeBSD.org>2015-09-26 13:55:55 +0000
committerIan Lepore <ian@FreeBSD.org>2015-09-26 13:55:55 +0000
commite488229ba4cde5788cb018b15365667d8afa2400 (patch)
tree5dab90e83e7ab5d8e456de14c760662518e47595 /sys/nfs
parent2e33ae99cfeb06745e92c89d620c39f419aeefea (diff)
downloadsrc-e488229ba4cde5788cb018b15365667d8afa2400.tar.gz
src-e488229ba4cde5788cb018b15365667d8afa2400.zip
Wait up to 10 seconds for late-initializing network interfaces to arrive.
Reviewed by: rmacklem
Notes
Notes: svn path=/head/; revision=288265
Diffstat (limited to 'sys/nfs')
-rw-r--r--sys/nfs/nfs_diskless.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/sys/nfs/nfs_diskless.c b/sys/nfs/nfs_diskless.c
index 3882007dff0f..864aae0bc8ee 100644
--- a/sys/nfs/nfs_diskless.c
+++ b/sys/nfs/nfs_diskless.c
@@ -57,6 +57,8 @@ __FBSDID("$FreeBSD$");
#include <nfsclient/nfs.h>
#include <nfs/nfsdiskless.h>
+#define NFS_IFACE_TIMEOUT_SECS 10 /* Timeout for interface to appear. */
+
static int inaddr_to_sockaddr(char *ev, struct sockaddr_in *sa);
static int hwaddr_to_sockaddr(char *ev, struct sockaddr_dl *sa);
static int decode_nfshandle(char *ev, u_char *fh, int maxfh);
@@ -170,6 +172,7 @@ nfs_setup_diskless(void)
char *cp;
int cnt, fhlen, is_nfsv3;
uint32_t len;
+ time_t timeout_at;
if (nfs_diskless_valid != 0)
return;
@@ -214,6 +217,8 @@ nfs_setup_diskless(void)
return;
}
ifa = NULL;
+ timeout_at = time_uptime + NFS_IFACE_TIMEOUT_SECS;
+retry:
CURVNET_SET(TD_TO_VNET(curthread));
IFNET_RLOCK();
TAILQ_FOREACH(ifp, &V_ifnet, if_link) {
@@ -234,6 +239,10 @@ nfs_setup_diskless(void)
}
IFNET_RUNLOCK();
CURVNET_RESTORE();
+ if (time_uptime < timeout_at) {
+ pause("nfssdl", hz / 5);
+ goto retry;
+ }
printf("nfs_diskless: no interface\n");
return; /* no matching interface */
match_done: