summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2010-03-24 06:55:29 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2010-03-24 06:55:29 +0000
commit13dfb63a3819f5e8eac9b3c863b3101b13ce357d (patch)
treefb613ede82acfb3665d9a02b91e14ceb7afc0c8f /sys/arch/sparc64
parent8f20bfe040f5dacd3a700435022aba14b4a4bb84 (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.c41
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