summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2006-07-23 02:50:21 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2006-07-23 02:50:21 +0000
commitd0c7fa94e63a36ad44f7c9e8a6de9c086d79ddb9 (patch)
treece8dcf2b99533282653ffc8dc15c70132581e292
parent5f6ef55cf04bf8f949493e83d0f055b08c20fbd0 (diff)
remove some scsi ioctls, most importantly the ones that can reprobe the
bus. supporting these complicates the midlayer unnecessarily. ok krw@
-rw-r--r--sbin/scsi/scsi.c184
-rw-r--r--sys/scsi/cd.c3
-rw-r--r--sys/scsi/scsi_ioctl.c25
-rw-r--r--sys/scsi/sd.c11
-rw-r--r--sys/sys/scsiio.h12
5 files changed, 14 insertions, 221 deletions
diff --git a/sbin/scsi/scsi.c b/sbin/scsi/scsi.c
index fb0919f1a8e..3a3392c9809 100644
--- a/sbin/scsi/scsi.c
+++ b/sbin/scsi/scsi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: scsi.c,v 1.20 2005/11/13 19:16:09 deraadt Exp $ */
+/* $OpenBSD: scsi.c,v 1.21 2006/07/23 02:50:20 dlg Exp $ */
/* $FreeBSD: scsi.c,v 1.11 1996/04/06 11:00:28 joerg Exp $ */
/*
@@ -61,17 +61,7 @@ int fd;
int debuglevel;
int debugflag;
int commandflag;
-int reprobe;
-#ifdef SCIOCADDR
-int probe_all;
-#endif
int verbose = 0;
-int bus = -1; /* all busses */
-int targ = -1; /* all targs */
-int lun = 0; /* just lun 0 */
-#ifdef SCIOCFREEZE
-int freeze = 0; /* Freeze this many seconds */
-#endif
int modeflag;
int editflag;
@@ -83,7 +73,6 @@ void procargs(int *argc_p, char ***argv_p);
int iget(void *hook, char *name);
char *cget(void *hook, char *name);
void arg_put(void *hook, int letter, void *arg, int count, char *name);
-int arg_get (void *hook, char *field_name);
void mode_sense(int fd, u_char *data, int len, int pc, int page);
void mode_select(int fd, u_char *data, int len, int perm);
@@ -94,12 +83,7 @@ usage(void)
"Usage:\n"
"\n"
" scsi -f device -d debug_level # To set debug level\n"
-#ifdef SCIOCFREEZE
-" scsi -f device [-v] -z seconds # To freeze bus\n"
-#endif
" scsi -f device -m page [-P pc] # To read mode pages\n"
-" scsi -f device -p [-b bus] [-l lun] # To probe all devices\n"
-" scsi -f device -r [-b bus] [-t targ] [-l lun] # To reprobe a device\n"
" scsi -f device [-v] [-s seconds] -c cmd_fmt [arg0 ... argn] # A command...\n"
" -o count out_fmt [arg0 ... argn] # EITHER (data out)\n"
" -i count in_fmt # OR (data in)\n"
@@ -124,22 +108,11 @@ procargs(int *argc_p, char ***argv_p)
fflag = 0;
commandflag = 0;
debugflag = 0;
- while ((ch = getopt(argc, argv, "ceprvf:d:b:t:l:z:m:P:s:")) != -1) {
+ while ((ch = getopt(argc, argv, "cef:d:m:P:s:v")) != -1) {
switch (ch) {
-#ifdef SCIOCADDR
- case 'p':
- probe_all = 1;
- break;
-#endif
- case 'r':
- reprobe = 1;
- break;
case 'c':
commandflag = 1;
break;
- case 'v':
- verbose = 1;
- break;
case 'e':
editflag = 1;
break;
@@ -152,29 +125,18 @@ procargs(int *argc_p, char ***argv_p)
debuglevel = strtol(optarg, 0, 0);
debugflag = 1;
break;
- case 'b':
- bus = strtol(optarg, 0, 0);
- break;
- case 't':
- targ = strtol(optarg, 0, 0);
- break;
- case 'l':
- lun = strtol(optarg, 0, 0);
- break;
-#ifdef SCIOCFREEZE
- case 'z':
- freeze = strtol(optarg, 0, 0);
+ case 'm':
+ modeflag = 1;
+ modepage = strtol(optarg, 0, 0);
break;
-#endif
case 'P':
pagectl = strtol(optarg, 0, 0);
break;
case 's':
seconds = strtol(optarg, 0, 0);
break;
- case 'm':
- modeflag = 1;
- modepage = strtol(optarg, 0, 0);
+ case 'v':
+ verbose = 1;
break;
case '?':
default:
@@ -281,12 +243,6 @@ void arg_put(void *hook, int letter, void *arg, int count, char *name)
putchar('\n');
}
-int arg_get (void *hook, char *field_name)
-{
- printf("get \"%s\".\n", field_name);
- return 0;
-}
-
/* data_phase: SCSI bus data phase: DATA IN, DATA OUT, or no data transfer.
*/
enum data_phase {none = 0, in, out};
@@ -415,52 +371,6 @@ do_cmd(int fd, char *fmt, int argc, char **argv)
}
}
-#ifdef SCIOCFREEZE
-static void
-freeze_ioctl(int fd, int op, void *data)
-{
- if (ioctl(fd, SCIOCFREEZE, 0) == -1) {
- if (errno == ENODEV) {
- fprintf(stderr,
- "Your kernel must be configured with option SCSI_FREEZE.\n");
- exit(errno);
- } else
- err(errno, "SCIOCFREEZE");
- }
-}
-
-/* do_freeze: Freeze the bus for a given number of seconds.
- */
-static void do_freeze(int seconds)
-{
- if (seconds == -1) {
- printf("Hit return to thaw: ");
- fflush(stdout);
- sync();
-
- freeze_ioctl(fd, SCIOCFREEZE, 0);
-
- (void)getchar();
-
- freeze_ioctl(fd, SCIOCTHAW, 0);
- }
- else {
- sync();
- freeze_ioctl(fd, SCIOCFREEZETHAW, &seconds);
- if (verbose) {
- putchar('\007');
- fflush(stdout);
- }
-
- freeze_ioctl(fd, SCIOCWAITTHAW, 0);
- if (verbose) {
- putchar('\007');
- fflush(stdout);
- }
- }
-}
-#endif
-
void mode_sense(int fd, u_char *data, int len, int pc, int page)
{
scsireq_t *scsireq;
@@ -875,92 +785,14 @@ mode_edit(int fd, int page, int edit, int argc, char *argv[])
}
}
-#ifdef SCIOCADDR
-/* do_probe_all: Loop over all SCSI IDs and see if something is
- * there. This only does BUS 0 LUN 0.
- */
-void do_probe_all(void)
-{
- scsireq_t *scsireq;
-
- char vendor_id[8 + 1], product_id[16 + 1], revision[4 + 1];
- int id;
- u_char *inq_buf = malloc(96);
- struct scsi_addr addr;
-
- scsireq = scsireq_build(scsireq_new(),
- 96, inq_buf, SCCMD_READ,
- "12 0 0 0 v 0", 96);
-
- addr.scbus = (bus == -1) ? 0 : bus;
- addr.lun = lun;
-
- if (addr.scbus || addr.lun)
- {
- printf("For bus %d lun %d:\n", addr.scbus, addr.lun);
- }
-
- for (id = 0; id < 8; id++)
- {
- addr.target = id;
-
- printf("%d: ", id);
- if (ioctl(fd, SCIOCADDR, &addr) == -1) {
- if (errno == ENXIO)
- {
- errno = 0;
- printf("nothing.\n");
- }
- else
- printf("SCIOCADDR: %s\n", strerror(errno));
-
- continue;
- }
-
- if (scsireq_enter(fd, scsireq) == -1) {
- printf("scsireq_enter: %s\n", strerror(errno));
- continue;
- }
-
- vendor_id[sizeof(vendor_id) - 1] = 0;
- product_id[sizeof(product_id) - 1] = 0;
- revision[sizeof(revision) - 1] = 0;
-
- scsireq_decode(scsireq, "s8 c8 c16 c4",
- vendor_id, product_id, revision);
-
- printf("%s %s %s\n", vendor_id, product_id, revision);
- }
-}
-#endif
-
int
main(int argc, char **argv)
{
- struct scsi_addr scaddr;
-
procargs(&argc,&argv);
/* XXX This has grown to the point that it should be cleaned up.
*/
-#ifdef SCIOCFREEZE
- if (freeze) {
- do_freeze(freeze);
- } else
-#endif
-#ifdef SCIOCADDR
- if (probe_all)
- do_probe_all();
- else
-#endif
- if(reprobe) {
- scaddr.scbus = bus;
- scaddr.target = targ;
- scaddr.lun = lun;
-
- if (ioctl(fd,SCIOCREPROBE,&scaddr) == -1)
- warn("SCIOCREPROBE");
- } else if(debugflag) {
+ if (debugflag) {
if (ioctl(fd,SCIOCDEBUG,&debuglevel) == -1)
err(errno, "SCIODEBUG");
} else if (commandflag) {
diff --git a/sys/scsi/cd.c b/sys/scsi/cd.c
index 4e1ed9e1d33..7c6703b91c4 100644
--- a/sys/scsi/cd.c
+++ b/sys/scsi/cd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cd.c,v 1.108 2006/07/19 01:21:28 krw Exp $ */
+/* $OpenBSD: cd.c,v 1.109 2006/07/23 02:50:20 dlg Exp $ */
/* $NetBSD: cd.c,v 1.100 1997/04/02 02:29:30 mycroft Exp $ */
/*
@@ -801,7 +801,6 @@ cdioctl(dev, cmd, addr, flag, p)
case DIOCLOCK:
case DIOCEJECT:
case SCIOCIDENTIFY:
- case OSCIOCIDENTIFY:
case SCIOCCOMMAND:
case SCIOCDEBUG:
case CDIOCLOADUNLOAD:
diff --git a/sys/scsi/scsi_ioctl.c b/sys/scsi/scsi_ioctl.c
index 7c784ea02d1..ffc9a4e1127 100644
--- a/sys/scsi/scsi_ioctl.c
+++ b/sys/scsi/scsi_ioctl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: scsi_ioctl.c,v 1.25 2006/07/11 09:26:47 dlg Exp $ */
+/* $OpenBSD: scsi_ioctl.c,v 1.26 2006/07/23 02:50:20 dlg Exp $ */
/* $NetBSD: scsi_ioctl.c,v 1.23 1996/10/12 23:23:17 christos Exp $ */
/*
@@ -341,14 +341,6 @@ scsi_do_ioctl(struct scsi_link *sc_link, dev_t dev, u_long cmd, caddr_t addr,
SC_DEBUG(sc_link, SDEV_DB2, ("scsi_do_ioctl(0x%lx)\n", cmd));
switch(cmd) {
- case OSCIOCIDENTIFY: {
- struct oscsi_addr *sca = (struct oscsi_addr *)addr;
-
- sca->scbus = sc_link->scsibus;
- sca->target = sc_link->target;
- sca->lun = sc_link->lun;
- return (0);
- }
case SCIOCIDENTIFY: {
struct scsi_addr *sca = (struct scsi_addr *)addr;
@@ -359,16 +351,11 @@ scsi_do_ioctl(struct scsi_link *sc_link, dev_t dev, u_long cmd, caddr_t addr,
sca->lun = sc_link->lun;
return (0);
}
- case SCIOCRECONFIG:
- case SCIOCDECONFIG:
- return (EINVAL);
case SCIOCCOMMAND:
if (scsi_readsafe_cmd[((scsireq_t *)addr)->cmd[0]])
break;
/* FALLTHROUGH */
case SCIOCDEBUG:
- case SCIOCREPROBE:
- case OSCIOCREPROBE:
case SCIOCRESET:
if ((flag & FWRITE) == 0)
return (EPERM);
@@ -432,16 +419,6 @@ scsi_do_ioctl(struct scsi_link *sc_link, dev_t dev, u_long cmd, caddr_t addr,
sc_link->flags |= SDEV_DB4;
return (0);
}
- case OSCIOCREPROBE: {
- struct oscsi_addr *sca = (struct oscsi_addr *)addr;
-
- return (scsi_probe_busses(sca->scbus, sca->target, sca->lun));
- }
- case SCIOCREPROBE: {
- struct scsi_addr *sca = (struct scsi_addr *)addr;
-
- return (scsi_probe_busses(sca->scbus, sca->target, sca->lun));
- }
case SCIOCRESET: {
scsi_scsi_cmd(sc_link, 0, 0, 0, 0, GENRETRY, 2000, NULL,
SCSI_RESET);
diff --git a/sys/scsi/sd.c b/sys/scsi/sd.c
index 5c7dc68326b..5c4cb6e789d 100644
--- a/sys/scsi/sd.c
+++ b/sys/scsi/sd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sd.c,v 1.108 2006/07/13 11:46:16 krw Exp $ */
+/* $OpenBSD: sd.c,v 1.109 2006/07/23 02:50:20 dlg Exp $ */
/* $NetBSD: sd.c,v 1.111 1997/04/02 02:29:41 mycroft Exp $ */
/*-
@@ -830,7 +830,6 @@ sdioctl(dev, cmd, addr, flag, p)
case DIOCLOCK:
case DIOCEJECT:
case SCIOCIDENTIFY:
- case OSCIOCIDENTIFY:
case SCIOCCOMMAND:
case SCIOCDEBUG:
if (part == RAW_PART)
@@ -925,14 +924,6 @@ sdioctl(dev, cmd, addr, flag, p)
sd->sc_link->flags |= SDEV_EJECTING;
goto exit;
- case SCIOCREASSIGN:
- if ((flag & FWRITE) == 0) {
- error = EBADF;
- goto exit;
- }
- error = sd_reassign_blocks(sd, (*(int *)addr));
- goto exit;
-
default:
if (part != RAW_PART) {
error = ENOTTY;
diff --git a/sys/sys/scsiio.h b/sys/sys/scsiio.h
index adceb238da5..5d245518c03 100644
--- a/sys/sys/scsiio.h
+++ b/sys/sys/scsiio.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: scsiio.h,v 1.6 2002/05/27 23:40:31 tdeval Exp $ */
+/* $OpenBSD: scsiio.h,v 1.7 2006/07/23 02:50:20 dlg Exp $ */
/* $NetBSD: scsiio.h,v 1.3 1994/06/29 06:45:09 cgd Exp $ */
#ifndef _SYS_SCSIIO_H_
@@ -57,20 +57,14 @@ struct oscsi_addr {
struct scsi_addr {
int type;
-#define TYPE_SCSI 0
-#define TYPE_ATAPI 1
+#define TYPE_SCSI 0
+#define TYPE_ATAPI 1
int scbus; /* -1 if wildcard */
int target; /* -1 if wildcard */
int lun; /* -1 if wildcard */
};
-#define OSCIOCREPROBE _IOW('Q', 3, struct oscsi_addr) /* look for new devs */
-#define OSCIOCIDENTIFY _IOR('Q', 4, struct oscsi_addr)
-#define SCIOCDECONFIG _IO('Q', 5) /* please disappear */
-#define SCIOCRECONFIG _IO('Q', 6) /* please check again */
#define SCIOCRESET _IO('Q', 7) /* reset the device */
-#define SCIOCREASSIGN _IOW('Q', 8, int) /* reassign block */
#define SCIOCIDENTIFY _IOR('Q', 9, struct scsi_addr)
-#define SCIOCREPROBE _IOW('Q', 10, struct scsi_addr)
#endif /* _SYS_SCSIIO_H_ */