diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2006-07-23 02:50:21 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2006-07-23 02:50:21 +0000 |
commit | d0c7fa94e63a36ad44f7c9e8a6de9c086d79ddb9 (patch) | |
tree | ce8dcf2b99533282653ffc8dc15c70132581e292 | |
parent | 5f6ef55cf04bf8f949493e83d0f055b08c20fbd0 (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.c | 184 | ||||
-rw-r--r-- | sys/scsi/cd.c | 3 | ||||
-rw-r--r-- | sys/scsi/scsi_ioctl.c | 25 | ||||
-rw-r--r-- | sys/scsi/sd.c | 11 | ||||
-rw-r--r-- | sys/sys/scsiio.h | 12 |
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_ */ |