summaryrefslogtreecommitdiff
path: root/sys/dev/ic/sili.c
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2007-04-10 09:08:20 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2007-04-10 09:08:20 +0000
commit66df66d3125d71f546435396484bc98d8d7518b6 (patch)
tree3f242446104951d1ccf3780759bf10687407bad6 /sys/dev/ic/sili.c
parentf58ddb7eb5f4c39992eca97bad5d2b72753bd853 (diff)
wrap reading of the error fis up into a func of its own, and use
bus_space_read_raw_region_4 to do it. more archs are happy with it.
Diffstat (limited to 'sys/dev/ic/sili.c')
-rw-r--r--sys/dev/ic/sili.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/sys/dev/ic/sili.c b/sys/dev/ic/sili.c
index 24c8fdda643..f0cc325d2ea 100644
--- a/sys/dev/ic/sili.c
+++ b/sys/dev/ic/sili.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sili.c,v 1.30 2007/04/08 08:13:30 pascoe Exp $ */
+/* $OpenBSD: sili.c,v 1.31 2007/04/10 09:08:19 dlg Exp $ */
/*
* Copyright (c) 2007 David Gwynne <dlg@openbsd.org>
@@ -144,6 +144,8 @@ void sili_post_direct(struct sili_port *, u_int,
void *, size_t buflen);
void sili_post_indirect(struct sili_port *,
struct sili_ccb *);
+void sili_pread_fis(struct sili_port *, u_int,
+ struct ata_fis_d2h *);
u_int32_t sili_signature(struct sili_port *, u_int);
int sili_load(struct sili_ccb *, struct sili_sge *, int);
void sili_unload(struct sili_ccb *);
@@ -231,7 +233,6 @@ sili_port_intr(struct sili_port *sp, int timeout_slot)
if (is & SILI_PREG_IS_CMDERR) {
int err_slot, err_code;
u_int32_t sactive = 0;
- bus_size_t r;
sili_pwrite(sp, SILI_PREG_IS, SILI_PREG_IS_CMDERR);
err_slot = SILI_PREG_PCS_ACTIVE(sili_pread(sp, SILI_PREG_PCS));
@@ -241,13 +242,7 @@ sili_port_intr(struct sili_port *sp, int timeout_slot)
case SILI_PREG_CE_DEVICEERROR:
case SILI_PREG_CE_DATAFISERROR:
/* Extract error from command slot in LRAM. */
- r = SILI_PREG_SLOT(err_slot) + 8;
- bus_space_barrier(sp->sp_sc->sc_iot_port, sp->sp_ioh,
- r, sizeof(struct ata_fis_d2h),
- BUS_SPACE_BARRIER_READ);
- bus_space_read_region_1(sp->sp_sc->sc_iot_port,
- sp->sp_ioh, r, &ccb->ccb_xa.rfis,
- sizeof(struct ata_fis_d2h));
+ sili_pread_fis(sp, err_slot, &ccb->ccb_xa.rfis);
break;
case SILI_PREG_CE_SDBERROR:
@@ -692,6 +687,17 @@ sili_post_direct(struct sili_port *sp, u_int slot, void *buf, size_t buflen)
}
void
+sili_pread_fis(struct sili_port *sp, u_int slot, struct ata_fis_d2h *fis)
+{
+ bus_size_t r = SILI_PREG_SLOT(slot) + 8;
+
+ bus_space_barrier(sp->sp_sc->sc_iot_port, sp->sp_ioh, r,
+ sizeof(struct ata_fis_d2h), BUS_SPACE_BARRIER_READ);
+ bus_space_read_raw_region_4(sp->sp_sc->sc_iot_port, sp->sp_ioh, r,
+ fis, sizeof(struct ata_fis_d2h));
+}
+
+void
sili_post_indirect(struct sili_port *sp, struct sili_ccb *ccb)
{
sili_pwrite(sp, SILI_PREG_CAR_LO(ccb->ccb_xa.tag),