summaryrefslogtreecommitdiff
path: root/sys/dev/ic/ami.c
diff options
context:
space:
mode:
authorMarco Peereboom <marco@cvs.openbsd.org>2005-05-11 18:48:54 +0000
committerMarco Peereboom <marco@cvs.openbsd.org>2005-05-11 18:48:54 +0000
commitda5aa746a14ecbe5b33033f82aeb9a5db51432f2 (patch)
tree647a9d07027a45006fbad1ebe8b98cb90e5aa2f0 /sys/dev/ic/ami.c
parent7847cf8cac3ace56d062c6d1962f2df02d25d329 (diff)
Reset IO completion values to 0 to disable completion holdof. This improves
read performance. This will only work with firmwares that are launched post 5/13/2005. Help LSI, ok mickey@
Diffstat (limited to 'sys/dev/ic/ami.c')
-rw-r--r--sys/dev/ic/ami.c36
1 files changed, 34 insertions, 2 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index 70eaa498760..d23894fe769 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.36 2005/05/09 19:50:48 marco Exp $ */
+/* $OpenBSD: ami.c,v 1.37 2005/05/11 18:48:53 marco Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -326,6 +326,7 @@ ami_attach(sc)
const char *p;
void *idata;
int error;
+ u_int32_t *pp;
if (!(idata = ami_allocmem(sc->dmat, &idatamap, idataseg,
NBPG, 1, "init data"))) {
@@ -484,7 +485,36 @@ ami_attach(sc)
p = "target";
}
- AMI_UNLOCK_AMI(sc, lock);
+ /* reset the IO completion values to 0
+ * the firmware either has at least pp[0] IOs outstanding
+ * -or-
+ * it times out pp[1] us before it completes any IO
+ * if the values remain unchanged it locksteps the driver
+ * 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
+ */
+ 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_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"));
+ }
if (sc->sc_flags & AMI_BROKEN) {
sc->sc_link.openings = 1;
@@ -502,6 +532,8 @@ ami_attach(sc)
else
sc->sc_link.openings = sc->sc_maxcmds;
}
+
+ AMI_UNLOCK_AMI(sc, lock);
}
ami_freemem(sc->dmat, &idatamap, idataseg, NBPG, 1, "init data");