summaryrefslogtreecommitdiff
path: root/sys/dev/ic/ami.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic/ami.c')
-rw-r--r--sys/dev/ic/ami.c49
1 files changed, 36 insertions, 13 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index d23894fe769..ca6c21a94d3 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.37 2005/05/11 18:48:53 marco Exp $ */
+/* $OpenBSD: ami.c,v 1.38 2005/05/17 18:38:52 marco Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -77,9 +77,9 @@
int ami_debug = 0
/* | AMI_D_CMD */
/* | AMI_D_INTR */
-/* | AMI_D_MISC */
+ | AMI_D_MISC
/* | AMI_D_DMA */
- | AMI_D_IOCTL
+/* | AMI_D_IOCTL */
;
#else
#define AMI_DPRINTF(m,a) /* m, a */
@@ -326,7 +326,7 @@ ami_attach(sc)
const char *p;
void *idata;
int error;
- u_int32_t *pp;
+ /* u_int32_t *pp; */
if (!(idata = ami_allocmem(sc->dmat, &idatamap, idataseg,
NBPG, 1, "init data"))) {
@@ -484,6 +484,11 @@ ami_attach(sc)
sc->sc_maxcmds = inq->ain_maxcmd;
p = "target";
}
+#if 0
+ /* FIXME need to find a way to detect if fw supports this
+ * calling it this way crashes fw when io is ran to
+ * multiple logical disks
+ */
/* reset the IO completion values to 0
* the firmware either has at least pp[0] IOs outstanding
@@ -493,29 +498,47 @@ ami_attach(sc)
* to a maximum of 4 outstanding IOs and it hits the 5us timer
* continuously (these are the default values)
* this trick only works with firmwares newer than 5/13/05
+ * Setting the values outright will hang old firmwares so
+ * we need to read them first before setting them.
*/
ccb = ami_get_ccb(sc);
ccb->ccb_data = NULL;
cmd = ccb->ccb_cmd;
cmd->acc_cmd = AMI_MISC;
- cmd->acc_io.aio_channel = AMI_SET_IO_CMPL; /* sub opcode */
+ cmd->acc_io.aio_channel = AMI_GET_IO_CMPL; /* sub opcode */
cmd->acc_io.aio_param = 0;
cmd->acc_io.aio_data = htole32(pa);
- /* set parameters */
- pp = idata;
- pp[0] = 0; /* minimal outstanding commands, 0 disable */
- pp[1] = 0; /* maximal timeout in us, 0 disable */
if (ami_cmd(ccb, 0, 1) != 0) {
- AMI_DPRINTF(AMI_D_MISC, ("setting io completion values"
+ AMI_DPRINTF(AMI_D_MISC, ("getting io completion values"
" failed\n"));
}
else {
- AMI_DPRINTF(AMI_D_MISC, ("setting io completion values"
- " succeeded\n"));
- }
+ ccb = ami_get_ccb(sc);
+ ccb->ccb_data = NULL;
+ cmd = ccb->ccb_cmd;
+
+ cmd->acc_cmd = AMI_MISC;
+ cmd->acc_io.aio_channel = AMI_SET_IO_CMPL;
+ cmd->acc_io.aio_param = 0;
+ cmd->acc_io.aio_data = htole32(pa);
+
+ /* set parameters */
+ pp = idata;
+ pp[0] = 0; /* minimal outstanding commands, 0 disable */
+ pp[1] = 0; /* maximal timeout in us, 0 disable */
+ if (ami_cmd(ccb, 0, 1) != 0) {
+ AMI_DPRINTF(AMI_D_MISC, ("setting io completion"
+ " values failed\n"));
+ }
+ else {
+ AMI_DPRINTF(AMI_D_MISC, ("setting io completion"
+ " values succeeded\n"));
+ }
+ }
+#endif
if (sc->sc_flags & AMI_BROKEN) {
sc->sc_link.openings = 1;
sc->sc_maxcmds = 1;