summaryrefslogtreecommitdiff
path: root/sys/dev/isa/aic6360.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/isa/aic6360.c')
-rw-r--r--sys/dev/isa/aic6360.c475
1 files changed, 285 insertions, 190 deletions
diff --git a/sys/dev/isa/aic6360.c b/sys/dev/isa/aic6360.c
index 5ab580f679e..68a84ce8035 100644
--- a/sys/dev/isa/aic6360.c
+++ b/sys/dev/isa/aic6360.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: aic6360.c,v 1.11 1997/01/23 04:13:52 flipk Exp $ */
+/* $OpenBSD: aic6360.c,v 1.12 1997/07/07 16:19:37 niklas Exp $ */
/* $NetBSD: aic6360.c,v 1.46 1996/05/12 23:51:37 mycroft Exp $ */
#define integrate static inline
@@ -97,7 +97,7 @@
* may spin in the interrupt routine waiting for this byte to come. How long?
* This is really (SCSI) device and processor dependent. Tuneable, I guess.
*/
-#define AIC_MSGIN_SPIN 1 /* Will spinwait upto ?ms for a new msg byte */
+#define AIC_MSGIN_SPIN 1 /* Spin upto ?ms for a new msg byte */
#define AIC_MSGOUT_SPIN 1
/* Include debug functions? At the end of this file there are a bunch of
@@ -128,6 +128,7 @@
#include <sys/user.h>
#include <sys/queue.h>
+#include <machine/bus.h>
#include <machine/intr.h>
#include <machine/pio.h>
@@ -140,6 +141,7 @@
/* Definitions, most of them has turned out to be unneccesary, but here they
* are anyway.
*/
+#define AIC_NPORTS 0x20 /* I/O port space used */
/* AIC6360 definitions */
#define SCSISEQ 0x00 /* SCSI sequence control */
@@ -495,7 +497,8 @@ struct aic_softc {
struct isadev sc_id;
void *sc_ih;
- int sc_iobase;
+ bus_space_tag_t sc_iot;
+ bus_space_handle_t sc_ioh;
int sc_irq, sc_drq;
struct scsi_link sc_link; /* prototype for subdevs */
@@ -565,8 +568,16 @@ struct aic_softc {
#define AIC_DOBREAK 0x40
int aic_debug = 0x00; /* AIC_SHOWSTART|AIC_SHOWMISC|AIC_SHOWTRACE; */
#define AIC_PRINT(b, s) do {if ((aic_debug & (b)) != 0) printf s;} while (0)
-#define AIC_BREAK() do {if ((aic_debug & AIC_DOBREAK) != 0) Debugger();} while (0)
-#define AIC_ASSERT(x) do {if (x) {} else {printf("%s at line %d: assertion failed\n", sc->sc_dev.dv_xname, __LINE__); Debugger();}} while (0)
+#define AIC_BREAK() \
+ do { if ((aic_debug & AIC_DOBREAK) != 0) Debugger(); } while (0)
+#define AIC_ASSERT(x) \
+ do { \
+ if (!x) { \
+ printf("%s at line %d: assertion failed\n", \
+ sc->sc_dev.dv_xname, __LINE__); \
+ Debugger(); \
+ } \
+ } while (0)
#else
#define AIC_PRINT(b, s)
#define AIC_BREAK()
@@ -593,7 +604,7 @@ integrate void aic_sched_msgout __P((struct aic_softc *, u_char));
integrate void aic_setsync __P((struct aic_softc *, struct aic_tinfo *));
void aic_select __P((struct aic_softc *, struct aic_acb *));
void aic_timeout __P((void *));
-int aic_find __P((struct aic_softc *));
+int aic_find __P((struct aic_softc *, struct isa_attach_args *));
void aic_sched __P((struct aic_softc *));
void aic_scsi_reset __P((struct aic_softc *));
void aic_reset __P((struct aic_softc *));
@@ -657,15 +668,15 @@ aicprobe(parent, match, aux)
return 0;
#endif
- sc->sc_iobase = ia->ia_iobase;
- if (aic_find(sc) != 0)
+ if (aic_find(sc, ia) != 0)
return 0;
#ifdef NEWCONFIG
if (ia->ia_irq != IRQUNK) {
if (ia->ia_irq != sc->sc_irq) {
- printf("%s: irq mismatch; kernel configured %d != board configured %d\n",
- sc->sc_dev.dv_xname, ia->ia_irq, sc->sc_irq);
+ printf("%s: irq mismatch; ", sc->sc_dev.dv_xname);
+ printf("kernel configured %d != board configured %d\n",
+ ia->ia_irq, sc->sc_irq);
return 0;
}
} else
@@ -673,8 +684,9 @@ aicprobe(parent, match, aux)
if (ia->ia_drq != DRQUNK) {
if (ia->ia_drq != sc->sc_drq) {
- printf("%s: drq mismatch; kernel configured %d != board configured %d\n",
- sc->sc_dev.dv_xname, ia->ia_drq, sc->sc_drq);
+ printf("%s: drq mismatch; ", sc->sc_dev.dv_xname);
+ printf("kernel configured %d != board configured %d\n",
+ ia->ia_drq, sc->sc_drq);
return 0;
}
} else
@@ -682,46 +694,51 @@ aicprobe(parent, match, aux)
#endif
ia->ia_msize = 0;
- ia->ia_iosize = 0x20;
+ ia->ia_iosize = AIC_NPORTS;
return 1;
}
-/* Do the real search-for-device.
- * Prerequisite: sc->sc_iobase should be set to the proper value
+/*
+ * Do the real search-for-device.
*/
int
-aic_find(sc)
+aic_find(sc, ia)
struct aic_softc *sc;
+ struct isa_attach_args *ia;
{
- int iobase = sc->sc_iobase;
+ bus_space_tag_t iot = ia->ia_iot;
+ bus_space_handle_t ioh;
char chip_id[sizeof(IDSTRING)]; /* For chips that support it */
int i;
+ if (bus_space_map(iot, ia->ia_iobase, AIC_NPORTS, 0, &ioh))
+ return (0);
+
/* Remove aic6360 from possible powerdown mode */
- outb(iobase + DMACNTRL0, 0);
+ bus_space_write_1(iot, ioh, DMACNTRL0, 0);
/* Thanks to mark@aggregate.com for the new method for detecting
* whether the chip is present or not. Bonus: may also work for
* the AIC-6260!
*/
- AIC_TRACE(("aic: probing for aic-chip at port 0x%x\n",
- sc->sc_iobase));
+ AIC_TRACE(("aic: probing for aic-chip at port 0x%x\n", ia->ia_iobase));
/*
* Linux also init's the stack to 1-16 and then clears it,
* 6260's don't appear to have an ID reg - mpg
*/
/* Push the sequence 0,1,..,15 on the stack */
#define STSIZE 16
- outb(iobase + DMACNTRL1, 0); /* Reset stack pointer */
+ bus_space_write_1(iot, ioh, DMACNTRL1, 0); /* Reset stack pointer */
for (i = 0; i < STSIZE; i++)
- outb(iobase + STACK, i);
+ bus_space_write_1(iot, ioh, STACK, i);
/* See if we can pull out the same sequence */
- outb(iobase + DMACNTRL1, 0);
- for (i = 0; i < STSIZE && inb(iobase + STACK) == i; i++)
+ bus_space_write_1(iot, ioh, DMACNTRL1, 0);
+ for (i = 0; i < STSIZE && bus_space_read_1(iot, ioh, STACK) == i; i++)
;
if (i != STSIZE) {
AIC_START(("STACK futzed at %d.\n", i));
+ bus_space_unmap(iot, ioh, AIC_NPORTS);
return ENXIO;
}
@@ -729,10 +746,10 @@ aic_find(sc)
* now only used for informational purposes.
*/
bzero(chip_id, sizeof(chip_id));
- insb(iobase + ID, chip_id, sizeof(IDSTRING)-1);
- AIC_START(("AIC found at 0x%x ", sc->sc_iobase));
- AIC_START(("ID: %s ",chip_id));
- AIC_START(("chip revision %d\n",(int)inb(iobase + REV)));
+ bus_space_read_multi_1(iot, ioh, ID, chip_id, sizeof(IDSTRING) - 1);
+ AIC_START(("AIC found at 0x%x ", ia->ia_iobase));
+ AIC_START(("ID: %s ", chip_id));
+ AIC_START(("chip revision %d\n",(int)bus_space_read_1(iot, ioh, REV)));
sc->sc_initiator = 7;
sc->sc_freq = 20; /* XXXX Assume 20 MHz. */
@@ -749,6 +766,7 @@ aic_find(sc)
sc->sc_minsync = (2 * 250) / sc->sc_freq;
sc->sc_maxsync = (9 * 250) / sc->sc_freq;
+ bus_space_unmap(iot, ioh, AIC_NPORTS);
return 0;
}
@@ -761,10 +779,17 @@ aicattach(parent, self, aux)
void *aux;
{
struct isa_attach_args *ia = aux;
+ bus_space_tag_t iot = ia->ia_iot;
+ bus_space_handle_t ioh;
struct aic_softc *sc = (void *)self;
AIC_TRACE(("aicattach "));
sc->sc_state = AIC_INIT;
+
+ bus_space_map(iot, ia->ia_iobase, AIC_NPORTS, 0, &ioh);
+ sc->sc_iot = iot;
+ sc->sc_ioh = ioh;
+
aic_init(sc); /* Init chip and driver */
/*
@@ -790,40 +815,53 @@ aicattach(parent, self, aux)
/* Initialize AIC6360 chip itself
* The following conditions should hold:
- * aicprobe should have succeeded, i.e. the iobase address in aic_softc must
+ * aicprobe should have succeeded, i.e. the ioh handle in aic_softc must
* be valid.
*/
void
aic_reset(sc)
struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
- outb(iobase + SCSITEST, 0); /* Doc. recommends to clear these two */
- outb(iobase + TEST, 0); /* registers before operations commence */
+ /*
+ * Doc. recommends to clear these two registers before operations
+ * commence
+ */
+ bus_space_write_1(iot, ioh, SCSITEST, 0);
+ bus_space_write_1(iot, ioh, TEST, 0);
/* Reset SCSI-FIFO and abort any transfers */
- outb(iobase + SXFRCTL0, CHEN | CLRCH | CLRSTCNT);
+ bus_space_write_1(iot, ioh, + SXFRCTL0, CHEN | CLRCH | CLRSTCNT);
/* Reset DMA-FIFO */
- outb(iobase + DMACNTRL0, RSTFIFO);
- outb(iobase + DMACNTRL1, 0);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO);
+ bus_space_write_1(iot, ioh, DMACNTRL1, 0);
- outb(iobase + SCSISEQ, 0); /* Disable all selection features */
- outb(iobase + SXFRCTL1, 0);
+ /* Disable all selection features */
+ bus_space_write_1(iot, ioh, SCSISEQ, 0);
+ bus_space_write_1(iot, ioh, SXFRCTL1, 0);
- outb(iobase + SIMODE0, 0x00); /* Disable some interrupts */
- outb(iobase + CLRSINT0, 0x7f); /* Clear a slew of interrupts */
+ /* Disable some interrupts */
+ bus_space_write_1(iot, ioh, SIMODE0, 0x00);
+ /* Clear a slew of interrupts */
+ bus_space_write_1(iot, ioh, CLRSINT0, 0x7f);
- outb(iobase + SIMODE1, 0x00); /* Disable some more interrupts */
- outb(iobase + CLRSINT1, 0xef); /* Clear another slew of interrupts */
+ /* Disable some more interrupts */
+ bus_space_write_1(iot, ioh, SIMODE1, 0x00);
+ /* Clear another slew of interrupts */
+ bus_space_write_1(iot, ioh, CLRSINT1, 0xef);
- outb(iobase + SCSIRATE, 0); /* Disable synchronous transfers */
+ /* Disable synchronous transfers */
+ bus_space_write_1(iot, ioh, SCSIRATE, 0);
- outb(iobase + CLRSERR, 0x07); /* Haven't seen ant errors (yet) */
+ /* Haven't seen ant errors (yet) */
+ bus_space_write_1(iot, ioh, CLRSERR, 0x07);
- outb(iobase + SCSIID, sc->sc_initiator << OID_S); /* Set our SCSI-ID */
- outb(iobase + BRSTCNTRL, EISA_BRST_TIM);
+ /* Set our SCSI-ID */
+ bus_space_write_1(iot, ioh, SCSIID, sc->sc_initiator << OID_S);
+ bus_space_write_1(iot, ioh, BRSTCNTRL, EISA_BRST_TIM);
}
/* Pull the SCSI RST line for 500 us */
@@ -831,11 +869,12 @@ void
aic_scsi_reset(sc)
struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
- outb(iobase + SCSISEQ, SCSIRSTO);
+ bus_space_write_1(iot, ioh, SCSISEQ, SCSIRSTO);
delay(500);
- outb(iobase + SCSISEQ, 0);
+ bus_space_write_1(iot, ioh, SCSISEQ, 0);
delay(50);
}
@@ -846,7 +885,8 @@ void
aic_init(sc)
struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
struct aic_acb *acb;
int r;
@@ -903,7 +943,7 @@ aic_init(sc)
}
sc->sc_state = AIC_IDLE;
- outb(iobase + DMACNTRL0, INTEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, INTEN);
}
void
@@ -1055,7 +1095,8 @@ aic_poll(sc, xs, count)
struct scsi_xfer *xs;
int count;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
AIC_TRACE(("aic_poll "));
while (count) {
@@ -1063,7 +1104,7 @@ aic_poll(sc, xs, count)
* If we had interrupts enabled, would we
* have got an interrupt?
*/
- if ((inb(iobase + DMASTAT) & INTSTAT) != 0)
+ if ((bus_space_read_1(iot, ioh, DMASTAT) & INTSTAT) != 0)
aicintr(sc);
if ((xs->flags & ITSDONE) != 0)
return 0;
@@ -1082,10 +1123,11 @@ aic_sched_msgout(sc, m)
struct aic_softc *sc;
u_char m;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
if (sc->sc_msgpriq == 0)
- outb(iobase + SCSISIG, sc->sc_phase | ATNO);
+ bus_space_write_1(iot, ioh, SCSISIG, sc->sc_phase | ATNO);
sc->sc_msgpriq |= m;
}
@@ -1098,13 +1140,14 @@ aic_setsync(sc, ti)
struct aic_tinfo *ti;
{
#if AIC_USE_SYNCHRONOUS
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
if (ti->offset != 0)
- outb(iobase + SCSIRATE,
+ bus_space_write_1(iot, ioh, SCSIRATE,
((ti->period * sc->sc_freq) / 250 - 2) << 4 | ti->offset);
else
- outb(iobase + SCSIRATE, 0);
+ bus_space_write_1(iot, ioh, SCSIRATE, 0);
#endif
}
@@ -1117,19 +1160,21 @@ aic_select(sc, acb)
struct aic_softc *sc;
struct aic_acb *acb;
{
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
struct scsi_link *sc_link = acb->xs->sc_link;
int target = sc_link->target;
struct aic_tinfo *ti = &sc->sc_tinfo[target];
- int iobase = sc->sc_iobase;
- outb(iobase + SCSIID, sc->sc_initiator << OID_S | target);
+ bus_space_write_1(iot, ioh, SCSIID,
+ sc->sc_initiator << OID_S | target);
aic_setsync(sc, ti);
- outb(iobase + SXFRCTL1, STIMO_256ms | ENSTIMER);
+ bus_space_write_1(iot, ioh, SXFRCTL1, STIMO_256ms | ENSTIMER);
/* Always enable reselections. */
- outb(iobase + SIMODE0, ENSELDI | ENSELDO);
- outb(iobase + SIMODE1, ENSCSIRST | ENSELTIMO);
- outb(iobase + SCSISEQ, ENRESELI | ENSELO | ENAUTOATNO);
+ bus_space_write_1(iot, ioh, SIMODE0, ENSELDI | ENSELDO);
+ bus_space_write_1(iot, ioh, SIMODE1, ENSCSIRST | ENSELTIMO);
+ bus_space_write_1(iot, ioh, SCSISEQ, ENRESELI | ENSELO | ENAUTOATNO);
sc->sc_state = AIC_SELECTING;
}
@@ -1151,8 +1196,9 @@ aic_reselect(sc, message)
*/
selid = sc->sc_selid & ~(1 << sc->sc_initiator);
if (selid & (selid - 1)) {
- printf("%s: reselect with invalid selid %02x; sending DEVICE RESET\n",
+ printf("%s: reselect with invalid selid %02x; ",
sc->sc_dev.dv_xname, selid);
+ printf("sending DEVICE RESET\n");
AIC_BREAK();
goto reset;
}
@@ -1171,8 +1217,9 @@ aic_reselect(sc, message)
break;
}
if (acb == NULL) {
- printf("%s: reselect from target %d lun %d with no nexus; sending ABORT\n",
+ printf("%s: reselect from target %d lun %d with no nexus; ",
sc->sc_dev.dv_xname, target, lun);
+ printf("sending ABORT\n");
AIC_BREAK();
goto abort;
}
@@ -1217,16 +1264,18 @@ void
aic_sched(sc)
register struct aic_softc *sc;
{
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
struct aic_acb *acb;
struct scsi_link *sc_link;
struct aic_tinfo *ti;
- int iobase = sc->sc_iobase;
/*
* Find first acb in ready queue that is for a target/lunit pair that
* is not busy.
*/
- outb(iobase + CLRSINT1, CLRSELTIMO | CLRBUSFREE | CLRSCSIPERR);
+ bus_space_write_1(iot, ioh, CLRSINT1,
+ CLRSELTIMO | CLRBUSFREE | CLRSCSIPERR);
for (acb = sc->ready_list.tqh_first; acb != NULL;
acb = acb->chain.tqe_next) {
sc_link = acb->xs->sc_link;
@@ -1244,9 +1293,9 @@ aic_sched(sc)
}
AIC_MISC(("idle "));
/* Nothing to start; just enable reselections and wait. */
- outb(iobase + SIMODE0, ENSELDI);
- outb(iobase + SIMODE1, ENSCSIRST);
- outb(iobase + SCSISEQ, ENRESELI);
+ bus_space_write_1(iot, ioh, SIMODE0, ENSELDI);
+ bus_space_write_1(iot, ioh, SIMODE1, ENSCSIRST);
+ bus_space_write_1(iot, ioh, SCSISEQ, ENRESELI);
}
void
@@ -1380,7 +1429,8 @@ void
aic_msgin(sc)
register struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
u_char sstat1;
int n;
@@ -1407,7 +1457,7 @@ nextbyte:
*/
for (;;) {
for (;;) {
- sstat1 = inb(iobase + SSTAT1);
+ sstat1 = bus_space_read_1(iot, ioh, SSTAT1);
if ((sstat1 & (REQINIT | PHASECHG | BUSFREE)) != 0)
break;
/* Wait for REQINIT. XXX Need timeout. */
@@ -1430,11 +1480,12 @@ nextbyte:
/* Gather incoming message bytes if needed. */
if ((sc->sc_flags & AIC_DROP_MSGIN) == 0) {
if (n >= AIC_MAX_MSG_LEN) {
- (void) inb(iobase + SCSIDAT);
+ (void) bus_space_read_1(iot, ioh, SCSIDAT);
sc->sc_flags |= AIC_DROP_MSGIN;
aic_sched_msgout(sc, SEND_REJECT);
} else {
- *sc->sc_imp++ = inb(iobase + SCSIDAT);
+ *sc->sc_imp++ = bus_space_read_1(iot, ioh,
+ SCSIDAT);
n++;
/*
* This testing is suboptimal, but most
@@ -1451,18 +1502,18 @@ nextbyte:
break;
}
} else
- (void) inb(iobase + SCSIDAT);
+ (void) bus_space_read_1(iot, ioh, SCSIDAT);
/*
* If we reach this spot we're either:
* a) in the middle of a multi-byte message, or
* b) dropping bytes.
*/
- outb(iobase + SXFRCTL0, CHEN | SPIOEN);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN | SPIOEN);
/* Ack the last byte read. */
- (void) inb(iobase + SCSIDAT);
- outb(iobase + SXFRCTL0, CHEN);
- while ((inb(iobase + SCSISIG) & ACKI) != 0)
+ (void) bus_space_read_1(iot, ioh, SCSIDAT);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
+ while ((bus_space_read_1(iot, ioh, SCSISIG) & ACKI) != 0)
;
}
@@ -1558,14 +1609,16 @@ nextbyte:
ti->flags &= ~DO_SYNC;
if (ti->offset == 0) {
} else if (ti->period < sc->sc_minsync ||
- ti->period > sc->sc_maxsync ||
- ti->offset > 8) {
+ ti->period > sc->sc_maxsync ||
+ ti->offset > 8) {
ti->period = ti->offset = 0;
aic_sched_msgout(sc, SEND_SDTR);
} else {
sc_print_addr(acb->xs->sc_link);
- printf("sync, offset %d, period %dnsec\n",
- ti->offset, ti->period * 4);
+ printf("sync, offset %d, ",
+ ti->offset);
+ printf("period %dnsec\n",
+ ti->period * 4);
}
aic_setsync(sc, ti);
break;
@@ -1590,8 +1643,9 @@ nextbyte:
#endif
default:
- printf("%s: unrecognized MESSAGE EXTENDED; sending REJECT\n",
+ printf("%s: unrecognized MESSAGE EXTENDED; ",
sc->sc_dev.dv_xname);
+ printf("sending REJECT\n");
AIC_BREAK();
goto reject;
}
@@ -1609,8 +1663,9 @@ nextbyte:
case AIC_RESELECTED:
if (!MSG_ISIDENTIFY(sc->sc_imess[0])) {
- printf("%s: reselect without IDENTIFY; sending DEVICE RESET\n",
+ printf("%s: reselect without IDENTIFY; ",
sc->sc_dev.dv_xname);
+ printf("sending DEVICE RESET\n");
AIC_BREAK();
goto reset;
}
@@ -1633,11 +1688,11 @@ nextbyte:
#endif
}
- outb(iobase + SXFRCTL0, CHEN | SPIOEN);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN | SPIOEN);
/* Ack the last message byte. */
- (void) inb(iobase + SCSIDAT);
- outb(iobase + SXFRCTL0, CHEN);
- while ((inb(iobase + SCSISIG) & ACKI) != 0)
+ (void) bus_space_read_1(iot, ioh, SCSIDAT);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
+ while ((bus_space_read_1(iot, ioh, SCSISIG) & ACKI) != 0)
;
/* Go get the next message, if any. */
@@ -1654,7 +1709,8 @@ void
aic_msgout(sc)
register struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
#if AIC_USE_SYNCHRONOUS
struct aic_tinfo *ti;
#endif
@@ -1664,9 +1720,9 @@ aic_msgout(sc)
AIC_TRACE(("aic_msgout "));
/* Reset the FIFO. */
- outb(iobase + DMACNTRL0, RSTFIFO);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO);
/* Enable REQ/ACK protocol. */
- outb(iobase + SXFRCTL0, CHEN | SPIOEN);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN | SPIOEN);
if (sc->sc_prevphase == PH_MSGOUT) {
if (sc->sc_omp == sc->sc_omess) {
@@ -1687,7 +1743,7 @@ aic_msgout(sc)
* Set ATN. If we're just sending a trivial 1-byte
* message, we'll clear ATN later on anyway.
*/
- outb(iobase + SCSISIG, PH_MSGOUT | ATNO);
+ bus_space_write_1(iot, ioh, SCSISIG, PH_MSGOUT | ATNO);
} else {
/* This is a continuation of the previous message. */
n = sc->sc_omp - sc->sc_omess;
@@ -1780,7 +1836,7 @@ nextbyte:
/* Send message bytes. */
for (;;) {
for (;;) {
- sstat1 = inb(iobase + SSTAT1);
+ sstat1 = bus_space_read_1(iot, ioh, SSTAT1);
if ((sstat1 & (REQINIT | PHASECHG | BUSFREE)) != 0)
break;
/* Wait for REQINIT. XXX Need timeout. */
@@ -1797,20 +1853,20 @@ nextbyte:
* case we reassert ATN anyway).
*/
if (sc->sc_msgpriq == 0)
- outb(iobase + CLRSINT1, CLRATNO);
+ bus_space_write_1(iot, ioh, CLRSINT1, CLRATNO);
goto out;
}
/* Clear ATN before last byte if this is the last message. */
if (n == 1 && sc->sc_msgpriq == 0)
- outb(iobase + CLRSINT1, CLRATNO);
+ bus_space_write_1(iot, ioh, CLRSINT1, CLRATNO);
/* Send message byte. */
- outb(iobase + SCSIDAT, *--sc->sc_omp);
+ bus_space_write_1(iot, ioh, SCSIDAT, *--sc->sc_omp);
--n;
/* Keep track of the last message we've sent any bytes of. */
sc->sc_lastmsg = sc->sc_currmsg;
/* Wait for ACK to be negated. XXX Need timeout. */
- while ((inb(iobase + SCSISIG) & ACKI) != 0)
+ while ((bus_space_read_1(iot, ioh, SCSISIG) & ACKI) != 0)
;
if (n == 0)
@@ -1833,7 +1889,7 @@ nextbyte:
out:
/* Disable REQ/ACK protocol. */
- outb(iobase + SXFRCTL0, CHEN);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
}
/* aic_dataout_pio: perform a data transfer using the FIFO datapath in the aic6360
@@ -1848,19 +1904,20 @@ aic_dataout_pio(sc, p, n)
u_char *p;
int n;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
register u_char dmastat = 0;
int out = 0;
#define DOUTAMOUNT 128 /* Full FIFO */
/* Clear host FIFO and counter. */
- outb(iobase + DMACNTRL0, RSTFIFO | WRITE);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO | WRITE);
/* Enable FIFOs. */
- outb(iobase + SXFRCTL0, SCSIEN | DMAEN | CHEN);
- outb(iobase + DMACNTRL0, ENDMA | DWORDPIO | WRITE);
+ bus_space_write_1(iot, ioh, SXFRCTL0, SCSIEN | DMAEN | CHEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, ENDMA | DWORDPIO | WRITE);
/* Turn off ENREQINIT for now. */
- outb(iobase + SIMODE1,
+ bus_space_write_1(iot, ioh, SIMODE1,
ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENPHASECHG);
/* I have tried to make the main loop as tight as possible. This
@@ -1869,7 +1926,7 @@ aic_dataout_pio(sc, p, n)
*/
while (n > 0) {
for (;;) {
- dmastat = inb(iobase + DMASTAT);
+ dmastat = bus_space_read_1(iot, ioh, DMASTAT);
if ((dmastat & (DFIFOEMP | INTSTAT)) != 0)
break;
}
@@ -1882,9 +1939,11 @@ aic_dataout_pio(sc, p, n)
out += DOUTAMOUNT;
#if AIC_USE_DWORDS
- outsl(iobase + DMADATALONG, p, DOUTAMOUNT >> 2);
+ bus_space_write_multi_4(iot, ioh, DMADATALONG, p,
+ DOUTAMOUNT >> 2);
#else
- outsw(iobase + DMADATA, p, DOUTAMOUNT >> 1);
+ bus_space_write_multi_2(iot, ioh, DMADATA, p,
+ DOUTAMOUNT >> 1);
#endif
p += DOUTAMOUNT;
@@ -1899,51 +1958,57 @@ aic_dataout_pio(sc, p, n)
#if AIC_USE_DWORDS
if (xfer >= 12) {
- outsl(iobase + DMADATALONG, p, xfer >> 2);
+ bus_space_write_multi_4(iot, ioh, DMADATALONG,
+ p, xfer >> 2);
p += xfer & ~3;
xfer &= 3;
}
#else
if (xfer >= 8) {
- outsw(iobase + DMADATA, p, xfer >> 1);
+ bus_space_write_multi_2(iot, ioh, DMADATA, p,
+ xfer >> 1);
p += xfer & ~1;
xfer &= 1;
}
#endif
if (xfer > 0) {
- outb(iobase + DMACNTRL0, ENDMA | B8MODE | WRITE);
- outsb(iobase + DMADATA, p, xfer);
+ bus_space_write_1(iot, ioh, DMACNTRL0,
+ ENDMA | B8MODE | WRITE);
+ bus_space_write_multi_1(iot, ioh, DMADATA, p,
+ xfer);
p += xfer;
- outb(iobase + DMACNTRL0, ENDMA | DWORDPIO | WRITE);
+ bus_space_write_1(iot, ioh, DMACNTRL0,
+ ENDMA | DWORDPIO | WRITE);
}
}
}
if (out == 0) {
- outb(iobase + SXFRCTL1, BITBUCKET);
+ bus_space_write_1(iot, ioh, SXFRCTL1, BITBUCKET);
for (;;) {
- if ((inb(iobase + DMASTAT) & INTSTAT) != 0)
+ if ((bus_space_read_1(iot, ioh, DMASTAT) & INTSTAT) !=
+ 0)
break;
}
- outb(iobase + SXFRCTL1, 0);
+ bus_space_write_1(iot, ioh, SXFRCTL1, 0);
AIC_MISC(("extra data "));
} else {
/* See the bytes off chip */
for (;;) {
- dmastat = inb(iobase + DMASTAT);
+ dmastat = bus_space_read_1(iot, ioh, DMASTAT);
if ((dmastat & INTSTAT) != 0)
goto phasechange;
if ((dmastat & DFIFOEMP) != 0 &&
- (inb(iobase + SSTAT2) & SEMPTY) != 0)
+ (bus_space_read_1(iot, ioh, SSTAT2) & SEMPTY) != 0)
break;
}
}
phasechange:
/* Stop the FIFO data path. */
- outb(iobase + SXFRCTL0, CHEN);
- while ((inb(iobase + SXFRCTL0) & SCSIEN) != 0)
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
+ while ((bus_space_read_1(iot, ioh, SXFRCTL0) & SCSIEN) != 0)
;
if ((dmastat & INTSTAT) != 0) {
@@ -1951,16 +2016,18 @@ phasechange:
int amount;
/* Stop transfers, do some accounting */
- amount = inb(iobase + FIFOSTAT) + (inb(iobase + SSTAT2) & 15);
+ amount = bus_space_read_1(iot, ioh, FIFOSTAT) +
+ (bus_space_read_1(iot, ioh, SSTAT2) & 15);
if (amount > 0) {
out -= amount;
- outb(iobase + SXFRCTL0, CHEN | CLRSTCNT | CLRCH);
+ bus_space_write_1(iot, ioh, SXFRCTL0,
+ CHEN | CLRSTCNT | CLRCH);
AIC_MISC(("+%d ", amount));
}
}
/* Turn on ENREQINIT again. */
- outb(iobase + SIMODE1,
+ bus_space_write_1(iot, ioh, SIMODE1,
ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENREQINIT | ENPHASECHG);
return out;
@@ -1979,19 +2046,20 @@ aic_datain_pio(sc, p, n)
u_char *p;
int n;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
register u_char dmastat;
int in = 0;
#define DINAMOUNT 128 /* Full FIFO */
/* Clear host FIFO and counter. */
- outb(iobase + DMACNTRL0, RSTFIFO);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO);
/* Enable FIFOs. */
- outb(iobase + SXFRCTL0, SCSIEN | DMAEN | CHEN);
- outb(iobase + DMACNTRL0, ENDMA | DWORDPIO);
+ bus_space_write_1(iot, ioh, SXFRCTL0, SCSIEN | DMAEN | CHEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, ENDMA | DWORDPIO);
/* Turn off ENREQINIT for now. */
- outb(iobase + SIMODE1,
+ bus_space_write_1(iot, ioh, SIMODE1,
ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENPHASECHG);
/* We leave this loop if one or more of the following is true:
@@ -2001,7 +2069,7 @@ aic_datain_pio(sc, p, n)
while (n > 0) {
/* Wait for fifo half full or phase mismatch */
for (;;) {
- dmastat = inb(iobase + DMASTAT);
+ dmastat = bus_space_read_1(iot, ioh, DMASTAT);
if ((dmastat & (DFIFOFULL | INTSTAT)) != 0)
break;
}
@@ -2011,16 +2079,18 @@ aic_datain_pio(sc, p, n)
in += DINAMOUNT;
#if AIC_USE_DWORDS
- insl(iobase + DMADATALONG, p, DINAMOUNT >> 2);
+ bus_space_read_multi_4(iot, ioh, DMADATALONG, p,
+ DINAMOUNT >> 2);
#else
- insw(iobase + DMADATA, p, DINAMOUNT >> 1);
+ bus_space_read_multi_2(iot, ioh, DMADATA, p,
+ DINAMOUNT >> 1);
#endif
p += DINAMOUNT;
} else {
register int xfer;
- xfer = min(inb(iobase + FIFOSTAT), n);
+ xfer = min(bus_space_read_1(iot, ioh, FIFOSTAT), n);
AIC_MISC((">%d ", xfer));
n -= xfer;
@@ -2028,23 +2098,28 @@ aic_datain_pio(sc, p, n)
#if AIC_USE_DWORDS
if (xfer >= 12) {
- insl(iobase + DMADATALONG, p, xfer >> 2);
+ bus_space_read_multi_4(iot, ioh, DMADATALONG,
+ p, xfer >> 2);
p += xfer & ~3;
xfer &= 3;
}
#else
if (xfer >= 8) {
- insw(iobase + DMADATA, p, xfer >> 1);
+ bus_space_read_multi_2(iot, ioh, DMADATA, p,
+ xfer >> 1);
p += xfer & ~1;
xfer &= 1;
}
#endif
if (xfer > 0) {
- outb(iobase + DMACNTRL0, ENDMA | B8MODE);
- insb(iobase + DMADATA, p, xfer);
+ bus_space_write_1(iot, ioh, DMACNTRL0,
+ ENDMA | B8MODE);
+ bus_space_read_multi_1(iot, ioh, DMADATA, p,
+ xfer);
p += xfer;
- outb(iobase + DMACNTRL0, ENDMA | DWORDPIO);
+ bus_space_write_1(iot, ioh, DMACNTRL0,
+ ENDMA | DWORDPIO);
}
}
@@ -2059,23 +2134,24 @@ aic_datain_pio(sc, p, n)
* FIFO is not empty, waste some bytes....
*/
if (in == 0) {
- outb(iobase + SXFRCTL1, BITBUCKET);
+ bus_space_write_1(iot, ioh, SXFRCTL1, BITBUCKET);
for (;;) {
- if ((inb(iobase + DMASTAT) & INTSTAT) != 0)
+ if ((bus_space_read_1(iot, ioh, DMASTAT) & INTSTAT) !=
+ 0)
break;
}
- outb(iobase + SXFRCTL1, 0);
+ bus_space_write_1(iot, ioh, SXFRCTL1, 0);
AIC_MISC(("extra data "));
}
phasechange:
/* Stop the FIFO data path. */
- outb(iobase + SXFRCTL0, CHEN);
- while ((inb(iobase + SXFRCTL0) & SCSIEN) != 0)
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
+ while ((bus_space_read_1(iot, ioh, SXFRCTL0) & SCSIEN) != 0)
;
/* Turn on ENREQINIT again. */
- outb(iobase + SIMODE1,
+ bus_space_write_1(iot, ioh, SIMODE1,
ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENREQINIT | ENPHASECHG);
return in;
@@ -2091,7 +2167,8 @@ aicintr(arg)
void *arg;
{
register struct aic_softc *sc = arg;
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
u_char sstat0, sstat1;
register struct aic_acb *acb;
register struct scsi_link *sc_link;
@@ -2102,7 +2179,7 @@ aicintr(arg)
* Clear INTEN. We enable it again before returning. This makes the
* interrupt esssentially level-triggered.
*/
- outb(iobase + DMACNTRL0, 0);
+ bus_space_write_1(iot, ioh, DMACNTRL0, 0);
AIC_TRACE(("aicintr "));
@@ -2110,7 +2187,7 @@ loop:
/*
* First check for abnormal conditions, such as reset.
*/
- sstat1 = inb(iobase + SSTAT1);
+ sstat1 = bus_space_read_1(iot, ioh, SSTAT1);
AIC_MISC(("sstat1:0x%02x ", sstat1));
if ((sstat1 & SCSIRSTI) != 0) {
@@ -2123,7 +2200,7 @@ loop:
*/
if ((sstat1 & SCSIPERR) != 0) {
printf("%s: SCSI bus parity error\n", sc->sc_dev.dv_xname);
- outb(iobase + CLRSINT1, CLRSCSIPERR);
+ bus_space_write_1(iot, ioh, CLRSINT1, CLRSCSIPERR);
if (sc->sc_prevphase == PH_MSGIN) {
sc->sc_flags |= AIC_DROP_MSGIN;
aic_sched_msgout(sc, SEND_PARITY_ERROR);
@@ -2144,7 +2221,7 @@ loop:
switch (sc->sc_state) {
case AIC_IDLE:
case AIC_SELECTING:
- sstat0 = inb(iobase + SSTAT0);
+ sstat0 = bus_space_read_1(iot, ioh, SSTAT0);
AIC_MISC(("sstat0:0x%02x ", sstat0));
if ((sstat0 & TARGET) != 0) {
@@ -2153,7 +2230,7 @@ loop:
*/
printf("%s: target mode selected; going to BUS FREE\n",
sc->sc_dev.dv_xname);
- outb(iobase + SCSISIG, 0);
+ bus_space_write_1(iot, ioh, SCSISIG, 0);
goto sched;
} else if ((sstat0 & SELDI) != 0) {
@@ -2172,7 +2249,7 @@ loop:
}
/* Save reselection ID. */
- sc->sc_selid = inb(iobase + SELID);
+ sc->sc_selid = bus_space_read_1(iot, ioh, SELID);
sc->sc_state = AIC_RESELECTED;
} else if ((sstat0 & SELDO) != 0) {
@@ -2184,8 +2261,9 @@ loop:
* c) Mark device as busy.
*/
if (sc->sc_state != AIC_SELECTING) {
- printf("%s: selection out while idle; resetting\n",
+ printf("%s: selection out while idle; ",
sc->sc_dev.dv_xname);
+ printf("resetting\n");
AIC_BREAK();
goto reset;
}
@@ -2221,32 +2299,35 @@ loop:
/* On our first connection, schedule a timeout. */
if ((acb->xs->flags & SCSI_POLL) == 0)
- timeout(aic_timeout, acb, (acb->timeout * hz) / 1000);
+ timeout(aic_timeout, acb,
+ (acb->timeout * hz) / 1000);
sc->sc_state = AIC_CONNECTED;
} else if ((sstat1 & SELTO) != 0) {
AIC_MISC(("selection timeout "));
if (sc->sc_state != AIC_SELECTING) {
- printf("%s: selection timeout while idle; resetting\n",
+ printf("%s: selection timeout while idle; ",
sc->sc_dev.dv_xname);
+ printf("resetting\n");
AIC_BREAK();
goto reset;
}
AIC_ASSERT(sc->sc_nexus != NULL);
acb = sc->sc_nexus;
- outb(iobase + SXFRCTL1, 0);
- outb(iobase + SCSISEQ, ENRESELI);
- outb(iobase + CLRSINT1, CLRSELTIMO);
+ bus_space_write_1(iot, ioh, SXFRCTL1, 0);
+ bus_space_write_1(iot, ioh, SCSISEQ, ENRESELI);
+ bus_space_write_1(iot, ioh, CLRSINT1, CLRSELTIMO);
delay(250);
acb->xs->error = XS_SELTIMEOUT;
goto finish;
} else {
if (sc->sc_state != AIC_IDLE) {
- printf("%s: BUS FREE while not idle; state=%d\n",
- sc->sc_dev.dv_xname, sc->sc_state);
+ printf("%s: BUS FREE while not idle; ",
+ sc->sc_dev.dv_xname);
+ printf("state=%d\n", sc->sc_state);
AIC_BREAK();
goto out;
}
@@ -2258,14 +2339,16 @@ loop:
* Turn off selection stuff, and prepare to catch bus free
* interrupts, parity errors, and phase changes.
*/
- outb(iobase + SXFRCTL0, CHEN | CLRSTCNT | CLRCH);
- outb(iobase + SXFRCTL1, 0);
- outb(iobase + SCSISEQ, ENAUTOATNP);
- outb(iobase + CLRSINT0, CLRSELDI | CLRSELDO);
- outb(iobase + CLRSINT1, CLRBUSFREE | CLRPHASECHG);
- outb(iobase + SIMODE0, 0);
- outb(iobase + SIMODE1,
- ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENREQINIT | ENPHASECHG);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN | CLRSTCNT | CLRCH);
+ bus_space_write_1(iot, ioh, SXFRCTL1, 0);
+ bus_space_write_1(iot, ioh, SCSISEQ, ENAUTOATNP);
+ bus_space_write_1(iot, ioh, CLRSINT0, CLRSELDI | CLRSELDO);
+ bus_space_write_1(iot, ioh, CLRSINT1,
+ CLRBUSFREE | CLRPHASECHG);
+ bus_space_write_1(iot, ioh, SIMODE0, 0);
+ bus_space_write_1(iot, ioh, SIMODE1,
+ ENSCSIRST | ENSCSIPERR | ENBUSFREE | ENREQINIT |
+ ENPHASECHG);
sc->sc_flags = 0;
sc->sc_prevphase = PH_INVALID;
@@ -2274,7 +2357,8 @@ loop:
if ((sstat1 & BUSFREE) != 0) {
/* We've gone to BUS FREE phase. */
- outb(iobase + CLRSINT1, CLRBUSFREE | CLRPHASECHG);
+ bus_space_write_1(iot, ioh, CLRSINT1,
+ CLRBUSFREE | CLRPHASECHG);
switch (sc->sc_state) {
case AIC_RESELECTED:
@@ -2319,8 +2403,9 @@ loop:
* disconnecting, and this is necessary to
* clean up their state.
*/
- printf("%s: unexpected disconnect; sending REQUEST SENSE\n",
+ printf("%s: unexpected disconnect; ",
sc->sc_dev.dv_xname);
+ printf("sending REQUEST SENSE\n");
AIC_BREAK();
aic_sense(sc, acb);
goto out;
@@ -2343,7 +2428,7 @@ loop:
}
}
- outb(iobase + CLRSINT1, CLRPHASECHG);
+ bus_space_write_1(iot, ioh, CLRSINT1, CLRPHASECHG);
dophase:
if ((sstat1 & REQINIT) == 0) {
@@ -2351,8 +2436,8 @@ dophase:
goto out;
}
- sc->sc_phase = inb(iobase + SCSISIG) & PH_MASK;
- outb(iobase + SCSISIG, sc->sc_phase);
+ sc->sc_phase = bus_space_read_1(iot, ioh, SCSISIG) & PH_MASK;
+ bus_space_write_1(iot, ioh, SCSISIG, sc->sc_phase);
switch (sc->sc_phase) {
case PH_MSGOUT:
@@ -2414,12 +2499,12 @@ dophase:
AIC_ASSERT(sc->sc_nexus != NULL);
acb = sc->sc_nexus;
/* XXXX Don't clear FIFO. Wait for byte to come in. */
- outb(iobase + SXFRCTL0, CHEN | SPIOEN);
- outb(iobase + DMACNTRL0, RSTFIFO);
- acb->target_stat = inb(iobase + SCSIDAT);
- outb(iobase + SXFRCTL0, CHEN);
- outb(iobase + DMACNTRL0, RSTFIFO);
- while ((inb(iobase + SXFRCTL0) & SCSIEN) != 0)
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN | SPIOEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO);
+ acb->target_stat = bus_space_read_1(iot, ioh, SCSIDAT);
+ bus_space_write_1(iot, ioh, SXFRCTL0, CHEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, RSTFIFO);
+ while ((bus_space_read_1(iot, ioh, SXFRCTL0) & SCSIEN) != 0)
;
AIC_MISC(("target_stat=0x%02x ", acb->target_stat));
sc->sc_prevphase = PH_STAT;
@@ -2443,7 +2528,7 @@ sched:
goto out;
out:
- outb(iobase + DMACNTRL0, INTEN);
+ bus_space_write_1(iot, ioh, DMACNTRL0, INTEN);
return 1;
}
@@ -2561,20 +2646,30 @@ void
aic_dump6360(sc)
struct aic_softc *sc;
{
- int iobase = sc->sc_iobase;
+ bus_space_handle_t iot = sc->sc_iot;
+ bus_space_handle_t ioh = sc->sc_ioh;
printf("aic6360: SCSISEQ=%x SXFRCTL0=%x SXFRCTL1=%x SCSISIG=%x\n",
- inb(iobase + SCSISEQ), inb(iobase + SXFRCTL0),
- inb(iobase + SXFRCTL1), inb(iobase + SCSISIG));
+ bus_space_read_1(iot, ioh, SCSISEQ),
+ bus_space_read_1(iot, ioh, SXFRCTL0),
+ bus_space_read_1(iot, ioh, SXFRCTL1),
+ bus_space_read_1(iot, ioh, SCSISIG));
printf(" SSTAT0=%x SSTAT1=%x SSTAT2=%x SSTAT3=%x SSTAT4=%x\n",
- inb(iobase + SSTAT0), inb(iobase + SSTAT1), inb(iobase + SSTAT2),
- inb(iobase + SSTAT3), inb(iobase + SSTAT4));
- printf(" SIMODE0=%x SIMODE1=%x DMACNTRL0=%x DMACNTRL1=%x DMASTAT=%x\n",
- inb(iobase + SIMODE0), inb(iobase + SIMODE1),
- inb(iobase + DMACNTRL0), inb(iobase + DMACNTRL1),
- inb(iobase + DMASTAT));
+ bus_space_read_1(iot, ioh, SSTAT0),
+ bus_space_read_1(iot, ioh, SSTAT1),
+ bus_space_read_1(iot, ioh, SSTAT2),
+ bus_space_read_1(iot, ioh, SSTAT3),
+ bus_space_read_1(iot, ioh, SSTAT4));
+ printf(" SIMODE0=%x SIMODE1=%x ",
+ bus_space_read_1(iot, ioh, SIMODE0),
+ bus_space_read_1(iot, ioh, SIMODE1));
+ printf("DMACNTRL0=%x DMACNTRL1=%x DMASTAT=%x\n",
+ bus_space_read_1(iot, ioh, DMACNTRL0),
+ bus_space_read_1(iot, ioh, DMACNTRL1),
+ bus_space_read_1(iot, ioh, DMASTAT));
printf(" FIFOSTAT=%d SCSIBUS=0x%x\n",
- inb(iobase + FIFOSTAT), inb(iobase + SCSIBUS));
+ bus_space_read_1(iot, ioh, FIFOSTAT),
+ bus_space_read_1(iot, ioh, SCSIBUS));
}
void
@@ -2585,9 +2680,9 @@ aic_dump_driver(sc)
int i;
printf("nexus=%p prevphase=%x\n", sc->sc_nexus, sc->sc_prevphase);
- printf("state=%x msgin=%x msgpriq=%x msgoutq=%x lastmsg=%x currmsg=%x\n",
- sc->sc_state, sc->sc_imess[0],
- sc->sc_msgpriq, sc->sc_msgoutq, sc->sc_lastmsg, sc->sc_currmsg);
+ printf("state=%x msgin=%x ", sc->sc_state, sc->sc_imess[0]);
+ printf("msgpriq=%x msgoutq=%x lastmsg=%x currmsg=%x\n", sc->sc_msgpriq,
+ sc->sc_msgoutq, sc->sc_lastmsg, sc->sc_currmsg);
for (i = 0; i < 7; i++) {
ti = &sc->sc_tinfo[i];
printf("tinfo%d: %d cmds %d disconnects %d timeouts",