conf/116177: rc.d/mdconfig2 script fail at -CURRENT
Rémi Guyomarch
rguyom at pobox.com
Sun Sep 30 09:10:08 PDT 2007
The following reply was made to PR conf/116177; it has been noted by GNATS.
From: =?ISO-8859-1?Q?R=E9mi_Guyomarch?= <rguyom at pobox.com>
To: bug-followup at FreeBSD.org, dindin at dindin.ru
Cc:
Subject: Re: conf/116177: rc.d/mdconfig2 script fail at -CURRENT
Date: Sun, 30 Sep 2007 16:57:42 +0200
I had the exact same problem but I fixed it by patching /sbin/mdconfig
instead. With this patch, "/sbin/mdconfig -l -u md0" will return 0 if
md0 exists and -1 if not. It has the advantage of fixing the bug in both
/etc/rc.d/mdconfig and /etc/rc.d/mdconfig2.
--- /usr/src/sbin/mdconfig/mdconfig.c~ 2007-09-30 15:25:16.000000000 +0200
+++ /usr/src/sbin/mdconfig/mdconfig.c 2007-09-30 15:25:16.000000000 +0200
@@ -284,7 +284,7 @@
*/
md_list(NULL, OPT_LIST);
} else {
- md_query(mdunit);
+ return (md_query(mdunit));
}
} else if (action == ATTACH) {
if (cmdline < 2)
@@ -323,7 +323,7 @@
struct ggeom *gg;
struct gclass *gcl;
void *sq;
- int retcode;
+ int retcode, found;
char *type, *file, *length;
type = file = length = NULL;
@@ -338,6 +338,7 @@
if (sq == NULL)
return (-1);
+ found = 0;
while ((gsp = geom_stats_snapshot_next(sq)) != NULL) {
gid = geom_lookupid(&gm, gsp->id);
if (gid == NULL)
@@ -352,6 +353,8 @@
retcode = md_find(units, pp->lg_name);
if (retcode != 1)
continue;
+ else
+ found = 1;
}
gc = &pp->lg_config;
printf("%s", pp->lg_name);
@@ -380,7 +383,10 @@
printf("\n");
/* XXX: Check if it's enough to clean everything. */
geom_stats_snapshot_free(sq);
- return (-1);
+ if ((opt & OPT_UNIT) && found)
+ return (0);
+ else
+ return (-1);
}
/*
More information about the freebsd-rc
mailing list