diff options
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/mfi.c | 48 | ||||
-rw-r--r-- | sys/dev/ic/mfireg.h | 17 |
2 files changed, 22 insertions, 43 deletions
diff --git a/sys/dev/ic/mfi.c b/sys/dev/ic/mfi.c index 15e95b35a45..f0ab43580ab 100644 --- a/sys/dev/ic/mfi.c +++ b/sys/dev/ic/mfi.c @@ -1,4 +1,4 @@ -/* $OpenBSD: mfi.c,v 1.123 2012/08/11 00:57:01 dlg Exp $ */ +/* $OpenBSD: mfi.c,v 1.124 2012/08/13 03:04:51 dlg Exp $ */ /* * Copyright (c) 2006 Marco Peereboom <marco@peereboom.us> * @@ -428,54 +428,38 @@ mfi_initialize_firmware(struct mfi_softc *sc) struct mfi_ccb *ccb; struct mfi_init_frame *init; struct mfi_init_qinfo *qinfo; - uint64_t handy; + int rv; DNPRINTF(MFI_D_MISC, "%s: mfi_initialize_firmware\n", DEVNAME(sc)); - if ((ccb = mfi_get_ccb(sc)) == NULL) + ccb = scsi_io_get(&sc->sc_iopool, 0); + if (ccb == NULL) return (1); init = &ccb->ccb_frame->mfr_init; qinfo = (struct mfi_init_qinfo *)((uint8_t *)init + MFI_FRAME_SIZE); - memset(qinfo, 0, sizeof *qinfo); - qinfo->miq_rq_entries = sc->sc_max_cmds + 1; + memset(qinfo, 0, sizeof(*qinfo)); + qinfo->miq_rq_entries = htole32(sc->sc_max_cmds + 1); - handy = MFIMEM_DVA(sc->sc_pcq) + - offsetof(struct mfi_prod_cons, mpc_reply_q); - qinfo->miq_rq_addr_hi = htole32(handy >> 32); - qinfo->miq_rq_addr_lo = htole32(handy); + qinfo->miq_rq_addr = htole64(MFIMEM_DVA(sc->sc_pcq) + + offsetof(struct mfi_prod_cons, mpc_reply_q)); - handy = MFIMEM_DVA(sc->sc_pcq) + - offsetof(struct mfi_prod_cons, mpc_producer); - qinfo->miq_pi_addr_hi = htole32(handy >> 32); - qinfo->miq_pi_addr_lo = htole32(handy); + qinfo->miq_pi_addr = htole64(MFIMEM_DVA(sc->sc_pcq) + + offsetof(struct mfi_prod_cons, mpc_producer)); - handy = MFIMEM_DVA(sc->sc_pcq) + - offsetof(struct mfi_prod_cons, mpc_consumer); - qinfo->miq_ci_addr_hi = htole32(handy >> 32); - qinfo->miq_ci_addr_lo = htole32(handy); + qinfo->miq_ci_addr = htole64(MFIMEM_DVA(sc->sc_pcq) + + offsetof(struct mfi_prod_cons, mpc_consumer)); init->mif_header.mfh_cmd = MFI_CMD_INIT; - init->mif_header.mfh_data_len = sizeof *qinfo; - init->mif_qinfo_new_addr_lo = htole32(ccb->ccb_pframe + MFI_FRAME_SIZE); - - DNPRINTF(MFI_D_MISC, "%s: entries: %08x%08x rq: %08x%08x pi: %#x " - "ci: %08x%08x\n", - DEVNAME(sc), - qinfo->miq_rq_entries, - qinfo->miq_rq_addr_hi, qinfo->miq_rq_addr_lo, - qinfo->miq_pi_addr_hi, qinfo->miq_pi_addr_lo, - qinfo->miq_ci_addr_hi, qinfo->miq_ci_addr_lo); + init->mif_header.mfh_data_len = htole32(sizeof(*qinfo)); + init->mif_qinfo_new_addr = htole64(ccb->ccb_pframe + MFI_FRAME_SIZE); - if (mfi_poll(ccb)) { - printf("%s: mfi_initialize_firmware failed\n", DEVNAME(sc)); - return (1); - } + rv = mfi_poll(ccb); mfi_put_ccb(sc, ccb); - return (0); + return (rv); } int diff --git a/sys/dev/ic/mfireg.h b/sys/dev/ic/mfireg.h index 7a6a817ce35..b6a763c15b6 100644 --- a/sys/dev/ic/mfireg.h +++ b/sys/dev/ic/mfireg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: mfireg.h,v 1.30 2012/01/12 06:12:30 dlg Exp $ */ +/* $OpenBSD: mfireg.h,v 1.31 2012/08/13 03:04:51 dlg Exp $ */ /* * Copyright (c) 2006 Marco Peereboom <marco@peereboom.us> * @@ -299,10 +299,8 @@ union mfi_sgl_frame { struct mfi_init_frame { struct mfi_frame_header mif_header; - uint32_t mif_qinfo_new_addr_lo; - uint32_t mif_qinfo_new_addr_hi; - uint32_t mif_qinfo_old_addr_lo; - uint32_t mif_qinfo_old_addr_hi; + uint64_t mif_qinfo_new_addr; + uint64_t mif_qinfo_old_addr; uint32_t mif_reserved[6]; } __packed; @@ -310,12 +308,9 @@ struct mfi_init_frame { struct mfi_init_qinfo { uint32_t miq_flags; uint32_t miq_rq_entries; - uint32_t miq_rq_addr_lo; - uint32_t miq_rq_addr_hi; - uint32_t miq_pi_addr_lo; - uint32_t miq_pi_addr_hi; - uint32_t miq_ci_addr_lo; - uint32_t miq_ci_addr_hi; + uint64_t miq_rq_addr; + uint64_t miq_pi_addr; + uint64_t miq_ci_addr; } __packed; #define MFI_IO_FRAME_SIZE 40 |