diff options
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/aic7xxx.c | 47 |
1 files changed, 29 insertions, 18 deletions
diff --git a/sys/dev/ic/aic7xxx.c b/sys/dev/ic/aic7xxx.c index c3b75d4399f..203b3eec311 100644 --- a/sys/dev/ic/aic7xxx.c +++ b/sys/dev/ic/aic7xxx.c @@ -33,7 +33,7 @@ * SUCH DAMAGE. * * $FreeBSD: src/sys/dev/aic7xxx/aic7xxx.c,v 1.40 2000/01/07 23:08:17 gibbs Exp $ - * $OpenBSD: aic7xxx.c,v 1.29 2001/08/12 20:33:50 mickey Exp $ + * $OpenBSD: aic7xxx.c,v 1.30 2001/08/31 02:52:19 krw Exp $ */ /* * A few notes on features of the driver. @@ -255,6 +255,14 @@ typedef enum { MSGLOOP_TERMINATED } msg_loop_stat; +#ifdef __HAS_NEW_BUS_DMAMAP_SYNC +#define ahc_bus_dmamap_sync(tag, map, off, len, op) \ + bus_dmamap_sync((tag), (map), (off), (len), (op)) +#else +#define ahc_bus_dmamap_sync(tag, map, off, len, op) \ + bus_dmamap_sync((tag), (map), (op)) +#endif + STATIC int ahc_parse_msg __P((struct ahc_softc *ahc, struct scsi_link *sc_link, struct ahc_devinfo *devinfo)); @@ -523,8 +531,8 @@ ahc_index_busy_tcl(ahc, tcl, unbusy) scbid = ahc->untagged_scbs[tcl]; if (unbusy) { ahc->untagged_scbs[tcl] = SCB_LIST_NULL; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_PREWRITE); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + UNTAGGEDSCB_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE); } return (scbid); @@ -536,8 +544,8 @@ ahc_busy_tcl(ahc, scb) struct scb *scb; { ahc->untagged_scbs[scb->hscb->tcl] = scb->hscb->tag; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_PREWRITE); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + UNTAGGEDSCB_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE); } static __inline int @@ -598,8 +606,8 @@ ahc_run_qoutfifo(ahc) struct scb *scb; u_int scb_index; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_POSTREAD); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + 0, 256, BUS_DMASYNC_POSTREAD); while (ahc->qoutfifo[ahc->qoutfifonext] != SCB_LIST_NULL) { scb_index = ahc->qoutfifo[ahc->qoutfifonext]; @@ -3453,7 +3461,8 @@ ahc_done(ahc, scb) op = BUS_DMASYNC_POSTREAD; else op = BUS_DMASYNC_POSTWRITE; - bus_dmamap_sync(ahc->sc_dmat, scb->dmamap, op); + ahc_bus_dmamap_sync(ahc->sc_dmat, scb->dmamap, + 0, scb->dmamap->dm_mapsize, op); bus_dmamap_unload(ahc->sc_dmat, scb->dmamap); } @@ -3672,8 +3681,8 @@ ahc_init(ahc) for (i = 0; i < 256; i++) ahc->qoutfifo[i] = SCB_LIST_NULL; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + 0, driver_data_size, BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); /* * Allocate a tstate to house information for our @@ -4314,7 +4323,8 @@ ahc_execute_scb(arg, dm_segs, nsegments) op = BUS_DMASYNC_PREREAD; else op = BUS_DMASYNC_PREWRITE; - bus_dmamap_sync(ahc->sc_dmat, scb->dmamap, op); + ahc_bus_dmamap_sync(ahc->sc_dmat, scb->dmamap, + 0, scb->dmamap->dm_mapsize, op); } else { scb->hscb->SG_pointer = 0; scb->hscb->data = 0; @@ -4369,8 +4379,8 @@ ahc_execute_scb(arg, dm_segs, nsegments) ahc->qinfifo[ahc->qinfifonext++] = scb->hscb->tag; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_PREWRITE); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE); if ((ahc->features & AHC_QUEUE_REGS) != 0) { ahc_outb(ahc, HNSCB_QOFF, ahc->qinfifonext); @@ -5070,8 +5080,9 @@ bus_reset: ahc->qinfifo[ahc->qinfifonext++] = scb->hscb->tag; - bus_dmamap_sync(ahc->sc_dmat, + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE); if ((ahc->features & AHC_QUEUE_REGS) != 0) { @@ -5123,8 +5134,8 @@ ahc_search_qinfifo(ahc, target, channel, lun, tag, role, status, action) * for removal will be re-added to the queue as we go. */ ahc->qinfifonext = qinpos; - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_POSTREAD); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_POSTREAD); while (qinpos != qintail) { scbp = &ahc->scb_data->scbarray[ahc->qinfifo[qinpos]]; @@ -5154,8 +5165,8 @@ ahc_search_qinfifo(ahc, target, channel, lun, tag, role, status, action) } qinpos++; } - bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, - BUS_DMASYNC_PREWRITE); + ahc_bus_dmamap_sync(ahc->sc_dmat, ahc->shared_data_dmamap, + QINFIFO_OFFSET * 256, 256, BUS_DMASYNC_PREWRITE); if ((ahc->features & AHC_QUEUE_REGS) != 0) { ahc_outb(ahc, HNSCB_QOFF, ahc->qinfifonext); |