diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2010-03-24 06:55:29 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2010-03-24 06:55:29 +0000 |
commit | 13dfb63a3819f5e8eac9b3c863b3101b13ce357d (patch) | |
tree | fb613ede82acfb3665d9a02b91e14ceb7afc0c8f /sys/arch/sparc64 | |
parent | 8f20bfe040f5dacd3a700435022aba14b4a4bb84 (diff) |
vdsk_scsi_cmd doesnt need to return now, so fix some of its scsi command
emulation to not return values either.
i think this is right, but cant test just yet.
found by deraadt@
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r-- | sys/arch/sparc64/dev/vdsk.c | 41 |
1 files changed, 22 insertions, 19 deletions
diff --git a/sys/arch/sparc64/dev/vdsk.c b/sys/arch/sparc64/dev/vdsk.c index 5a9def7238f..76c2c08c34c 100644 --- a/sys/arch/sparc64/dev/vdsk.c +++ b/sys/arch/sparc64/dev/vdsk.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vdsk.c,v 1.18 2010/03/23 01:57:19 krw Exp $ */ +/* $OpenBSD: vdsk.c,v 1.19 2010/03/24 06:55:28 dlg Exp $ */ /* * Copyright (c) 2009 Mark Kettenis * @@ -205,10 +205,10 @@ int vdsk_dev_probe(struct scsi_link *); void vdsk_dev_free(struct scsi_link *); int vdsk_ioctl(struct scsi_link *, u_long, caddr_t, int, struct proc *); -int vdsk_scsi_inq(struct scsi_xfer *); -int vdsk_scsi_inquiry(struct scsi_xfer *); -int vdsk_scsi_capacity(struct scsi_xfer *); -int vdsk_scsi_done(struct scsi_xfer *, int); +void vdsk_scsi_inq(struct scsi_xfer *); +void vdsk_scsi_inquiry(struct scsi_xfer *); +void vdsk_scsi_capacity(struct scsi_xfer *); +void vdsk_scsi_done(struct scsi_xfer *, int); int vdsk_match(struct device *parent, void *match, void *aux) @@ -938,21 +938,25 @@ vdsk_scsi_cmd(struct scsi_xfer *xs) break; case INQUIRY: - return (vdsk_scsi_inq(xs)); + vdsk_scsi_inq(xs); + return; case READ_CAPACITY: - return (vdsk_scsi_capacity(xs)); + vdsk_scsi_capacity(xs); + return; case TEST_UNIT_READY: case START_STOP: case PREVENT_ALLOW: - return (vdsk_scsi_done(xs, XS_NOERROR)); + vdsk_scsi_done(xs, XS_NOERROR); + return; default: printf("%s cmd 0x%02x\n", __func__, xs->cmd->opcode); case MODE_SENSE: case MODE_SENSE_BIG: case REPORT_LUNS: - return (vdsk_scsi_done(xs, XS_DRIVER_STUFFUP)); + vdsk_scsi_done(xs, XS_DRIVER_STUFFUP); + return; } if (xs->cmdlen == 6) { @@ -1055,18 +1059,18 @@ vdsk_scsi_cmd(struct scsi_xfer *xs) } } -int +void vdsk_scsi_inq(struct scsi_xfer *xs) { struct scsi_inquiry *inq = (struct scsi_inquiry *)xs->cmd; if (ISSET(inq->flags, SI_EVPD)) - return (vdsk_scsi_done(xs, XS_DRIVER_STUFFUP)); - - return (vdsk_scsi_inquiry(xs)); + vdsk_scsi_done(xs, XS_DRIVER_STUFFUP); + else + vdsk_scsi_inquiry(xs); } -int +void vdsk_scsi_inquiry(struct scsi_xfer *xs) { struct vdsk_softc *sc = xs->sc_link->adapter_softc; @@ -1086,10 +1090,10 @@ vdsk_scsi_inquiry(struct scsi_xfer *xs) bcopy(&inq, xs->data, MIN(sizeof(inq), xs->datalen)); - return (vdsk_scsi_done(xs, XS_NOERROR)); + vdsk_scsi_done(xs, XS_NOERROR); } -int +void vdsk_scsi_capacity(struct scsi_xfer *xs) { struct vdsk_softc *sc = xs->sc_link->adapter_softc; @@ -1107,10 +1111,10 @@ vdsk_scsi_capacity(struct scsi_xfer *xs) bcopy(&rcd, xs->data, MIN(sizeof(rcd), xs->datalen)); - return (vdsk_scsi_done(xs, XS_NOERROR)); + vdsk_scsi_done(xs, XS_NOERROR); } -int +void vdsk_scsi_done(struct scsi_xfer *xs, int error) { int s; @@ -1120,7 +1124,6 @@ vdsk_scsi_done(struct scsi_xfer *xs, int error) s = splbio(); scsi_done(xs); splx(s); - return (COMPLETE); } int |