Change dsioctl() interface to allow DIOCSYNCSLICEINFO to update the caller's

slice pointer and to print the device name in error messages.
This commit is contained in:
bde 1995-04-30 15:14:34 +00:00
parent 8427285121
commit 8467ec16ea
4 changed files with 12 additions and 11 deletions

View File

@ -403,8 +403,9 @@ vnioctl(dev_t dev, u_long cmd, caddr_t data, int flag, struct proc *p)
IFOPT(vn,VN_LABELS) {
if (vn->sc_slices != NULL) {
error = dsioctl(dev, cmd, data, flag, vn->sc_slices,
vnstrategy, (ds_setgeom_t *)NULL);
error = dsioctl("vn", dev, cmd, data, flag,
&vn->sc_slices, vnstrategy,
(ds_setgeom_t *)NULL);
if (error != -1)
return (error);
}

View File

@ -34,7 +34,7 @@
* SUCH DAMAGE.
*
* from: @(#)wd.c 7.2 (Berkeley) 5/9/91
* $Id: wd.c,v 1.75 1995/04/24 04:32:31 dyson Exp $
* $Id: wd.c,v 1.77 1995/04/24 05:12:29 phk Exp $
*/
/* TODO:
@ -1565,8 +1565,8 @@ wdioctl(dev_t dev, int cmd, caddr_t addr, int flags, struct proc *p)
du = wddrives[lunit];
wdsleep(du->dk_ctrlr, "wdioct");
error = dsioctl(dev, cmd, addr, flags, du->dk_slices, wdstrategy1,
(ds_setgeom_t *)NULL);
error = dsioctl("wd", dev, cmd, addr, flags, &du->dk_slices,
wdstrategy1, (ds_setgeom_t *)NULL);
if (error != -1)
return (error);

View File

@ -14,7 +14,7 @@
*
* Ported to run under 386BSD by Julian Elischer (julian@dialix.oz.au) Sept 1992
*
* $Id: sd.c,v 1.60 1995/04/23 22:07:53 gibbs Exp $
* $Id: sd.c,v 1.61 1995/04/29 17:52:44 dufault Exp $
*/
#define SPLSD splbio
@ -575,8 +575,8 @@ sd_ioctl(dev_t dev, int cmd, caddr_t addr, int flag, struct proc *p,
if (cmd == DIOCSBAD)
return (EINVAL); /* XXX */
error = dsioctl(dev, cmd, addr, flag, sd->dk_slices, sdstrategy1,
(ds_setgeom_t *)NULL);
error = dsioctl("sd", dev, cmd, addr, flag, &sd->dk_slices,
sdstrategy1, (ds_setgeom_t *)NULL);
if (error != -1)
return (error);
if (PARTITION(dev) != RAW_PART && !SCSI_SUPER(dev))

View File

@ -23,7 +23,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
* $Id: diskslice.h,v 1.5 1995/03/04 11:05:44 bde Exp $
* $Id: diskslice.h,v 1.6 1995/04/24 17:07:08 bde Exp $
*/
#ifndef _SYS_DISKSLICE_H_
@ -74,8 +74,8 @@ void dsclose __P((dev_t dev, int mode, struct diskslices *ssp));
void dsgone __P((struct diskslices **sspp));
int dsinit __P((char *dname, dev_t dev, d_strategy_t *strat,
struct disklabel *lp, struct diskslices **sspp));
int dsioctl __P((dev_t dev, int cmd, caddr_t data, int flags,
struct diskslices *ssp, d_strategy_t *strat,
int dsioctl __P((char *dname, dev_t dev, int cmd, caddr_t data, int flags,
struct diskslices **sspp, d_strategy_t *strat,
ds_setgeom_t *setgeom));
int dsisopen __P((struct diskslices *ssp));
char *dsname __P((char *dname, int unit, int slice, int part,