diff options
-rw-r--r-- | sys/dev/ic/iha.c | 134 | ||||
-rw-r--r-- | sys/dev/ic/iha.h | 20 |
2 files changed, 78 insertions, 76 deletions
diff --git a/sys/dev/ic/iha.c b/sys/dev/ic/iha.c index f5f9f367426..a7cf935908b 100644 --- a/sys/dev/ic/iha.c +++ b/sys/dev/ic/iha.c @@ -1,4 +1,4 @@ -/* $OpenBSD: iha.c,v 1.20 2003/03/29 23:28:49 krw Exp $ */ +/* $OpenBSD: iha.c,v 1.21 2003/03/30 00:32:48 krw Exp $ */ /*------------------------------------------------------------------------- * * Device driver for the INI-9XXXU/UW or INIC-940/950 PCI SCSI Controller. @@ -71,7 +71,7 @@ struct scsi_device iha_dev = { * SCSI Rate Table, indexed by FLAG_SCSI_RATE field of * TCS_Flags. */ -static const u_int8_t iha_rate_tbl[8] = { +static const u_int8_t iha_rate_tbl[] = { /* fast 20 */ /* nanosecond divide by 4 */ 12, /* 50ns, 20M */ @@ -84,9 +84,9 @@ static const u_int8_t iha_rate_tbl[8] = { 62 /* 250ns, 4M */ }; -int iha_setup_sg_list(struct iha_softc *, struct iha_scsi_req_q *); -u_int8_t iha_data_over_run(struct iha_scsi_req_q *); -int iha_push_sense_request(struct iha_softc *, struct iha_scsi_req_q *); +int iha_setup_sg_list(struct iha_softc *, struct iha_scb *); +u_int8_t iha_data_over_run(struct iha_scb *); +int iha_push_sense_request(struct iha_softc *, struct iha_scb *); void iha_timeout(void *); int iha_alloc_scbs(struct iha_softc *); void iha_read_eeprom(bus_space_tag_t, bus_space_handle_t, @@ -99,22 +99,22 @@ void iha_reset_chip(struct iha_softc *, void iha_reset_dma(bus_space_tag_t, bus_space_handle_t); void iha_reset_tcs(struct tcs *, u_int8_t); void iha_print_info(struct iha_softc *, int); -void iha_done_scb(struct iha_softc *, struct iha_scsi_req_q *); -void iha_exec_scb(struct iha_softc *, struct iha_scsi_req_q *); +void iha_done_scb(struct iha_softc *, struct iha_scb *); +void iha_exec_scb(struct iha_softc *, struct iha_scb *); void iha_main(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); void iha_scsi(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); int iha_wait(struct iha_softc *, bus_space_tag_t, bus_space_handle_t, u_int8_t); -void iha_mark_busy_scb(struct iha_scsi_req_q *); -void iha_append_free_scb(struct iha_softc *, struct iha_scsi_req_q *); -struct iha_scsi_req_q *iha_pop_free_scb(struct iha_softc *); -void iha_append_done_scb(struct iha_softc *, struct iha_scsi_req_q *, +void iha_mark_busy_scb(struct iha_scb *); +void iha_append_free_scb(struct iha_softc *, struct iha_scb *); +struct iha_scb *iha_pop_free_scb(struct iha_softc *); +void iha_append_done_scb(struct iha_softc *, struct iha_scb *, u_int8_t); -struct iha_scsi_req_q *iha_pop_done_scb(struct iha_softc *); -void iha_append_pend_scb(struct iha_softc *, struct iha_scsi_req_q *); -void iha_push_pend_scb(struct iha_softc *, struct iha_scsi_req_q *); -void iha_del_pend_scb(struct iha_softc *, struct iha_scsi_req_q *); -struct iha_scsi_req_q *iha_find_pend_scb(struct iha_softc *); +struct iha_scb *iha_pop_done_scb(struct iha_softc *); +void iha_append_pend_scb(struct iha_softc *, struct iha_scb *); +void iha_push_pend_scb(struct iha_softc *, struct iha_scb *); +void iha_del_pend_scb(struct iha_softc *, struct iha_scb *); +struct iha_scb *iha_find_pend_scb(struct iha_softc *); void iha_sync_done(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); void iha_wide_done(struct iha_softc *, @@ -142,7 +142,7 @@ int iha_xpad_in(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); int iha_xpad_out(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); -int iha_xfer_data(struct iha_scsi_req_q *, +int iha_xfer_data(struct iha_scb *, bus_space_tag_t, bus_space_handle_t, int direction); int iha_status_msg(struct iha_softc *, @@ -167,7 +167,7 @@ int iha_msgout_wdtr(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); void iha_select(struct iha_softc *, bus_space_tag_t, bus_space_handle_t, - struct iha_scsi_req_q *, u_int8_t); + struct iha_scb *, u_int8_t); void iha_busfree(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); int iha_resel(struct iha_softc *, bus_space_tag_t, bus_space_handle_t); @@ -217,7 +217,7 @@ iha_intr(arg) int iha_setup_sg_list(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { bus_dma_segment_t *segs = pScb->SCB_DataDma->dm_segs; int i, error, nseg = pScb->SCB_DataDma->dm_nsegs; @@ -264,7 +264,7 @@ int iha_scsi_cmd(xs) struct scsi_xfer *xs; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct scsi_link *sc_link = xs->sc_link; struct iha_softc *sc = sc_link->adapter_softc; int error; @@ -366,7 +366,7 @@ int iha_init_tulip(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct iha_nvram_scsi *pScsi; bus_space_handle_t ioh; struct iha_nvram iha_nvram; @@ -514,11 +514,11 @@ iha_reset_dma(iot, ioh) /* * iha_pop_free_scb - return the first free SCB, or NULL if there are none. */ -struct iha_scsi_req_q * +struct iha_scb * iha_pop_free_scb(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; int s; s = splbio(); @@ -543,7 +543,7 @@ iha_pop_free_scb(sc) void iha_append_free_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { int s; @@ -584,7 +584,7 @@ iha_append_free_scb(sc, pScb) void iha_append_pend_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { /* ASSUMPTION: only called within a splbio()/splx() pair */ @@ -599,7 +599,7 @@ iha_append_pend_scb(sc, pScb) void iha_push_pend_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { int s; @@ -621,11 +621,11 @@ iha_push_pend_scb(sc, pScb) * and a pointer to the SCB if one is found. If there * is an active SCB, return NULL! */ -struct iha_scsi_req_q * +struct iha_scb * iha_find_pend_scb(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct tcs *pTcs; int s; @@ -682,7 +682,7 @@ iha_find_pend_scb(sc) void iha_del_pend_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { int s; @@ -695,7 +695,7 @@ iha_del_pend_scb(sc, pScb) void iha_mark_busy_scb(pScb) - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { int s; @@ -714,7 +714,7 @@ iha_mark_busy_scb(pScb) void iha_append_done_scb(sc, pScb, hastat) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; u_int8_t hastat; { struct tcs *pTcs; @@ -744,11 +744,11 @@ iha_append_done_scb(sc, pScb, hastat) splx(s); } -struct iha_scsi_req_q * +struct iha_scb * iha_pop_done_scb(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; int s; s = splbio(); @@ -776,7 +776,7 @@ iha_abort_xs(sc, xs, hastat) struct scsi_xfer *xs; u_int8_t hastat; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; int i, s; s = splbio(); @@ -821,7 +821,7 @@ void iha_bad_seq(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; if (pScb != NULL) iha_append_done_scb(sc, pScb, HOST_BAD_PHAS); @@ -838,7 +838,7 @@ iha_bad_seq(sc) int iha_push_sense_request(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { struct scsi_sense *sensecmd; int error; @@ -922,7 +922,7 @@ iha_main(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; for (;;) { iha_scsi_label: @@ -984,7 +984,7 @@ iha_scsi(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct tcs *pTcs; u_int8_t stat; int i; @@ -1094,7 +1094,7 @@ iha_scsi(sc, iot, ioh) */ u_int8_t iha_data_over_run(pScb) - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { switch (pScb->SCB_CDB[0]) { case 0x03: /* Request Sense SPC-2 */ @@ -1227,7 +1227,7 @@ iha_state_1(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; struct tcs *pTcs; u_int16_t flags; @@ -1288,7 +1288,7 @@ iha_state_2(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; iha_mark_busy_scb(pScb); @@ -1315,7 +1315,7 @@ iha_state_3(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; u_int16_t flags; for (;;) @@ -1374,7 +1374,7 @@ iha_state_4(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; if ((pScb->SCB_Flags & FLAG_DIR) == FLAG_DIR) return (6); /* Both dir flags set => NO xfer was requested */ @@ -1437,7 +1437,7 @@ iha_state_5(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; struct iha_sg_element *pSg; u_int32_t cnt; u_int16_t period; @@ -1581,7 +1581,7 @@ iha_state_8(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; u_int32_t i; u_int8_t tar; @@ -1627,7 +1627,7 @@ iha_state_8(sc, iot, ioh) */ int iha_xfer_data(pScb, iot, ioh, direction) - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; bus_space_tag_t iot; bus_space_handle_t ioh; int direction; @@ -1672,7 +1672,7 @@ iha_xpad_in(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; if ((pScb->SCB_Flags & FLAG_DIR) != 0) pScb->SCB_HaStat = HOST_DO_DU; @@ -1704,7 +1704,7 @@ iha_xpad_out(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb = sc->HCS_ActScb; + struct iha_scb *pScb = sc->HCS_ActScb; if ((pScb->SCB_Flags & FLAG_DIR) != 0) pScb->SCB_HaStat = HOST_DO_DU; @@ -1739,7 +1739,7 @@ iha_status_msg(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; u_int8_t msg; int phase; @@ -1812,7 +1812,7 @@ iha_busfree(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; bus_space_write_1(iot, ioh, TUL_SCTRL0, RSFIFO); bus_space_write_1(iot, ioh, TUL_SCONFIG0, SCONFIG0DEFAULT); @@ -1835,7 +1835,7 @@ void iha_reset_scsi_bus(sc) struct iha_softc *sc; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct tcs *pTcs; int i, s; @@ -1872,7 +1872,7 @@ iha_resel(sc, iot, ioh) bus_space_tag_t iot; bus_space_handle_t ioh; { - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; struct tcs *pTcs; u_int8_t tag, target, lun, msg, abortmsg; @@ -2102,13 +2102,15 @@ iha_msgin_extended(sc, iot, ioh) flags = sc->HCS_ActScb->SCB_Tcs->TCS_Flags; if ((flags & FLAG_NO_WIDE) != 0) - sc->HCS_Msg[2] = 0; /* Offer async xfers only */ + /* Offer 8 bit xfers only */ + sc->HCS_Msg[2] = MSG_EXT_WDTR_BUS_8_BIT; - else if (sc->HCS_Msg[2] > 2) /* BAD MSG: 2 is max value */ + else if (sc->HCS_Msg[2] > MSG_EXT_WDTR_BUS_32_BIT) return (iha_msgout_reject(sc, iot, ioh)); - else if (sc->HCS_Msg[2] == 2) /* a request for 32 bit xfers*/ - sc->HCS_Msg[2] = 1; /* Offer 16 instead */ + else if (sc->HCS_Msg[2] == MSG_EXT_WDTR_BUS_32_BIT) + /* Offer 16 instead */ + sc->HCS_Msg[2] = MSG_EXT_WDTR_BUS_32_BIT; else { iha_wide_done(sc, iot, ioh); @@ -2319,7 +2321,7 @@ iha_sync_done(sc, iot, ioh) pTcs->TCS_JS_Period |= sc->HCS_Msg[3]; /* pick the highest possible rate */ - for (i = 0; i < 8; i++) + for (i = 0; i < sizeof(iha_rate_tbl); i++) if (iha_rate_tbl[i] >= sc->HCS_Msg[2]) break; @@ -2366,7 +2368,7 @@ iha_select(sc, iot, ioh, pScb, select_type) struct iha_softc *sc; bus_space_tag_t iot; bus_space_handle_t ioh; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; u_int8_t select_type; { switch (select_type) { @@ -2488,7 +2490,7 @@ iha_wait(sc, iot, ioh, cmd) void iha_done_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { struct scsi_sense_data *s1, *s2; struct scsi_xfer *xs = pScb->SCB_Xs; @@ -2582,7 +2584,7 @@ void iha_timeout(arg) void *arg; { - struct iha_scsi_req_q *pScb = (struct iha_scsi_req_q *)arg; + struct iha_scb *pScb = (struct iha_scb *)arg; struct scsi_xfer *xs = pScb->SCB_Xs; if (xs != NULL) { @@ -2595,7 +2597,7 @@ iha_timeout(arg) void iha_exec_scb(sc, pScb) struct iha_softc *sc; - struct iha_scsi_req_q *pScb; + struct iha_scb *pScb; { bus_space_handle_t ioh; bus_space_tag_t iot; @@ -2618,13 +2620,13 @@ iha_exec_scb(sc, pScb) ioh = sc->sc_ioh; bus_space_write_1(iot, ioh, TUL_IMSK, MASK_ALL); - sc->HCS_Semaph = SEMAPH_IN_MAIN;; + sc->HCS_Semaph = SEMAPH_IN_MAIN; splx(s); iha_main(sc, iot, ioh); s = splbio(); - sc->HCS_Semaph = ~SEMAPH_IN_MAIN;; + sc->HCS_Semaph = ~SEMAPH_IN_MAIN; bus_space_write_1(iot, ioh, TUL_IMSK, (MASK_ALL & ~MSCMP)); } @@ -2691,7 +2693,7 @@ iha_alloc_scbs(sc) * Allocate dma-safe memory for the SCB's */ if ((error = bus_dmamem_alloc(sc->sc_dmat, - sizeof(struct iha_scsi_req_q)*IHA_MAX_SCB, + sizeof(struct iha_scb)*IHA_MAX_SCB, NBPG, 0, &seg, 1, &rseg, BUS_DMA_NOWAIT)) != 0) { printf("%s: unable to allocate SCBs," @@ -2699,14 +2701,14 @@ iha_alloc_scbs(sc) return (error); } if ((error = bus_dmamem_map(sc->sc_dmat, - &seg, rseg, sizeof(struct iha_scsi_req_q)*IHA_MAX_SCB, + &seg, rseg, sizeof(struct iha_scb)*IHA_MAX_SCB, (caddr_t *)&sc->HCS_Scb, BUS_DMA_NOWAIT | BUS_DMA_COHERENT)) != 0) { printf("%s: unable to map SCBs, error = %d\n", sc->sc_dev.dv_xname, error); return (error); } - bzero(sc->HCS_Scb, sizeof(struct iha_scsi_req_q)*IHA_MAX_SCB); + bzero(sc->HCS_Scb, sizeof(struct iha_scb)*IHA_MAX_SCB); return (0); } diff --git a/sys/dev/ic/iha.h b/sys/dev/ic/iha.h index cfad53dcc33..04eb9043744 100644 --- a/sys/dev/ic/iha.h +++ b/sys/dev/ic/iha.h @@ -1,4 +1,4 @@ -/* $OpenBSD: iha.h,v 1.12 2003/03/29 17:52:01 krw Exp $ */ +/* $OpenBSD: iha.h,v 1.13 2003/03/30 00:32:48 krw Exp $ */ /*------------------------------------------------------------------------- * * Device driver for the INI-9XXXU/UW or INIC-940/950 PCI SCSI Controller. @@ -47,13 +47,13 @@ struct iha_sg_element { }; /* - * iha_scsi_req_q - SCSI Request structure used by the - * Tulip (aka inic-940/950). Note that 32 - * bit pointers and ints are assumed! + * iha_scb - SCSI Request structure used by the + * Tulip (aka inic-940/950). Note that 32 + * bit pointers and ints are assumed! */ -struct iha_scsi_req_q { - TAILQ_ENTRY(iha_scsi_req_q) SCB_ScbList; +struct iha_scb { + TAILQ_ENTRY(iha_scb) SCB_ScbList; bus_dmamap_t SCB_DataDma; /* maps xfer buffer */ bus_dmamap_t SCB_SGDma; /* maps scatter-gather list */ @@ -121,7 +121,7 @@ struct tcs { u_int8_t TCS_SConfig0; u_int8_t TCS_TagCnt; - struct iha_scsi_req_q *TCS_NonTagScb; + struct iha_scb *TCS_NonTagScb; }; struct iha_softc { @@ -161,10 +161,10 @@ struct iha_softc { u_int8_t HCS_SConf1; u_int8_t HCS_Msg[IHA_MAX_EXTENDED_MSG]; /* [0] len, [1] Msg Code */ - struct iha_scsi_req_q *HCS_Scb; /* SCB array */ - struct iha_scsi_req_q *HCS_ActScb; /* SCB using SCSI bus */ + struct iha_scb *HCS_Scb; /* SCB array */ + struct iha_scb *HCS_ActScb; /* SCB using SCSI bus */ - TAILQ_HEAD(, iha_scsi_req_q) HCS_FreeScb, HCS_PendScb, HCS_DoneScb; + TAILQ_HEAD(, iha_scb) HCS_FreeScb, HCS_PendScb, HCS_DoneScb; struct tcs HCS_Tcs[IHA_MAX_TARGETS]; }; |