summaryrefslogtreecommitdiffstats
path: root/sbin/vinum/commands.c
diff options
context:
space:
mode:
authorgrog <grog@FreeBSD.org>1999-10-13 03:27:06 +0000
committergrog <grog@FreeBSD.org>1999-10-13 03:27:06 +0000
commitdc37e533a4305b4e4fb37d12d8999298f03e4c5a (patch)
treede206b6b58b9463af2c5d09a2f5048b01bb8a879 /sbin/vinum/commands.c
parent7e038455663efb2b12dafb8a59cd202019372c69 (diff)
downloadFreeBSD-src-dc37e533a4305b4e4fb37d12d8999298f03e4c5a.zip
FreeBSD-src-dc37e533a4305b4e4fb37d12d8999298f03e4c5a.tar.gz
Change the name of the v flag variable from 'verbose' to 'vflag',
indicating the multiple use (verbose or verify). initsd: rewrite: Initialization is now done in the kernel. Verify (again!) if -v is specified. Allow specification of a blocksize, the length to be transferred in one transfer. vinum_revive: Allow specification of a blocksize, the length to be transferred in one transfer.
Diffstat (limited to 'sbin/vinum/commands.c')
-rw-r--r--sbin/vinum/commands.c153
1 files changed, 110 insertions, 43 deletions
diff --git a/sbin/vinum/commands.c b/sbin/vinum/commands.c
index 7a2b4fa..6d77ebb 100644
--- a/sbin/vinum/commands.c
+++ b/sbin/vinum/commands.c
@@ -36,10 +36,10 @@
* otherwise) arising in any way out of the use of this software, even if
* advised of the possibility of such damage.
*
+ * $Id: commands.c,v 1.9 1999/10/13 02:33:26 grog Exp grog $
+ * $FreeBSD$
*/
-/* $FreeBSD$ */
-
#include <ctype.h>
#include <errno.h>
#include <fcntl.h>
@@ -131,12 +131,12 @@ vinum_create(int argc, char *argv[], char *arg0[])
break;
}
file_line++; /* count the lines */
- if (verbose)
+ if (vflag)
printf("%4d: %s", file_line, buffer);
strcpy(commandline, buffer); /* make a copy */
ioctl(superdev, VINUM_CREATE, buffer);
if (reply->error != 0) { /* error in config */
- if (!verbose) /* print this line anyway */
+ if (!vflag) /* print this line anyway */
printf("%4d: %s", file_line, commandline);
fprintf(stdout, "** %d %s: %s\n",
file_line,
@@ -257,7 +257,7 @@ vinum_rm(int argc, char *argv[], char *arg0[])
argv[index],
reply.msg[0] ? reply.msg : strerror(reply.error),
reply.error);
- } else if (verbose)
+ } else if (vflag)
fprintf(stderr, "%s removed\n", argv[index]);
}
}
@@ -405,6 +405,14 @@ initplex(int plexno, char *name)
exit(0); /* we've done our dash */
}
+/*
+ * Initialize a subdisk. Currently (October 1999)
+ * there is something very funny with
+ * initialization, and it's a good idea to verify.
+ * We do this twice, once in the kernel and once
+ * after finishing the initialization. One day
+ * this should be removed.
+ */
void
initsd(int sdno, int dowait)
{
@@ -412,13 +420,14 @@ initsd(int sdno, int dowait)
struct _ioctl_reply reply;
struct vinum_ioctl_msg *message = (struct vinum_ioctl_msg *) &reply;
char filename[MAXPATHLEN]; /* create a file name here */
+ off_t pos;
/* Variables for use by children */
int sdfh; /* and for subdisk */
- char zeros[PLEXINITSIZE];
- int count; /* write count */
- long long offset; /* offset in subdisk */
+ char buf[MAXPLEXINITSIZE];
+ int initsize; /* actual size to write */
long long sdsize; /* size of subdisk */
+ int retval;
if (dowait == 0) {
pid = fork(); /* into the background with you */
@@ -429,8 +438,13 @@ initsd(int sdno, int dowait)
return;
}
}
+ if (SSize != 0) { /* specified a size for init */
+ if (SSize < 512)
+ SSize <<= DEV_BSHIFT;
+ initsize = min(SSize, MAXPLEXINITSIZE);
+ } else
+ initsize = PLEXINITSIZE;
openlog("vinum", LOG_CONS | LOG_PERROR | LOG_PID, LOG_KERN);
- bzero(zeros, sizeof(zeros));
get_sd_info(&sd, sdno);
sdsize = sd.sectors * DEV_BSIZE; /* size of subdisk in bytes */
sprintf(filename, VINUM_DIR "/rsd/%s", sd.name);
@@ -447,27 +461,66 @@ initsd(int sdno, int dowait)
message->index = sd.sdno; /* pass object number */
message->type = sd_object; /* and type of object */
message->state = object_initializing;
+ message->verify = vflag; /* verify what we write? */
message->force = 1; /* insist */
ioctl(superdev, VINUM_SETSTATE, message);
- for (offset = 0; offset < sdsize; offset += count) {
- count = write(sdfh, zeros, PLEXINITSIZE); /* write a block */
- if (count < 0) {
+ if ((SSize > 0) /* specified a size for init */
+ &&(SSize < 512))
+ SSize <<= DEV_BSHIFT;
+ if (reply.error) {
+ fprintf(stderr, "Can't initialize %s: %s (%d)\n",
+ filename,
+ strerror(reply.error),
+ reply.error);
+ exit(1);
+ } else {
+ do {
+ message->index = sd.sdno; /* pass object number */
+ message->type = sd_object; /* and type of object */
+ message->state = object_up;
+ message->verify = vflag; /* verify what we write? */
+ message->blocksize = SSize;
+ ioctl(superdev, VINUM_SETSTATE, message);
+ }
+ while (reply.error == EAGAIN); /* until we're done */
+ }
+ if (vflag) { /* don't trust the thing, check again */
+ close(sdfh);
+ pos = 0;
+ if ((sdfh = open(filename, O_RDWR, S_IRWXU)) < 0) { /* no go */
syslog(LOG_ERR | LOG_KERN,
- "can't write subdisk %s: %s",
+ "can't open subdisk %s: %s",
filename,
strerror(errno));
exit(1);
- } else if (count == 0)
- break;
+ } else {
+ for (;;) { /* damn style(9) */
+ retval = read(sdfh, buf, initsize);
+ if (retval == 0) /* EOF */
+ break;
+ else if (retval < 0) {
+ fprintf(stderr,
+ "Can't read %s: %s (%d)\n",
+ sd.name,
+ strerror(errno),
+ errno);
+ if (dowait)
+ return;
+ else
+ exit(1);
+ } else if ((buf[0] != 0) /* first word spammed */
+ ||(bcmp(buf, &buf[1], initsize - 1))) { /* or one of the others */
+ fprintf(stderr,
+ "init error on %s, offset 0x%llx sectors\n",
+ sd.name,
+ pos);
+ }
+ pos += retval;
+ }
+ }
}
- syslog(LOG_INFO | LOG_KERN, "subdisk %s initialized", filename);
- /* Bring the subdisk up */
- message->index = sd.sdno; /* pass object number */
- message->type = sd_object; /* and type of object */
- message->state = object_initialized;
- message->force = 0; /* don't insist */
- ioctl(superdev, VINUM_SETSTATE, message);
- exit(0);
+ if (!dowait)
+ exit(0);
}
void
@@ -486,6 +539,7 @@ vinum_start(int argc, char *argv[], char *arg0[])
char **token; /* list of tokens */
int tokens; /* and their number */
+ bzero(&statinfo, sizeof(struct statinfo));
statinfo.dinfo = malloc(devs * sizeof(struct statinfo));
namelist = malloc(devs * (DEVSTAT_NAME_LEN + 8));
token = malloc((devs + 1) * sizeof(char *));
@@ -559,6 +613,19 @@ vinum_start(int argc, char *argv[], char *arg0[])
message->type = sd_object; /* it's a subdisk */
message->state = object_up;
message->force = force; /* don't force it, use a larger hammer */
+
+ /*
+ * We don't do any checking here.
+ * The kernel module has a better
+ * understanding of these things,
+ * let it do it.
+ */
+ if (SSize != 0) { /* specified a size for init */
+ if (SSize < 512)
+ SSize <<= DEV_BSHIFT;
+ message->blocksize = SSize;
+ } else
+ message->blocksize = 0;
ioctl(superdev, VINUM_SETSTATE, message);
if (reply.error != 0) {
if (reply.error == EAGAIN) /* we're reviving */
@@ -1286,7 +1353,7 @@ create_drive(char *devicename)
char command[MAXDRIVENAME * 2];
sprintf(command, "drive %s device %s", drivename, devicename); /* create a create command */
- if (verbose)
+ if (vflag)
printf("drive %s device %s\n", drivename, devicename); /* create a create command */
ioctl(superdev, VINUM_CREATE, command);
reply = (struct _ioctl_reply *) &command;
@@ -1339,7 +1406,7 @@ vinum_concat(int argc, char *argv[], char *argv0[])
if (!objectname) /* we need a name for our object */
genvolname();
sprintf(buffer, "volume %s", objectname);
- if (verbose)
+ if (vflag)
printf("volume %s\n", objectname);
ioctl(superdev, VINUM_CREATE, buffer); /* create the volume */
if (reply->error != 0) { /* error in config */
@@ -1357,7 +1424,7 @@ vinum_concat(int argc, char *argv[], char *argv0[])
longjmp(command_fail, -1); /* give up */
}
sprintf(buffer, "plex name %s.p0 org concat", objectname);
- if (verbose)
+ if (vflag)
printf(" plex name %s.p0 org concat\n", objectname);
ioctl(superdev, VINUM_CREATE, buffer);
if (reply->error != 0) { /* error in config */
@@ -1378,7 +1445,7 @@ vinum_concat(int argc, char *argv[], char *argv0[])
if ((drive = find_drive_by_devname(argv[o])) == NULL) /* doesn't exist */
drive = create_drive(argv[o]); /* create it */
sprintf(buffer, "sd name %s.p0.s%d drive %s size 0", objectname, o, drive->label.name);
- if (verbose)
+ if (vflag)
printf(" sd name %s.p0.s%d drive %s size 0\n", objectname, o, drive->label.name);
ioctl(superdev, VINUM_CREATE, buffer);
if (reply->error != 0) { /* error in config */
@@ -1406,8 +1473,8 @@ vinum_concat(int argc, char *argv[], char *argv0[])
perror("Can't save Vinum config");
find_object(objectname, &type); /* find the index of the volume */
make_vol_dev(vol.volno, 1); /* and create the devices */
- if (verbose) {
- verbose--; /* XXX don't give too much detail */
+ if (vflag) {
+ vflag--; /* XXX don't give too much detail */
find_object(objectname, &type); /* point to the volume */
vinum_lvi(vol.volno, 1); /* and print info about it */
}
@@ -1475,7 +1542,7 @@ vinum_stripe(int argc, char *argv[], char *argv0[])
/* Now create the volume */
sprintf(buffer, "volume %s", objectname);
- if (verbose)
+ if (vflag)
printf("volume %s\n", objectname);
ioctl(superdev, VINUM_CREATE, buffer); /* create the volume */
if (reply->error != 0) { /* error in config */
@@ -1493,7 +1560,7 @@ vinum_stripe(int argc, char *argv[], char *argv0[])
longjmp(command_fail, -1); /* give up */
}
sprintf(buffer, "plex name %s.p0 org striped 256k", objectname);
- if (verbose)
+ if (vflag)
printf(" plex name %s.p0 org striped 256k\n", objectname);
ioctl(superdev, VINUM_CREATE, buffer);
if (reply->error != 0) { /* error in config */
@@ -1518,7 +1585,7 @@ vinum_stripe(int argc, char *argv[], char *argv0[])
o,
drive->label.name,
maxsize);
- if (verbose)
+ if (vflag)
printf(" sd name %s.p0.s%d drive %s size %lldb\n",
objectname,
o,
@@ -1550,8 +1617,8 @@ vinum_stripe(int argc, char *argv[], char *argv0[])
perror("Can't save Vinum config");
find_object(objectname, &type); /* find the index of the volume */
make_vol_dev(vol.volno, 1); /* and create the devices */
- if (verbose) {
- verbose--; /* XXX don't give too much detail */
+ if (vflag) {
+ vflag--; /* XXX don't give too much detail */
find_object(objectname, &type); /* point to the volume */
vinum_lvi(vol.volno, 1); /* and print info about it */
}
@@ -1635,7 +1702,7 @@ vinum_mirror(int argc, char *argv[], char *argv0[])
/* Now create the volume */
sprintf(buffer, "volume %s setupstate", objectname);
- if (verbose)
+ if (vflag)
printf("volume %s setupstate\n", objectname);
ioctl(superdev, VINUM_CREATE, buffer); /* create the volume */
if (reply->error != 0) { /* error in config */
@@ -1655,11 +1722,11 @@ vinum_mirror(int argc, char *argv[], char *argv0[])
for (p = 0; p < 2; p++) { /* create each plex */
if (sflag) {
sprintf(buffer, "plex name %s.p%d org striped 256k", objectname, p);
- if (verbose)
+ if (vflag)
printf(" plex name %s.p%d org striped 256k\n", objectname, p);
} else { /* concat */
sprintf(buffer, "plex name %s.p%d org concat", objectname, p);
- if (verbose)
+ if (vflag)
printf(" plex name %s.p%d org concat\n", objectname, p);
}
ioctl(superdev, VINUM_CREATE, buffer);
@@ -1689,7 +1756,7 @@ vinum_mirror(int argc, char *argv[], char *argv0[])
o >> 1,
drive->label.name,
maxsize[p]);
- if (verbose)
+ if (vflag)
printf(" sd name %s.p%d.s%d drive %s size %lldb\n",
objectname,
p,
@@ -1725,8 +1792,8 @@ vinum_mirror(int argc, char *argv[], char *argv0[])
perror("Can't save Vinum config");
find_object(objectname, &type); /* find the index of the volume */
make_vol_dev(vol.volno, 1); /* and create the devices */
- if (verbose) {
- verbose--; /* XXX don't give too much detail */
+ if (vflag) {
+ vflag--; /* XXX don't give too much detail */
sflag = 0; /* no stats, please */
find_object(objectname, &type); /* point to the volume */
vinum_lvi(vol.volno, 1); /* and print info about it */
@@ -1770,7 +1837,7 @@ vinum_readpol(int argc, char *argv[], char *argv0[])
message->otherobject = plexno;
if (ioctl(superdev, VINUM_READPOL, message) < 0)
fprintf(stderr, "Can't set read policy: %s (%d)\n", strerror(errno), errno);
- if (verbose)
+ if (vflag)
vinum_lpi(plexno, recurse);
}
@@ -1879,7 +1946,7 @@ vinum_checkparity(int argc, char *argv[], char *argv0[])
message->index = object; /* pass object number */
message->type = type; /* and type of object */
ioctl(superdev, VINUM_CHECKPARITY, message);
- if (verbose) {
+ if (vflag) {
get_plex_info(&plex, object);
if (plex.checkblock != 0)
printf("\rChecking at %s ", roughlength(plex.checkblock << DEV_BSHIFT, 1));
@@ -1894,7 +1961,7 @@ vinum_checkparity(int argc, char *argv[], char *argv0[])
fprintf(stderr,
"checkparity failed: %s\n",
strerror(reply.error));
- } else if (verbose)
+ } else if (vflag)
fprintf(stderr, "%s has correct parity\n", argv[index]);
}
}
OpenPOWER on IntegriCloud