diff options
Diffstat (limited to 'sys/dev/i2o/iop.c')
-rw-r--r-- | sys/dev/i2o/iop.c | 49 |
1 files changed, 27 insertions, 22 deletions
diff --git a/sys/dev/i2o/iop.c b/sys/dev/i2o/iop.c index 66202f78140..d4f1d2999c5 100644 --- a/sys/dev/i2o/iop.c +++ b/sys/dev/i2o/iop.c @@ -1,4 +1,4 @@ -/* $OpenBSD: iop.c,v 1.10 2001/06/26 12:06:31 mickey Exp $ */ +/* $OpenBSD: iop.c,v 1.11 2001/06/26 20:05:21 niklas Exp $ */ /* $NetBSD: iop.c,v 1.12 2001/03/21 14:27:05 ad Exp $ */ /*- @@ -222,15 +222,14 @@ void iop_adjqparam(struct iop_softc *, int); void iop_create_reconf_thread(void *); int iop_handle_reply(struct iop_softc *, u_int32_t); int iop_hrt_get(struct iop_softc *); -int iop_hrt_get0(struct iop_softc *, struct i2o_hrt *, int); +int iop_hrt_get0(struct iop_softc *, struct i2o_hrt *, size_t); void iop_intr_event(struct device *, struct iop_msg *, void *); -int iop_lct_get0(struct iop_softc *, struct i2o_lct *, int, - u_int32_t); +int iop_lct_get0(struct iop_softc *, struct i2o_lct *, size_t, u_int32_t); void iop_msg_poll(struct iop_softc *, struct iop_msg *, int); void iop_msg_wait(struct iop_softc *, struct iop_msg *, int); int iop_ofifo_init(struct iop_softc *); int iop_passthrough(struct iop_softc *, struct ioppt *); -int iop_post(struct iop_softc *, u_int32_t *, int size); +int iop_post(struct iop_softc *, u_int32_t *); void iop_reconf_thread(void *); void iop_release_mfa(struct iop_softc *, u_int32_t); int iop_reset(struct iop_softc *); @@ -922,7 +921,7 @@ iop_status_get(struct iop_softc *sc, int nosleep) bzero(st, sizeof(*st)); bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD); - if ((rv = iop_post(sc, (u_int32_t *)&mf, sizeof(mf)))) + if ((rv = iop_post(sc, (u_int32_t *)&mf))) return (rv); /* XXX */ @@ -960,6 +959,7 @@ iop_ofifo_init(struct iop_softc *sc) mb[sizeof(*mf) / sizeof(u_int32_t) + 0] = sizeof(*sw) | I2O_SGL_SIMPLE | I2O_SGL_END_BUFFER | I2O_SGL_END; mb[sizeof(*mf) / sizeof(u_int32_t) + 1] = sc->sc_scr_seg->ds_addr; + mb[0] += 2 << 16; *sw = 0; bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD); @@ -970,7 +970,7 @@ iop_ofifo_init(struct iop_softc *sc) * that if you don't want to get the list of MFAs, an IGNORE SGL is * necessary; this isn't the case (and is in fact a bad thing). */ - if ((rv = iop_post(sc, mb, sizeof(*mf) + 2 * sizeof(*mb)))) + if ((rv = iop_post(sc, mb))) return (rv); /* XXX */ @@ -1034,7 +1034,7 @@ iop_ofifo_init(struct iop_softc *sc) * Read the specified number of bytes from the IOP's hardware resource table. */ int -iop_hrt_get0(struct iop_softc *sc, struct i2o_hrt *hrt, int size) +iop_hrt_get0(struct iop_softc *sc, struct i2o_hrt *hrt, size_t size) { struct iop_msg *im; struct i2o_exec_hrt_get *mf; @@ -1062,7 +1062,8 @@ int iop_hrt_get(struct iop_softc *sc) { struct i2o_hrt hrthdr, *hrt; - int size, rv; + size_t size; + int rv; PHOLD(curproc); rv = iop_hrt_get0(sc, &hrthdr, sizeof(hrthdr)); @@ -1097,7 +1098,7 @@ iop_hrt_get(struct iop_softc *sc) * to wait indefinitely. */ int -iop_lct_get0(struct iop_softc *sc, struct i2o_lct *lct, int size, +iop_lct_get0(struct iop_softc *sc, struct i2o_lct *lct, size_t size, u_int32_t chgind) { struct iop_msg *im; @@ -1136,7 +1137,8 @@ iop_lct_get0(struct iop_softc *sc, struct i2o_lct *lct, int size, int iop_lct_get(struct iop_softc *sc) { - int esize, size, rv; + size_t esize, size; + int rv; struct i2o_lct *lct; esize = letoh32(sc->sc_status.expectedlctsize); @@ -1180,7 +1182,7 @@ iop_lct_get(struct iop_softc *sc) */ int iop_param_op(struct iop_softc *sc, int tid, struct iop_initiator *ii, - int write, int group, void *buf, int size) + int write, int group, void *buf, size_t size) { struct iop_msg *im; struct i2o_util_params_op *mf; @@ -1372,7 +1374,7 @@ iop_reset(struct iop_softc *sc) *sw = 0; bus_dmamap_sync(sc->sc_dmat, sc->sc_scr_dmamap, BUS_DMASYNC_PREREAD); - if ((rv = iop_post(sc, (u_int32_t *)&mf, sizeof(mf)))) + if ((rv = iop_post(sc, (u_int32_t *)&mf))) return (rv); /* XXX */ @@ -1689,7 +1691,7 @@ iop_msg_free(struct iop_softc *sc, struct iop_msg *im) */ int iop_msg_map(struct iop_softc *sc, struct iop_msg *im, u_int32_t *mb, - void *xferaddr, int xfersize, int out) + void *xferaddr, size_t xfersize, int out) { bus_dmamap_t dm; bus_dma_segment_t *ds; @@ -1731,7 +1733,7 @@ iop_msg_map(struct iop_softc *sc, struct iop_msg *im, u_int32_t *mb, */ off = mb[0] >> 16; p = mb + off; - nsegs = ((IOP_MAX_MSG_SIZE / 4) - off) >> 1; + nsegs = ((IOP_MAX_MSG_SIZE / sizeof *mb) - off) >> 1; if (dm->dm_nsegs > nsegs) { bus_dmamap_unload(sc->sc_dmat, ix->ix_map); @@ -1914,13 +1916,14 @@ iop_msg_unmap(struct iop_softc *sc, struct iop_msg *im) * Post a message frame to the IOP's inbound queue. */ int -iop_post(struct iop_softc *sc, u_int32_t *mb, int size) +iop_post(struct iop_softc *sc, u_int32_t *mb) { u_int32_t mfa; int s; + size_t size = mb[0] >> 14 & ~3; /* ZZZ */ - if (size > IOP_MAX_MSG_SIZE) + if (size > IOP_MAX_MSG_SIZE) panic("iop_post: frame too large"); #ifdef I2ODEBUG @@ -1928,7 +1931,7 @@ iop_post(struct iop_softc *sc, u_int32_t *mb, int size) int i; printf("\niop_post\n"); - for (i = 0; i < size / 4; i++) + for (i = 0; i < size / sizeof *mb; i++) printf("%4d %08x\n", i, mb[i]); } #endif @@ -1954,8 +1957,9 @@ iop_post(struct iop_softc *sc, u_int32_t *mb, int size) BUS_DMASYNC_PREREAD); /* Copy out the message frame. */ - bus_space_write_region_4(sc->sc_iot, sc->sc_ioh, mfa, mb, size / 4); - bus_space_barrier(sc->sc_iot, sc->sc_ioh, mfa, size & ~3, + bus_space_write_region_4(sc->sc_iot, sc->sc_ioh, mfa, mb, + size / sizeof *mb); + bus_space_barrier(sc->sc_iot, sc->sc_ioh, mfa, size, BUS_SPACE_BARRIER_WRITE); /* Post the MFA back to the IOP. */ @@ -1972,13 +1976,14 @@ int iop_msg_post(struct iop_softc *sc, struct iop_msg *im, void *xmb, int timo) { u_int32_t *mb = xmb; - int rv, s, size = mb[0] >> 16; + int rv, s; + size_t size = mb[0] >> 14 & 3; /* Terminate the scatter/gather list chain. */ if ((im->im_flags & IM_SGLOFFADJ) != 0) mb[size - 2] |= I2O_SGL_END; - if ((rv = iop_post(sc, mb, size)) != 0) + if ((rv = iop_post(sc, mb)) != 0) return (rv); if ((im->im_flags & IM_DISCARD) != 0) |