summaryrefslogtreecommitdiffstats
path: root/sbin/vinum/commands.c
diff options
context:
space:
mode:
authorgrog <grog@FreeBSD.org>1999-08-24 02:31:19 +0000
committergrog <grog@FreeBSD.org>1999-08-24 02:31:19 +0000
commit922bb45cf94f8ee09141eff2cd1177789595b322 (patch)
treee38b8a5199ff44872f6dc037cd91eb350490226c /sbin/vinum/commands.c
parent685c3b6c7f18af01b0ea2bb14b2a3d34624959b3 (diff)
downloadFreeBSD-src-922bb45cf94f8ee09141eff2cd1177789595b322.zip
FreeBSD-src-922bb45cf94f8ee09141eff2cd1177789595b322.tar.gz
Tidy up some indentation and comments.
vinum_init(): Change name of variable plexindex to objindex, which better describes its purpose. initsd(): Add a second parameter to determine whether it should wait for completion or not. This allows it to DTRT when called with the -w flag either directly or via initplex(). Add 'setstate' command (function vinum_setstate ()) to implement the VINUM_SETSTATE_FORCE ioctl for diddling individual object states. This is a repair tool which can also be used for panicing the system. Use with utmost care if at all. Add unimplemented commands 'checkparity' and 'rebuildparity'. Watch this space.
Diffstat (limited to 'sbin/vinum/commands.c')
-rw-r--r--sbin/vinum/commands.c124
1 files changed, 109 insertions, 15 deletions
diff --git a/sbin/vinum/commands.c b/sbin/vinum/commands.c
index eb02f5d..5173e00 100644
--- a/sbin/vinum/commands.c
+++ b/sbin/vinum/commands.c
@@ -138,10 +138,16 @@ vinum_create(int argc, char *argv[], char *arg0[])
if (reply->error != 0) { /* error in config */
if (!verbose) /* print this line anyway */
printf("%4d: %s", file_line, commandline);
- fprintf(stdout, "** %d %s: %s\n", file_line, reply->msg, strerror(reply->error));
- /* XXX at the moment, we reset the config
+ fprintf(stdout, "** %d %s: %s\n",
+ file_line,
+ reply->msg,
+ strerror(reply->error));
+
+ /*
+ * XXX at the moment, we reset the config
* lock on error, so try to get it again.
- * If we fail, don't cry again */
+ * If we fail, don't cry again.
+ */
if (ioctl(superdev, VINUM_STARTCONFIG, &force)) /* can't get config? */
return;
}
@@ -291,16 +297,16 @@ void
vinum_init(int argc, char *argv[], char *arg0[])
{
if (argc > 0) { /* initialize plexes */
- int plexindex;
+ int objindex;
int objno;
enum objecttype type; /* type returned */
if (history)
fflush(history); /* don't let all the kids do it. */
- for (plexindex = 0; plexindex < argc; plexindex++) {
- objno = find_object(argv[plexindex], &type); /* find the object */
+ for (objindex = 0; objindex < argc; objindex++) {
+ objno = find_object(argv[objindex], &type); /* find the object */
if (objno < 0)
- printf("Can't find %s\n", argv[plexindex]);
+ printf("Can't find %s\n", argv[objindex]);
else {
switch (type) {
case volume_object:
@@ -308,15 +314,15 @@ vinum_init(int argc, char *argv[], char *arg0[])
break;
case plex_object:
- initplex(objno, argv[plexindex]);
+ initplex(objno, argv[objindex]);
break;
case sd_object:
- initsd(objno);
+ initsd(objno, dowait);
break;
default:
- printf("Can't initalize %s: wrong object type\n", argv[plexindex]);
+ printf("Can't initalize %s: wrong object type\n", argv[objindex]);
break;
}
}
@@ -362,12 +368,13 @@ initplex(int plexno, char *name)
}
}
/*
- * If we get here, we're either the first-level child
- * (if we're not waiting) or we're going to wait.
+ * If we get here, we're either the first-level
+ * child (if we're not waiting) or we're going
+ * to wait.
*/
for (sdno = 0; sdno < plex.subdisks; sdno++) { /* initialize each subdisk */
get_plex_sd_info(&sd, plexno, sdno);
- initsd(sd.sdno);
+ initsd(sd.sdno, 0);
}
/* Now wait for them to complete */
while (1) {
@@ -399,7 +406,7 @@ initplex(int plexno, char *name)
}
void
-initsd(int sdno)
+initsd(int sdno, int dowait)
{
pid_t pid;
struct _ioctl_reply reply;
@@ -557,7 +564,7 @@ vinum_start(int argc, char *argv[], char *arg0[])
else
fprintf(stderr,
"Can't start %s: %s (%d)\n",
- argv[index],
+ sd.name,
reply.msg[0] ? reply.msg : strerror(reply.error),
reply.error);
}
@@ -1764,6 +1771,93 @@ vinum_readpol(int argc, char *argv[], char *argv0[])
if (verbose)
vinum_lpi(plexno, recurse);
}
+
+/*
+ * Brute force set state function. Don't look at
+ * any dependencies, just do it.
+ */
+void
+vinum_setstate(int argc, char *argv[], char *argv0[])
+{
+ int object;
+ struct _ioctl_reply reply;
+ struct vinum_ioctl_msg *message = (struct vinum_ioctl_msg *) &reply;
+ int index;
+ enum objecttype type;
+ int state;
+
+ for (index = 1; index < argc; index++) {
+ object = find_object(argv[index], &type); /* look for it */
+ if (type == invalid_object)
+ fprintf(stderr, "Can't find object: %s\n", argv[index]);
+ else {
+ int doit = 0; /* set to 1 if we pass our tests */
+ switch (type) {
+ case drive_object:
+ state = DriveState(argv[0]); /* get the state */
+ if (drive.state == state) /* already in that state */
+ fprintf(stderr, "%s is already %s\n", drive.label.name, argv[0]);
+ else
+ doit = 1;
+ break;
+
+ case sd_object:
+ state = SdState(argv[0]); /* get the state */
+ if (sd.state == state) /* already in that state */
+ fprintf(stderr, "%s is already %s\n", sd.name, argv[0]);
+ else
+ doit = 1;
+ break;
+
+ case plex_object:
+ state = PlexState(argv[0]); /* get the state */
+ if (plex.state == state) /* already in that state */
+ fprintf(stderr, "%s is already %s\n", plex.name, argv[0]);
+ else
+ doit = 1;
+ break;
+
+ case volume_object:
+ state = VolState(argv[0]); /* get the state */
+ if (vol.state == state) /* already in that state */
+ fprintf(stderr, "%s is already %s\n", vol.name, argv[0]);
+ else
+ doit = 1;
+ break;
+
+ default:
+ }
+
+ if (state == -1)
+ fprintf(stderr, "Invalid state for object: %s\n", argv[0]);
+ else if (doit) {
+ message->index = object; /* pass object number */
+ message->type = type; /* and type of object */
+ message->state = state;
+ message->force = force; /* don't force it, use a larger hammer */
+ ioctl(superdev, VINUM_SETSTATE_FORCE, message);
+ if (reply.error != 0)
+ fprintf(stderr,
+ "Can't start %s: %s (%d)\n",
+ argv[index],
+ reply.msg[0] ? reply.msg : strerror(reply.error),
+ reply.error);
+ if (Verbose)
+ vinum_li(object, type);
+ }
+ }
+ }
+}
+
+void
+vinum_checkparity(int argc, char *argv[], char *argv0[])
+{
+}
+void
+vinum_rebuildparity(int argc, char *argv[], char *argv0[])
+{
+}
+
/* Local Variables: */
/* fill-column: 50 */
/* End: */
OpenPOWER on IntegriCloud