diff options
author | grog <grog@FreeBSD.org> | 2003-05-05 05:33:59 +0000 |
---|---|---|
committer | grog <grog@FreeBSD.org> | 2003-05-05 05:33:59 +0000 |
commit | 25618ca2261142261b81aa45cf99736b366f26de (patch) | |
tree | 0d0f222fd833416699068e03756df1a334b52c95 /sys/dev/vinum | |
parent | 6b74835fffdefce28a29b87d4df3434d62d4004f (diff) | |
download | FreeBSD-src-25618ca2261142261b81aa45cf99736b366f26de.zip FreeBSD-src-25618ca2261142261b81aa45cf99736b366f26de.tar.gz |
Remove DIOCGDINFO ioctl. This almost makes newfs work again without
the -v option, though it's not clear that it won't bite us elsewhere.
Forgotten by: phk
Implement setreadpol() function for the VINUM_READPOL ioctl.
Submitted by: Allan Saddi <allan@saddi.com>
Diffstat (limited to 'sys/dev/vinum')
-rw-r--r-- | sys/dev/vinum/vinumioctl.c | 55 |
1 files changed, 41 insertions, 14 deletions
diff --git a/sys/dev/vinum/vinumioctl.c b/sys/dev/vinum/vinumioctl.c index ea734c8..911470f 100644 --- a/sys/dev/vinum/vinumioctl.c +++ b/sys/dev/vinum/vinumioctl.c @@ -41,7 +41,7 @@ * otherwise) arising in any way out of the use of this software, even if * advised of the possibility of such damage. * - * $Id: vinumioctl.c,v 1.20 2003/04/28 02:54:43 grog Exp $ + * $Id: vinumioctl.c,v 1.21 2003/05/04 05:23:09 grog Exp grog $ * $FreeBSD$ */ @@ -57,6 +57,7 @@ void detachobject(struct vinum_ioctl_msg *); void renameobject(struct vinum_rename_msg *); void replaceobject(struct vinum_ioctl_msg *); void moveobject(struct vinum_ioctl_msg *); +void setreadpol(struct vinum_ioctl_msg *); jmp_buf command_fail; /* return on a failed command */ @@ -86,10 +87,6 @@ vinumioctl(dev_t dev, sd = &SD[objno]; switch (cmd) { - case DIOCGDINFO: /* get disk label */ - get_volume_label(sd->name, 1, sd->sectors, (struct disklabel *) data); - break; - /* * We don't have this stuff on hardware, * so just pretend to do it so that @@ -111,10 +108,6 @@ vinumioctl(dev_t dev, plex = &PLEX[objno]; switch (cmd) { - case DIOCGDINFO: /* get disk label */ - get_volume_label(plex->name, 1, plex->length, (struct disklabel *) data); - break; - /* * We don't have this stuff on hardware, * so just pretend to do it so that @@ -140,10 +133,6 @@ vinumioctl(dev_t dev, return EIO; /* I/O error */ switch (cmd) { - case DIOCGDINFO: /* get disk label */ - get_volume_label(vol->name, vol->plexes, vol->size, (struct disklabel *) data); - break; - /* * We don't have this stuff on hardware, * so just pretend to do it so that @@ -420,6 +409,10 @@ vinum_super_ioctl(dev_t dev, moveobject((struct vinum_ioctl_msg *) data); return 0; + case VINUM_READPOL: + setreadpol((struct vinum_ioctl_msg *) data); + return 0; + default: /* FALLTHROUGH */ break; @@ -633,7 +626,7 @@ attachobject(struct vinum_ioctl_msg *msg) set_sd_state(plex->sdnos[sdno], sd_stale, setstate_force); /* make it stale */ } set_plex_state(plex->plexno, plex_up, setstate_none); /* update plex state */ - give_plex_to_volume(msg->otherobject, msg->index); /* and give it to the volume */ + give_plex_to_volume(msg->otherobject, msg->index, 0); /* and give it to the volume */ update_plex_config(plex->plexno, 0); save_config(); reply->error = 0; /* all went well */ @@ -909,6 +902,40 @@ moveobject(struct vinum_ioctl_msg *msg) reply->error = 0; } +void +setreadpol(struct vinum_ioctl_msg *msg) +{ + struct _ioctl_reply *reply = (struct _ioctl_reply *) msg; + struct volume *vol; + struct plex *plex; + int myplexno = -1; + + /* Check that our objects are valid (i.e. they exist) */ + vol = validvol(msg->index, reply); + if (vol == NULL) + return; + + /* If a plex was specified, check that is is valid */ + if (msg->otherobject >= 0) { + plex = validplex(msg->otherobject, reply); + if (vol == NULL) + return; + + /* Is it attached to this volume? */ + myplexno = my_plex(msg->index, msg->otherobject); + if (myplexno < 0) { + strcpy(reply->msg, "Plex is not attached to volume"); + reply->error = ENOENT; + return; + } + } + lock_config(); + vol->preferred_plex = myplexno; + save_config(); + unlock_config(); + reply->error = 0; +} + /* Local Variables: */ /* fill-column: 50 */ /* End: */ |