Module Name: src
Committed By: christos
Date: Wed Dec 31 17:06:49 UTC 2014
Modified Files:
src/sys/arch/emips/ebus: ace_ebus.c flash_ebus.c
src/sys/dev: ccd.c dksubr.c ld.c vnd.c
src/sys/dev/ata: wd.c
src/sys/dev/mca: ed_mca.c
src/sys/dev/mscp: mscp_disk.c
src/sys/dev/ofw: ofdisk.c
src/sys/dev/qbus: rl.c
src/sys/dev/raidframe: rf_netbsdkintf.c
src/sys/dev/scsipi: sd.c
src/sys/kern: subr_disk.c
Log Message:
Centralize wedge ioctls in disk_ioctl.
To generate a diff of this commit:
cvs rdiff -u -r1.14 -r1.15 src/sys/arch/emips/ebus/ace_ebus.c
cvs rdiff -u -r1.12 -r1.13 src/sys/arch/emips/ebus/flash_ebus.c
cvs rdiff -u -r1.159 -r1.160 src/sys/dev/ccd.c
cvs rdiff -u -r1.56 -r1.57 src/sys/dev/dksubr.c
cvs rdiff -u -r1.78 -r1.79 src/sys/dev/ld.c
cvs rdiff -u -r1.236 -r1.237 src/sys/dev/vnd.c
cvs rdiff -u -r1.415 -r1.416 src/sys/dev/ata/wd.c
cvs rdiff -u -r1.59 -r1.60 src/sys/dev/mca/ed_mca.c
cvs rdiff -u -r1.82 -r1.83 src/sys/dev/mscp/mscp_disk.c
cvs rdiff -u -r1.48 -r1.49 src/sys/dev/ofw/ofdisk.c
cvs rdiff -u -r1.46 -r1.47 src/sys/dev/qbus/rl.c
cvs rdiff -u -r1.318 -r1.319 src/sys/dev/raidframe/rf_netbsdkintf.c
cvs rdiff -u -r1.311 -r1.312 src/sys/dev/scsipi/sd.c
cvs rdiff -u -r1.106 -r1.107 src/sys/kern/subr_disk.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/emips/ebus/ace_ebus.c
diff -u src/sys/arch/emips/ebus/ace_ebus.c:1.14 src/sys/arch/emips/ebus/ace_ebus.c:1.15
--- src/sys/arch/emips/ebus/ace_ebus.c:1.14 Sun Nov 9 05:10:08 2014
+++ src/sys/arch/emips/ebus/ace_ebus.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: ace_ebus.c,v 1.14 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: ace_ebus.c,v 1.15 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 2010 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ace_ebus.c,v 1.14 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ace_ebus.c,v 1.15 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -2247,46 +2247,6 @@ aceioctl(dev_t dev, u_long xfer, void *a
case DIOCCACHESYNC:
return 0;
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(ace->sc_dev));
- return dkwedge_add(dkw);
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(ace->sc_dev));
- return dkwedge_del(dkw);
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return dkwedge_list(&ace->sc_dk, dkwl, l);
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- dkwedge_discover(&ace->sc_dk);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = (void *)addr;
Index: src/sys/arch/emips/ebus/flash_ebus.c
diff -u src/sys/arch/emips/ebus/flash_ebus.c:1.12 src/sys/arch/emips/ebus/flash_ebus.c:1.13
--- src/sys/arch/emips/ebus/flash_ebus.c:1.12 Sun Nov 9 05:10:08 2014
+++ src/sys/arch/emips/ebus/flash_ebus.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: flash_ebus.c,v 1.12 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: flash_ebus.c,v 1.13 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 2010 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: flash_ebus.c,v 1.12 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: flash_ebus.c,v 1.13 2014/12/31 17:06:48 christos Exp $");
/* Driver for the Intel 28F320/640/128 (J3A150) StrataFlash memory device
* Extended to include the Intel JS28F256P30T95.
@@ -2164,46 +2164,6 @@ eflashioctl(dev_t dev, u_long xfer, void
case DIOCCACHESYNC:
return 0;
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(sc->sc_dev));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(sc->sc_dev));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return (dkwedge_list(&sc->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&sc->sc_dk);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = (void *)addr;
Index: src/sys/dev/ccd.c
diff -u src/sys/dev/ccd.c:1.159 src/sys/dev/ccd.c:1.160
--- src/sys/dev/ccd.c:1.159 Tue Dec 30 15:57:37 2014
+++ src/sys/dev/ccd.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: ccd.c,v 1.159 2014/12/30 20:57:37 christos Exp $ */
+/* $NetBSD: ccd.c,v 1.160 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 1999, 2007, 2009 The NetBSD Foundation, Inc.
@@ -88,7 +88,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ccd.c,v 1.159 2014/12/30 20:57:37 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ccd.c,v 1.160 2014/12/31 17:06:48 christos Exp $");
#if defined(_KERNEL_OPT)
#include "opt_compat_netbsd.h"
@@ -1415,42 +1415,6 @@ ccdioctl(dev_t dev, u_long cmd, void *da
}
break;
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, cs->sc_xname,
- sizeof(dkw->dkw_parent));
- error = dkwedge_add(dkw);
- break;
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, cs->sc_xname,
- sizeof(dkw->dkw_parent));
- error = dkwedge_del(dkw);
- break;
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) data;
-
- error = dkwedge_list(&cs->sc_dkdev, dkwl, l);
- break;
- }
-
- case DIOCMWEDGES:
- {
- dkwedge_discover(&cs->sc_dkdev);
- break;
- }
-
case DIOCWDINFO:
case DIOCSDINFO:
#ifdef __HAVE_OLD_DISKLABEL
Index: src/sys/dev/dksubr.c
diff -u src/sys/dev/dksubr.c:1.56 src/sys/dev/dksubr.c:1.57
--- src/sys/dev/dksubr.c:1.56 Mon Dec 29 13:41:20 2014
+++ src/sys/dev/dksubr.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: dksubr.c,v 1.56 2014/12/29 18:41:20 mlelstv Exp $ */
+/* $NetBSD: dksubr.c,v 1.57 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 1999, 2002, 2008 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: dksubr.c,v 1.56 2014/12/29 18:41:20 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: dksubr.c,v 1.57 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -285,11 +285,11 @@ dk_ioctl(struct dk_intf *di, struct dk_s
u_long cmd, void *data, int flag, struct lwp *l)
{
struct disklabel *lp;
- struct disk *dk;
+ struct disk *dk = &dksc->sc_dkdev;
#ifdef __HAVE_OLD_DISKLABEL
struct disklabel newlabel;
#endif
- int error = 0;
+ int error;
DPRINTF_FOLLOW(("dk_ioctl(%s, %p, 0x%"PRIx64", 0x%lx)\n",
di->di_dkname, dksc, dev, cmd));
@@ -332,6 +332,12 @@ dk_ioctl(struct dk_intf *di, struct dk_s
return ENXIO;
}
+ error = disk_ioctl(dk, cmd, data, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
+ else
+ error = 0;
+
switch (cmd) {
case DIOCGDINFO:
*(struct disklabel *)data = *(dksc->sc_dkdev.dk_label);
@@ -367,7 +373,6 @@ dk_ioctl(struct dk_intf *di, struct dk_s
#endif
lp = (struct disklabel *)data;
- dk = &dksc->sc_dkdev;
mutex_enter(&dk->dk_openlock);
dksc->sc_flags |= DKF_LABELLING;
@@ -408,46 +413,6 @@ dk_ioctl(struct dk_intf *di, struct dk_s
break;
#endif
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *)data;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, dksc->sc_dkdev.dk_name);
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *)data;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, dksc->sc_dkdev.dk_name);
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *)data;
-
- return (dkwedge_list(&dksc->sc_dkdev, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&dksc->sc_dkdev);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = (void *)data;
Index: src/sys/dev/ld.c
diff -u src/sys/dev/ld.c:1.78 src/sys/dev/ld.c:1.79
--- src/sys/dev/ld.c:1.78 Tue Nov 4 02:51:54 2014
+++ src/sys/dev/ld.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: ld.c,v 1.78 2014/11/04 07:51:54 mlelstv Exp $ */
+/* $NetBSD: ld.c,v 1.79 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1998, 2000 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ld.c,v 1.78 2014/11/04 07:51:54 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ld.c,v 1.79 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -523,48 +523,6 @@ ldioctl(dev_t dev, u_long cmd, void *add
error = 0; /* XXX Error out instead? */
break;
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(sc->sc_dv),
- sizeof(dkw->dkw_parent));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(sc->sc_dv),
- sizeof(dkw->dkw_parent));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return (dkwedge_list(&sc->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&sc->sc_dk);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = (void *)addr;
Index: src/sys/dev/vnd.c
diff -u src/sys/dev/vnd.c:1.236 src/sys/dev/vnd.c:1.237
--- src/sys/dev/vnd.c:1.236 Wed Dec 31 03:24:50 2014
+++ src/sys/dev/vnd.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: vnd.c,v 1.236 2014/12/31 08:24:50 mlelstv Exp $ */
+/* $NetBSD: vnd.c,v 1.237 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 2008 The NetBSD Foundation, Inc.
@@ -91,7 +91,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vnd.c,v 1.236 2014/12/31 08:24:50 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vnd.c,v 1.237 2014/12/31 17:06:48 christos Exp $");
#if defined(_KERNEL_OPT)
#include "opt_vnd.h"
@@ -1041,8 +1041,6 @@ vndioctl(dev_t dev, u_long cmd, void *da
#ifdef __HAVE_OLD_DISKLABEL
struct disklabel newlabel;
#endif
- struct dkwedge_info *dkw;
- struct dkwedge_list *dkwl;
#ifdef DEBUG
if (vnddebug & VDB_FOLLOW)
@@ -1564,40 +1562,6 @@ unlock_and_exit:
VOP_UNLOCK(vnd->sc_vp);
return error;
- case DIOCAWEDGE:
- dkw = (void *) data;
-
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(vnd->sc_dev),
- sizeof(dkw->dkw_parent));
- return dkwedge_add(dkw);
-
- case DIOCDWEDGE:
- dkw = (void *) data;
-
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(vnd->sc_dev),
- sizeof(dkw->dkw_parent));
- return dkwedge_del(dkw);
-
- case DIOCLWEDGES:
- dkwl = (void *) data;
-
- return dkwedge_list(&vnd->sc_dkdev, dkwl, l);
-
- case DIOCMWEDGES:
- if ((flag & FWRITE) == 0)
- return EBADF;
-
- dkwedge_discover(&vnd->sc_dkdev);
- return 0;
-
default:
return ENOTTY;
}
Index: src/sys/dev/ata/wd.c
diff -u src/sys/dev/ata/wd.c:1.415 src/sys/dev/ata/wd.c:1.416
--- src/sys/dev/ata/wd.c:1.415 Tue Nov 4 02:51:55 2014
+++ src/sys/dev/ata/wd.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: wd.c,v 1.415 2014/11/04 07:51:55 mlelstv Exp $ */
+/* $NetBSD: wd.c,v 1.416 2014/12/31 17:06:48 christos Exp $ */
/*
* Copyright (c) 1998, 2001 Manuel Bouyer. All rights reserved.
@@ -54,7 +54,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.415 2014/11/04 07:51:55 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wd.c,v 1.416 2014/12/31 17:06:48 christos Exp $");
#include "opt_ata.h"
@@ -1479,46 +1479,6 @@ wdioctl(dev_t dev, u_long xfer, void *ad
return(error1);
}
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(wd->sc_dev));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(wd->sc_dev));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return (dkwedge_list(&wd->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&wd->sc_dk);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = (void *)addr;
Index: src/sys/dev/mca/ed_mca.c
diff -u src/sys/dev/mca/ed_mca.c:1.59 src/sys/dev/mca/ed_mca.c:1.60
--- src/sys/dev/mca/ed_mca.c:1.59 Sun Nov 9 05:10:08 2014
+++ src/sys/dev/mca/ed_mca.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: ed_mca.c,v 1.59 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: ed_mca.c,v 1.60 2014/12/31 17:06:48 christos Exp $ */
/*
* Copyright (c) 2001 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ed_mca.c,v 1.59 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ed_mca.c,v 1.60 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -478,6 +478,10 @@ edmcaioctl(dev_t dev, u_long xfer, void
if ((ed->sc_flags & WDF_LOADED) == 0)
return EIO;
+ error = disk_ioctl(&ed->sc_dk, xfer, addr, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
+
switch (xfer) {
case DIOCGDINFO:
*(struct disklabel *)addr = *(ed->sc_dk.dk_label);
@@ -569,48 +573,6 @@ edmcaioctl(dev_t dev, u_long xfer, void
}
#endif
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(ed->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(ed->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return (dkwedge_list(&ed->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&ed->sc_dk);
- return 0;
- }
-
default:
return ENOTTY;
}
Index: src/sys/dev/mscp/mscp_disk.c
diff -u src/sys/dev/mscp/mscp_disk.c:1.82 src/sys/dev/mscp/mscp_disk.c:1.83
--- src/sys/dev/mscp/mscp_disk.c:1.82 Sun Nov 9 05:10:08 2014
+++ src/sys/dev/mscp/mscp_disk.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: mscp_disk.c,v 1.82 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: mscp_disk.c,v 1.83 2014/12/31 17:06:48 christos Exp $ */
/*
* Copyright (c) 1988 Regents of the University of California.
* All rights reserved.
@@ -82,7 +82,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mscp_disk.c,v 1.82 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mscp_disk.c,v 1.83 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/buf.h>
@@ -405,13 +405,19 @@ raioctl(dev_t dev, u_long cmd, void *dat
{
struct disklabel *lp, *tp;
struct ra_softc *ra = mscp_device_lookup(dev);
- int error = 0;
+ int error;
#ifdef __HAVE_OLD_DISKLABEL
struct disklabel newlabel;
#endif
lp = ra->ra_disk.dk_label;
+ error = disk_ioctl(&ra->ra_disk, cmd, data, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
+ else
+ error = 0;
+
switch (cmd) {
case DIOCGDINFO:
@@ -497,48 +503,6 @@ raioctl(dev_t dev, u_long cmd, void *dat
#endif
break;
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(ra->ra_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(ra->ra_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) data;
-
- return (dkwedge_list(&ra->ra_disk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&ra->ra_disk);
- return 0;
- }
-
default:
error = ENOTTY;
break;
@@ -909,10 +873,16 @@ rxioctl(dev_t dev, u_long cmd, void *dat
int unit = DISKUNIT(dev);
struct disklabel *lp;
struct rx_softc *rx = device_lookup_private(&rx_cd, unit);
- int error = 0;
+ int error;
lp = rx->ra_disk.dk_label;
+ error = disk_ioctl(&rx->ra_disk, cmd, data, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
+ else
+ error = 0;
+
switch (cmd) {
case DIOCGDINFO:
Index: src/sys/dev/ofw/ofdisk.c
diff -u src/sys/dev/ofw/ofdisk.c:1.48 src/sys/dev/ofw/ofdisk.c:1.49
--- src/sys/dev/ofw/ofdisk.c:1.48 Sun Nov 9 05:10:08 2014
+++ src/sys/dev/ofw/ofdisk.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: ofdisk.c,v 1.48 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: ofdisk.c,v 1.49 2014/12/31 17:06:48 christos Exp $ */
/*
* Copyright (C) 1995, 1996 Wolfgang Solfrank.
@@ -32,7 +32,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ofdisk.c,v 1.48 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ofdisk.c,v 1.49 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/buf.h>
@@ -359,6 +359,19 @@ ofdisk_ioctl(dev_t dev, u_long cmd, void
#ifdef __HAVE_OLD_DISKLABEL
struct disklabel newlabel;
#endif
+ /* XXX: Why not allow wedges on floppy? */
+ switch (cmd) {
+ case DIOCDWEDGE:
+ case DIOCAWEDGE:
+ case DIOCLWEDGES:
+ case DIOCMWEDGES:
+ if (OFDISK_FLOPPY_P(of))
+ return ENOTTY;
+ }
+
+ error = disk_ioctl(&of->sc_dk, cmd, data, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
switch (cmd) {
case DIOCGDINFO:
@@ -431,60 +444,6 @@ ofdisk_ioctl(dev_t dev, u_long cmd, void
return 0;
#endif
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- if (OFDISK_FLOPPY_P(of))
- return (ENOTTY);
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(of->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) data;
-
- if (OFDISK_FLOPPY_P(of))
- return (ENOTTY);
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(of->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) data;
-
- if (OFDISK_FLOPPY_P(of))
- return (ENOTTY);
-
- return (dkwedge_list(&of->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if (OFDISK_FLOPPY_P(of))
- return (ENOTTY);
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&of->sc_dk);
- return 0;
- }
-
default:
return ENOTTY;
}
Index: src/sys/dev/qbus/rl.c
diff -u src/sys/dev/qbus/rl.c:1.46 src/sys/dev/qbus/rl.c:1.47
--- src/sys/dev/qbus/rl.c:1.46 Sun Nov 9 05:10:08 2014
+++ src/sys/dev/qbus/rl.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: rl.c,v 1.46 2014/11/09 10:10:08 mlelstv Exp $ */
+/* $NetBSD: rl.c,v 1.47 2014/12/31 17:06:48 christos Exp $ */
/*
* Copyright (c) 2000 Ludd, University of Lule}, Sweden. All rights reserved.
@@ -43,7 +43,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rl.c,v 1.46 2014/11/09 10:10:08 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rl.c,v 1.47 2014/12/31 17:06:48 christos Exp $");
#include <sys/param.h>
#include <sys/device.h>
@@ -443,11 +443,17 @@ rlioctl(dev_t dev, u_long cmd, void *add
{
struct rl_softc *rc = device_lookup_private(&rl_cd, DISKUNIT(dev));
struct disklabel *lp = rc->rc_disk.dk_label;
- int err = 0;
+ int error;
#ifdef __HAVE_OLD_DISKLABEL
- struct disklabel newlabel;
+ struct diklabel newlabel;
#endif
+ error = disk_ioctl(&rc->rc_disk, xfer, addr, flag, l);
+ if (error != EPASSTHROUGH)
+ return error;
+ else
+ error = 0;
+
switch (cmd) {
case DIOCGDINFO:
memcpy(addr, lp, sizeof (struct disklabel));
@@ -487,10 +493,10 @@ rlioctl(dev_t dev, u_long cmd, void *add
tp = (struct disklabel *)addr;
if ((flag & FWRITE) == 0)
- err = EBADF;
+ error = EBADF;
else {
mutex_enter(&rc->rc_disk.dk_openlock);
- err = ((
+ error = ((
#ifdef __HAVE_OLD_DISKLABEL
cmd == ODIOCSDINFO ||
#endif
@@ -504,50 +510,14 @@ rlioctl(dev_t dev, u_long cmd, void *add
case DIOCWLABEL:
if ((flag & FWRITE) == 0)
- err = EBADF;
+ error = EBADF;
break;
- case DIOCAWEDGE: {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(rc->rc_dev));
- return dkwedge_add(dkw);
- }
-
- case DIOCDWEDGE: {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strcpy(dkw->dkw_parent, device_xname(rc->rc_dev));
- return dkwedge_del(dkw);
- }
-
- case DIOCLWEDGES: {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return dkwedge_list(&rc->rc_disk, dkwl, l);
- }
-
- case DIOCMWEDGES: {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&rc->rc_disk);
- return 0;
- }
-
default:
- err = ENOTTY;
+ error = ENOTTY;
break;
}
- return err;
+ return error;
}
int
Index: src/sys/dev/raidframe/rf_netbsdkintf.c
diff -u src/sys/dev/raidframe/rf_netbsdkintf.c:1.318 src/sys/dev/raidframe/rf_netbsdkintf.c:1.319
--- src/sys/dev/raidframe/rf_netbsdkintf.c:1.318 Wed Dec 31 03:24:50 2014
+++ src/sys/dev/raidframe/rf_netbsdkintf.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: rf_netbsdkintf.c,v 1.318 2014/12/31 08:24:50 mlelstv Exp $ */
+/* $NetBSD: rf_netbsdkintf.c,v 1.319 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 2008-2011 The NetBSD Foundation, Inc.
@@ -101,7 +101,7 @@
***********************************************************/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rf_netbsdkintf.c,v 1.318 2014/12/31 08:24:50 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rf_netbsdkintf.c,v 1.319 2014/12/31 17:06:48 christos Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -1062,7 +1062,6 @@ raidioctl(dev_t dev, u_long cmd, void *d
#ifdef __HAVE_OLD_DISKLABEL
struct disklabel newlabel;
#endif
- struct dkwedge_info *dkw;
if ((rs = raidget(unit)) == NULL)
return ENXIO;
@@ -1913,20 +1912,6 @@ raidioctl(dev_t dev, u_long cmd, void *d
break;
#endif
- case DIOCAWEDGE:
- case DIOCDWEDGE:
- dkw = (void *)data;
-
- /* If the ioctl happens here, the parent is us. */
- (void)strcpy(dkw->dkw_parent, rs->sc_xname);
- return cmd == DIOCAWEDGE ? dkwedge_add(dkw) : dkwedge_del(dkw);
-
- case DIOCLWEDGES:
- return dkwedge_list(&rs->sc_dkdev,
- (struct dkwedge_list *)data, l);
- case DIOCMWEDGES:
- dkwedge_discover(&rs->sc_dkdev);
- return 0;
case DIOCCACHESYNC:
return rf_sync_component_caches(raidPtr);
Index: src/sys/dev/scsipi/sd.c
diff -u src/sys/dev/scsipi/sd.c:1.311 src/sys/dev/scsipi/sd.c:1.312
--- src/sys/dev/scsipi/sd.c:1.311 Wed Dec 31 03:24:50 2014
+++ src/sys/dev/scsipi/sd.c Wed Dec 31 12:06:48 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: sd.c,v 1.311 2014/12/31 08:24:50 mlelstv Exp $ */
+/* $NetBSD: sd.c,v 1.312 2014/12/31 17:06:48 christos Exp $ */
/*-
* Copyright (c) 1998, 2003, 2004 The NetBSD Foundation, Inc.
@@ -47,7 +47,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sd.c,v 1.311 2014/12/31 08:24:50 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sd.c,v 1.312 2014/12/31 17:06:48 christos Exp $");
#include "opt_scsi.h"
@@ -1223,48 +1223,6 @@ sdioctl(dev_t dev, u_long cmd, void *add
}
return (error);
- case DIOCAWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(sd->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_add(dkw));
- }
-
- case DIOCDWEDGE:
- {
- struct dkwedge_info *dkw = (void *) addr;
-
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- /* If the ioctl happens here, the parent is us. */
- strlcpy(dkw->dkw_parent, device_xname(sd->sc_dev),
- sizeof(dkw->dkw_parent));
- return (dkwedge_del(dkw));
- }
-
- case DIOCLWEDGES:
- {
- struct dkwedge_list *dkwl = (void *) addr;
-
- return (dkwedge_list(&sd->sc_dk, dkwl, l));
- }
-
- case DIOCMWEDGES:
- {
- if ((flag & FWRITE) == 0)
- return (EBADF);
-
- dkwedge_discover(&sd->sc_dk);
- return 0;
- }
-
case DIOCGSTRATEGY:
{
struct disk_strategy *dks = addr;
Index: src/sys/kern/subr_disk.c
diff -u src/sys/kern/subr_disk.c:1.106 src/sys/kern/subr_disk.c:1.107
--- src/sys/kern/subr_disk.c:1.106 Wed Dec 31 03:24:51 2014
+++ src/sys/kern/subr_disk.c Wed Dec 31 12:06:49 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: subr_disk.c,v 1.106 2014/12/31 08:24:51 mlelstv Exp $ */
+/* $NetBSD: subr_disk.c,v 1.107 2014/12/31 17:06:49 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1999, 2000, 2009 The NetBSD Foundation, Inc.
@@ -67,12 +67,13 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_disk.c,v 1.106 2014/12/31 08:24:51 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_disk.c,v 1.107 2014/12/31 17:06:49 christos Exp $");
#include <sys/param.h>
#include <sys/kernel.h>
#include <sys/kmem.h>
#include <sys/buf.h>
+#include <sys/fcntl.h>
#include <sys/syslog.h>
#include <sys/disklabel.h>
#include <sys/disk.h>
@@ -487,38 +488,54 @@ convertdisklabel(struct disklabel *lp, v
* Generic disk ioctl handling.
*/
int
-disk_ioctl(struct disk *diskp, u_long cmd, void *data, int flag,
- struct lwp *l)
+disk_ioctl(struct disk *dk, u_long cmd, void *data, int flag, struct lwp *l)
{
- int error = 0;
+ struct dkwedge_info *dkw;
switch (cmd) {
- case DIOCGDISKINFO:
- {
- struct plistref *pref = (struct plistref *) data;
+ case DIOCAWEDGE:
+ if ((flag & FWRITE) == 0)
+ return EBADF;
+
+ dkw = data;
+ strlcpy(dkw->dkw_parent, dk->dk_name, sizeof(dkw->dkw_parent));
+ return dkwedge_add(dkw);
+
+ case DIOCDWEDGE:
+ if ((flag & FWRITE) == 0)
+ return EBADF;
+
+ dkw = data;
+ strlcpy(dkw->dkw_parent, dk->dk_name, sizeof(dkw->dkw_parent));
+ return dkwedge_del(dkw);
+
+ case DIOCLWEDGES:
+ return dkwedge_list(dk, data, l);
+
+ case DIOCMWEDGES:
+ if ((flag & FWRITE) == 0)
+ return EBADF;
+
+ dkwedge_discover(dk);
+ return 0;
- if (diskp->dk_info == NULL)
- error = ENOTSUP;
- else
- error = prop_dictionary_copyout_ioctl(pref, cmd,
- diskp->dk_info);
- break;
- }
+ case DIOCGDISKINFO:
+ if (dk->dk_info == NULL)
+ return ENOTSUP;
+ return prop_dictionary_copyout_ioctl(data, cmd, dk->dk_info);
case DIOCGSECTORSIZE:
- *(u_int *)data = diskp->dk_geom.dg_secsize;
- break;
+ *(u_int *)data = dk->dk_geom.dg_secsize;
+ return 0;
case DIOCGMEDIASIZE:
- *(off_t *)data = (off_t)diskp->dk_geom.dg_secsize *
- diskp->dk_geom.dg_secperunit;
- break;
+ *(off_t *)data = (off_t)dk->dk_geom.dg_secsize *
+ dk->dk_geom.dg_secperunit;
+ return 0;
default:
- error = EPASSTHROUGH;
+ return EPASSTHROUGH;
}
-
- return (error);
}
void