From 197679ac3ac6257cd4f18f9f5d3c4a17ce63411b Mon Sep 17 00:00:00 2001 From: Joel Sing Date: Mon, 16 Jan 2012 16:29:50 +0000 Subject: Ensure that all disk attach callbacks have completed before attempting to locate the root via DUID. ok krw@ --- sys/kern/subr_disk.c | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) (limited to 'sys/kern') diff --git a/sys/kern/subr_disk.c b/sys/kern/subr_disk.c index 10d181c6fa2..acf29011f81 100644 --- a/sys/kern/subr_disk.c +++ b/sys/kern/subr_disk.c @@ -1,4 +1,4 @@ -/* $OpenBSD: subr_disk.c,v 1.139 2012/01/13 14:39:31 jsing Exp $ */ +/* $OpenBSD: subr_disk.c,v 1.140 2012/01/16 16:29:49 jsing Exp $ */ /* $NetBSD: subr_disk.c,v 1.17 1996/03/16 23:17:08 christos Exp $ */ /* @@ -1161,7 +1161,7 @@ parsedisk(char *str, int len, int defpart, dev_t *devp) void setroot(struct device *bootdv, int part, int exitflags) { - int majdev, unit, len, s; + int majdev, unit, len, s, slept = 0; struct swdevt *swp; struct device *rootdv, *dv; dev_t nrootdev, nswapdev = NODEV, temp = NODEV; @@ -1173,6 +1173,20 @@ setroot(struct device *bootdv, int part, int exitflags) extern char *nfsbootdevname; #endif + /* Ensure that all disk attach callbacks have completed. */ + do { + TAILQ_FOREACH(dk, &disklist, dk_link) { + if ((dk->dk_flags & DKF_OPENED) == 0) { + tsleep(dk, 0, "dkopen", hz); + slept++; + break; + } + } + } while (dk != NULL && slept < 5); + + if (slept == 5) + printf("not all disklabels read successfully\n"); + /* Locate DUID for boot disk if not already provided. */ bzero(duid, sizeof(duid)); if (bcmp(bootduid, duid, sizeof(bootduid)) == 0) { -- cgit v1.2.3