summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/ic/ami.c115
-rw-r--r--sys/dev/ic/amivar.h13
2 files changed, 51 insertions, 77 deletions
diff --git a/sys/dev/ic/ami.c b/sys/dev/ic/ami.c
index f7a8d51f215..9608b785969 100644
--- a/sys/dev/ic/ami.c
+++ b/sys/dev/ic/ami.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ami.c,v 1.87 2005/09/26 21:33:02 dlg Exp $ */
+/* $OpenBSD: ami.c,v 1.88 2005/09/30 07:53:03 dlg Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -324,13 +324,11 @@ ami_attach(sc)
struct ami_rawsoftc *rsc;
struct ami_ccb *ccb;
struct ami_iocmd *cmd;
- struct ami_passthrough *pt;
- struct ami_sgent *sg;
bus_dmamap_t idatamap;
bus_dma_segment_t idataseg[1];
const char *p;
void *idata;
- int error;
+ int i, error;
/* u_int32_t *pp; */
if (!(idata = ami_allocmem(sc->dmat, &idatamap, idataseg,
@@ -345,18 +343,13 @@ ami_attach(sc)
sc->sc_mbox_pa = sc->sc_mbox_seg[0].ds_addr;
AMI_DPRINTF(AMI_D_CMD, ("mbox_pa=%llx ", sc->sc_mbox_pa));
- sc->sc_cmds = ami_allocmem(sc->dmat, &sc->sc_cmdmap, sc->sc_cmdseg,
- sizeof(struct ami_iocmd), AMI_MAXCMDS+1, "command");
- if (!sc->sc_cmds)
- goto free_mbox;
-
sc->sc_pts = ami_allocmem(sc->dmat, &sc->sc_ptmap, sc->sc_ptseg,
- sizeof(struct ami_passthrough), AMI_MAXCMDS+1, "ptlist");
+ sizeof(struct ami_passthrough), AMI_MAXCMDS, "ptlist");
if (!sc->sc_pts)
- goto free_cmds;
+ goto free_mbox;
sc->sc_sgents = ami_allocmem(sc->dmat, &sc->sc_sgmap, sc->sc_sgseg,
- sizeof(struct ami_sgent) * AMI_SGEPERCMD, AMI_MAXCMDS+1, "sglist");
+ sizeof(struct ami_sgent) * AMI_SGEPERCMD, AMI_MAXCMDS, "sglist");
if (!sc->sc_sgents)
goto free_pts;
@@ -364,38 +357,28 @@ ami_attach(sc)
TAILQ_INIT(&sc->sc_ccbdone);
TAILQ_INIT(&sc->sc_free_ccb);
- /* 0th command is a mailbox */
- for (ccb = &sc->sc_ccbs[AMI_MAXCMDS-1],
- cmd = sc->sc_cmds + sizeof(*cmd) * AMI_MAXCMDS,
- pt = sc->sc_pts + sizeof(*pt) * AMI_MAXCMDS,
- sg = sc->sc_sgents + sizeof(*sg) * AMI_MAXCMDS * AMI_SGEPERCMD;
- cmd >= (struct ami_iocmd *)sc->sc_cmds;
- cmd--, ccb--, pt--, sg -= AMI_SGEPERCMD) {
-
- cmd->acc_id = cmd - (struct ami_iocmd *)sc->sc_cmds;
- if (cmd->acc_id) {
- error = bus_dmamap_create(sc->dmat,
- AMI_MAXFER, AMI_MAXOFFSETS, AMI_MAXFER, 0,
- BUS_DMA_NOWAIT | BUS_DMA_ALLOCNOW,
- &ccb->ccb_dmamap);
- if (error) {
- printf(": cannot create ccb dmamap (%d)\n",
- error);
- goto destroy;
- }
- ccb->ccb_sc = sc;
- ccb->ccb_cmd = cmd;
- ccb->ccb_state = AMI_CCB_FREE;
- ccb->ccb_cmdpa = htole32(sc->sc_cmdseg[0].ds_addr +
- cmd->acc_id * sizeof(*cmd));
- ccb->ccb_pt = pt;
- ccb->ccb_ptpa = htole32(sc->sc_ptseg[0].ds_addr +
- cmd->acc_id * sizeof(*pt));
- ccb->ccb_sglist = sg;
- ccb->ccb_sglistpa = htole32(sc->sc_sgseg[0].ds_addr +
- cmd->acc_id * sizeof(*sg) * AMI_SGEPERCMD);
- TAILQ_INSERT_TAIL(&sc->sc_free_ccb, ccb, ccb_link);
+ for (i = 0; i < AMI_MAXCMDS; i++) {
+ ccb = &sc->sc_ccbs[i];
+
+ error = bus_dmamap_create(sc->dmat, AMI_MAXFER, AMI_MAXOFFSETS,
+ AMI_MAXFER, 0, BUS_DMA_NOWAIT | BUS_DMA_ALLOCNOW,
+ &ccb->ccb_dmamap);
+ if (error) {
+ printf(": cannot create ccb dmamap (%d)\n", error);
+ goto destroy;
}
+
+
+ ccb->ccb_sc = sc;
+ ccb->ccb_state = AMI_CCB_FREE;
+ ccb->ccb_cmd.acc_id = i + 1;
+ ccb->ccb_pt = &sc->sc_pts[i];
+ ccb->ccb_ptpa = htole32(sc->sc_ptseg[0].ds_addr +
+ (sizeof(struct ami_passthrough) * i));
+ ccb->ccb_sglist = &sc->sc_sgents[i * AMI_SGEPERCMD];
+ ccb->ccb_sglistpa = htole32(sc->sc_sgseg[0].ds_addr +
+ (sizeof(struct ami_sgent) * AMI_SGEPERCMD * i));
+ TAILQ_INSERT_TAIL(&sc->sc_free_ccb, ccb, ccb_link);
}
timeout_set(&sc->sc_poll_tmo, (void (*)(void *))ami_intr, sc);
@@ -408,7 +391,7 @@ ami_attach(sc)
lock = AMI_LOCK_AMI(sc);
ccb = ami_get_ccb(sc);
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
/* try FC inquiry first */
cmd->acc_cmd = AMI_FCOP;
@@ -424,7 +407,7 @@ ami_attach(sc)
einq->ain_ldstat);
ccb = ami_get_ccb(sc);
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_FCOP;
cmd->acc_io.aio_channel = AMI_FC_PRODINF;
@@ -449,7 +432,7 @@ ami_attach(sc)
struct ami_inquiry *inq = idata;
ccb = ami_get_ccb(sc);
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_EINQUIRY;
cmd->acc_io.aio_channel = 0;
@@ -457,7 +440,7 @@ ami_attach(sc)
cmd->acc_io.aio_data = htole32(pa);
if (ami_cmd(ccb, BUS_DMA_NOWAIT, 1) != 0) {
ccb = ami_get_ccb(sc);
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_INQUIRY;
cmd->acc_io.aio_channel = 0;
@@ -504,7 +487,7 @@ ami_attach(sc)
*/
ccb = ami_get_ccb(sc);
ccb->ccb_data = NULL;
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_MISC;
cmd->acc_io.aio_channel = AMI_GET_IO_CMPL; /* sub opcode */
@@ -517,7 +500,7 @@ ami_attach(sc)
} else {
ccb = ami_get_ccb(sc);
ccb->ccb_data = NULL;
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_MISC;
cmd->acc_io.aio_channel = AMI_SET_IO_CMPL;
@@ -644,14 +627,12 @@ destroy:
if (ccb->ccb_dmamap)
bus_dmamap_destroy(sc->dmat, ccb->ccb_dmamap);
- ami_freemem(sc->sc_sgents, sc->dmat, &sc->sc_sgmap, sc->sc_sgseg,
- sizeof(struct ami_sgent) * AMI_SGEPERCMD, AMI_MAXCMDS+1, "sglist");
+ ami_freemem((caddr_t)sc->sc_sgents, sc->dmat, &sc->sc_sgmap,
+ sc->sc_sgseg, sizeof(struct ami_sgent) * AMI_SGEPERCMD,
+ AMI_MAXCMDS, "sglist");
free_pts:
- ami_freemem(sc->sc_pts, sc->dmat, &sc->sc_ptmap, sc->sc_ptseg,
- sizeof(struct ami_passthrough), AMI_MAXCMDS+1, "ptlist");
-free_cmds:
- ami_freemem(sc->sc_cmds, sc->dmat, &sc->sc_cmdmap, sc->sc_cmdseg,
- sizeof(struct ami_iocmd), AMI_MAXCMDS+1, "command");
+ ami_freemem((caddr_t)sc->sc_pts, sc->dmat, &sc->sc_ptmap, sc->sc_ptseg,
+ sizeof(struct ami_passthrough), AMI_MAXCMDS, "ptlist");
free_mbox:
ami_freemem((caddr_t)sc->sc_mbox, sc->dmat, &sc->sc_mbox_map,
sc->sc_mbox_seg, sizeof(struct ami_iocmd), 1, "mbox");
@@ -1039,7 +1020,7 @@ ami_cmd(ccb, flags, wait)
int error = 0, i;
if (ccb->ccb_data) {
- struct ami_iocmd *cmd = ccb->ccb_cmd;
+ struct ami_iocmd *cmd = &ccb->ccb_cmd;
bus_dma_segment_t *sgd;
error = bus_dmamap_load(sc->dmat, dmap, ccb->ccb_data,
@@ -1094,14 +1075,12 @@ ami_cmd(ccb, flags, wait)
bus_dmamap_sync(sc->dmat, dmap, 0, dmap->dm_mapsize,
BUS_DMASYNC_PREWRITE);
} else
- ccb->ccb_cmd->acc_mbox.amb_nsge = 0;
- bus_dmamap_sync(sc->dmat, sc->sc_cmdmap, 0, sc->sc_cmdmap->dm_mapsize,
- BUS_DMASYNC_PREWRITE);
+ ccb->ccb_cmd.acc_mbox.amb_nsge = 0;
if (wait) {
AMI_DPRINTF(AMI_D_DMA, ("waiting "));
/* FIXME remove all wait out ami_start */
- if ((error = sc->sc_poll(sc, ccb->ccb_cmd))) {
+ if ((error = sc->sc_poll(sc, &ccb->ccb_cmd))) {
AMI_DPRINTF(AMI_D_MISC, ("pf "));
}
if (ccb->ccb_data)
@@ -1127,7 +1106,7 @@ ami_start(ccb, wait)
int wait;
{
struct ami_softc *sc = ccb->ccb_sc;
- struct ami_iocmd *cmd = ccb->ccb_cmd;
+ struct ami_iocmd *cmd = &ccb->ccb_cmd;
struct scsi_xfer *xs = ccb->ccb_xs;
volatile struct ami_iocmd *mbox = sc->sc_mbox;
int i;
@@ -1189,7 +1168,7 @@ ami_stimeout(v)
struct ami_ccb *ccb = v;
struct ami_softc *sc = ccb->ccb_sc;
struct scsi_xfer *xs = ccb->ccb_xs;
- struct ami_iocmd *cmd = ccb->ccb_cmd;
+ struct ami_iocmd *cmd = &ccb->ccb_cmd;
volatile struct ami_iocmd *mbox = sc->sc_mbox;
ami_lock_t lock;
@@ -1247,7 +1226,7 @@ ami_done(sc, idx)
struct scsi_xfer *xs = ccb->ccb_xs;
ami_lock_t lock;
- AMI_DPRINTF(AMI_D_CMD, ("done(%d) ", ccb->ccb_cmd->acc_id));
+ AMI_DPRINTF(AMI_D_CMD, ("done(%d) ", ccb->ccb_cmd.acc_id));
if (ccb->ccb_state != AMI_CCB_QUEUED) {
printf("%s: unqueued ccb %d ready, state = %d\n",
@@ -1373,7 +1352,7 @@ ami_scsi_raw_cmd(xs)
ccb->ccb_pt->apt_nsense = AMI_MAX_SENSE;
ccb->ccb_pt->apt_datalen = xs->datalen;
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = AMI_PASSTHRU;
if ((error = ami_cmd(ccb, ((xs->flags & SCSI_NOSLEEP) ?
@@ -1562,7 +1541,7 @@ ami_scsi_cmd(xs)
ccb->ccb_dir = (xs->flags & SCSI_DATA_IN) ?
AMI_CCB_IN : AMI_CCB_OUT;
ccb->ccb_data = xs->data;
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_mbox.amb_nsect = htole16(blockcnt);
cmd->acc_mbox.amb_lba = htole32(blockno);
cmd->acc_mbox.amb_ldn = target;
@@ -1752,7 +1731,7 @@ ami_drv_inq(sc, ch, tg, page, inqbuf)
ccb->ccb_len = sizeof(struct scsi_inquiry_data);
ccb->ccb_dir = AMI_CCB_IN;
- ccb->ccb_cmd->acc_cmd = AMI_PASSTHRU;
+ ccb->ccb_cmd.acc_cmd = AMI_PASSTHRU;
pt = ccb->ccb_pt;
@@ -1824,7 +1803,7 @@ ami_mgmt(sc, opcode, par1, par2, par3, size, buffer)
ccb->ccb_data = NULL;
ccb->ccb_wakeup = 1;
- cmd = ccb->ccb_cmd;
+ cmd = &ccb->ccb_cmd;
cmd->acc_cmd = opcode;
diff --git a/sys/dev/ic/amivar.h b/sys/dev/ic/amivar.h
index 02ff931cf1e..22979543074 100644
--- a/sys/dev/ic/amivar.h
+++ b/sys/dev/ic/amivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: amivar.h,v 1.29 2005/09/26 21:33:02 dlg Exp $ */
+/* $OpenBSD: amivar.h,v 1.30 2005/09/30 07:53:03 dlg Exp $ */
/*
* Copyright (c) 2001 Michael Shalayeff
@@ -31,8 +31,7 @@ struct ami_softc;
struct ami_ccb {
struct ami_softc *ccb_sc;
- struct ami_iocmd *ccb_cmd;
- paddr_t ccb_cmdpa;
+ struct ami_iocmd ccb_cmd;
struct ami_passthrough *ccb_pt;
paddr_t ccb_ptpa;
struct ami_sgent *ccb_sglist;
@@ -92,15 +91,11 @@ struct ami_softc {
struct ami_ccb sc_ccbs[AMI_MAXCMDS];
ami_queue_head sc_free_ccb, sc_ccbq, sc_ccbdone;
- void *sc_cmds;
- bus_dmamap_t sc_cmdmap;
- bus_dma_segment_t sc_cmdseg[1];
-
- void *sc_pts;
+ struct ami_passthrough *sc_pts;
bus_dmamap_t sc_ptmap;
bus_dma_segment_t sc_ptseg[1];
- void *sc_sgents;
+ struct ami_sgent *sc_sgents;
bus_dmamap_t sc_sgmap;
bus_dma_segment_t sc_sgseg[1];