diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/ic/re.c | 56 | ||||
-rw-r--r-- | sys/dev/ic/rtl81x9reg.h | 48 |
2 files changed, 64 insertions, 40 deletions
diff --git a/sys/dev/ic/re.c b/sys/dev/ic/re.c index d0203b58bb4..f3bba86e11e 100644 --- a/sys/dev/ic/re.c +++ b/sys/dev/ic/re.c @@ -1,4 +1,4 @@ -/* $OpenBSD: re.c,v 1.181 2015/10/25 12:48:46 mpi Exp $ */ +/* $OpenBSD: re.c,v 1.182 2015/11/02 00:08:50 dlg Exp $ */ /* $FreeBSD: if_re.c,v 1.31 2004/09/04 07:54:05 ru Exp $ */ /* * Copyright (c) 1997, 1998-2003 @@ -674,6 +674,7 @@ re_attach(struct rl_softc *sc, const char *intrstr) int error = 0, i; const struct re_revision *rr; const char *re_name = NULL; + int ntxsegs; sc->sc_hwrev = CSR_READ_4(sc, RL_TXCFG) & RL_TXCFG_HWREV; @@ -908,16 +909,20 @@ re_attach(struct rl_softc *sc, const char *intrstr) /* * Set RX length mask, TX poll request register - * and TX descriptor count. + * and descriptor count. */ if (sc->sc_hwrev == RL_HWREV_8139CPLUS) { sc->rl_rxlenmask = RL_RDESC_STAT_FRAGLEN; sc->rl_txstart = RL_TXSTART; - sc->rl_ldata.rl_tx_desc_cnt = RL_TX_DESC_CNT_8139; + sc->rl_ldata.rl_tx_desc_cnt = RL_8139_TX_DESC_CNT; + sc->rl_ldata.rl_rx_desc_cnt = RL_8139_RX_DESC_CNT; + ntxsegs = RL_8139_NTXSEGS; } else { sc->rl_rxlenmask = RL_RDESC_STAT_GFRAGLEN; sc->rl_txstart = RL_GTXSTART; - sc->rl_ldata.rl_tx_desc_cnt = RL_TX_DESC_CNT_8169; + sc->rl_ldata.rl_tx_desc_cnt = RL_8169_TX_DESC_CNT; + sc->rl_ldata.rl_rx_desc_cnt = RL_8169_RX_DESC_CNT; + ntxsegs = RL_8169_NTXSEGS; } bcopy(eaddr, (char *)&sc->sc_arpcom.ac_enaddr, ETHER_ADDR_LEN); @@ -980,7 +985,7 @@ re_attach(struct rl_softc *sc, const char *intrstr) /* Create DMA maps for TX buffers */ for (i = 0; i < RL_TX_QLEN; i++) { error = bus_dmamap_create(sc->sc_dmat, - RL_JUMBO_FRAMELEN, RL_NTXSEGS, RL_JUMBO_FRAMELEN, + RL_JUMBO_FRAMELEN, ntxsegs, RL_JUMBO_FRAMELEN, 0, 0, &sc->rl_ldata.rl_txq[i].txq_dmamap); if (error) { printf("%s: can't create DMA map for TX\n", @@ -990,7 +995,7 @@ re_attach(struct rl_softc *sc, const char *intrstr) } /* Allocate DMA'able memory for the RX ring */ - if ((error = bus_dmamem_alloc(sc->sc_dmat, RL_RX_DMAMEM_SZ, + if ((error = bus_dmamem_alloc(sc->sc_dmat, RL_RX_DMAMEM_SZ(sc), RL_RING_ALIGN, 0, &sc->rl_ldata.rl_rx_listseg, 1, &sc->rl_ldata.rl_rx_listnseg, BUS_DMA_NOWAIT | BUS_DMA_ZERO)) != 0) { @@ -1001,7 +1006,7 @@ re_attach(struct rl_softc *sc, const char *intrstr) /* Load the map for the RX ring. */ if ((error = bus_dmamem_map(sc->sc_dmat, &sc->rl_ldata.rl_rx_listseg, - sc->rl_ldata.rl_rx_listnseg, RL_RX_DMAMEM_SZ, + sc->rl_ldata.rl_rx_listnseg, RL_RX_DMAMEM_SZ(sc), (caddr_t *)&sc->rl_ldata.rl_rx_list, BUS_DMA_COHERENT | BUS_DMA_NOWAIT)) != 0) { printf("%s: can't map rx list, error = %d\n", @@ -1010,8 +1015,8 @@ re_attach(struct rl_softc *sc, const char *intrstr) } - if ((error = bus_dmamap_create(sc->sc_dmat, RL_RX_DMAMEM_SZ, 1, - RL_RX_DMAMEM_SZ, 0, 0, + if ((error = bus_dmamap_create(sc->sc_dmat, RL_RX_DMAMEM_SZ(sc), 1, + RL_RX_DMAMEM_SZ(sc), 0, 0, &sc->rl_ldata.rl_rx_list_map)) != 0) { printf("%s: can't create rx list map, error = %d\n", sc->sc_dev.dv_xname, error); @@ -1020,14 +1025,14 @@ re_attach(struct rl_softc *sc, const char *intrstr) if ((error = bus_dmamap_load(sc->sc_dmat, sc->rl_ldata.rl_rx_list_map, sc->rl_ldata.rl_rx_list, - RL_RX_DMAMEM_SZ, NULL, BUS_DMA_NOWAIT)) != 0) { + RL_RX_DMAMEM_SZ(sc), NULL, BUS_DMA_NOWAIT)) != 0) { printf("%s: can't load rx list, error = %d\n", sc->sc_dev.dv_xname, error); goto fail_7; } /* Create DMA maps for RX buffers */ - for (i = 0; i < RL_RX_DESC_CNT; i++) { + for (i = 0; i < sc->rl_ldata.rl_rx_desc_cnt; i++) { error = bus_dmamap_create(sc->sc_dmat, RL_FRAMELEN(sc->rl_max_mtu), 1, RL_FRAMELEN(sc->rl_max_mtu), 0, 0, @@ -1116,7 +1121,7 @@ re_attach(struct rl_softc *sc, const char *intrstr) fail_8: /* Destroy DMA maps for RX buffers. */ - for (i = 0; i < RL_RX_DESC_CNT; i++) { + for (i = 0; i < sc->rl_ldata.rl_rx_desc_cnt; i++) { if (sc->rl_ldata.rl_rxsoft[i].rxs_dmamap != NULL) bus_dmamap_destroy(sc->sc_dmat, sc->rl_ldata.rl_rxsoft[i].rxs_dmamap); @@ -1128,7 +1133,7 @@ fail_7: bus_dmamap_destroy(sc->sc_dmat, sc->rl_ldata.rl_rx_list_map); fail_6: bus_dmamem_unmap(sc->sc_dmat, - (caddr_t)sc->rl_ldata.rl_rx_list, RL_RX_DMAMEM_SZ); + (caddr_t)sc->rl_ldata.rl_rx_list, RL_RX_DMAMEM_SZ(sc)); fail_5: bus_dmamem_free(sc->sc_dmat, &sc->rl_ldata.rl_rx_listseg, sc->rl_ldata.rl_rx_listnseg); @@ -1206,7 +1211,7 @@ re_newbuf(struct rl_softc *sc) d->rl_vlanctl = 0; cmdstat = map->dm_segs[0].ds_len; - if (idx == (RL_RX_DESC_CNT - 1)) + if (idx == sc->rl_ldata.rl_rx_desc_cnt - 1) cmdstat |= RL_RDESC_CMD_EOR; re_set_bufaddr(d, map->dm_segs[0].ds_addr); d->rl_cmdstat = htole32(cmdstat); @@ -1237,7 +1242,7 @@ re_tx_list_init(struct rl_softc *sc) BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); sc->rl_ldata.rl_txq_prodidx = 0; sc->rl_ldata.rl_txq_considx = 0; - sc->rl_ldata.rl_tx_free = RL_TX_DESC_CNT(sc); + sc->rl_ldata.rl_tx_free = sc->rl_ldata.rl_tx_desc_cnt; sc->rl_ldata.rl_tx_nextfree = 0; return (0); @@ -1246,13 +1251,13 @@ re_tx_list_init(struct rl_softc *sc) int re_rx_list_init(struct rl_softc *sc) { - bzero(sc->rl_ldata.rl_rx_list, RL_RX_LIST_SZ); + bzero(sc->rl_ldata.rl_rx_list, RL_RX_LIST_SZ(sc)); sc->rl_ldata.rl_rx_prodidx = 0; sc->rl_ldata.rl_rx_considx = 0; sc->rl_head = sc->rl_tail = NULL; - if_rxr_init(&sc->rl_ldata.rl_rx_ring, 2, RL_RX_DESC_CNT); + if_rxr_init(&sc->rl_ldata.rl_rx_ring, 2, sc->rl_ldata.rl_rx_desc_cnt); re_rx_list_fill(sc); return (0); @@ -1263,7 +1268,8 @@ re_rx_list_fill(struct rl_softc *sc) { u_int slots; - for (slots = if_rxr_get(&sc->rl_ldata.rl_rx_ring, RL_RX_DESC_CNT); + for (slots = if_rxr_get(&sc->rl_ldata.rl_rx_ring, + sc->rl_ldata.rl_rx_desc_cnt); slots > 0; slots--) { if (re_newbuf(sc) == ENOBUFS) break; @@ -1473,7 +1479,7 @@ re_txeof(struct rl_softc *sc) tx = 1; sc->rl_ldata.rl_tx_free += txq->txq_nsegs; - KASSERT(sc->rl_ldata.rl_tx_free <= RL_TX_DESC_CNT(sc)); + KASSERT(sc->rl_ldata.rl_tx_free <= sc->rl_ldata.rl_tx_desc_cnt); bus_dmamap_sync(sc->sc_dmat, txq->txq_dmamap, 0, txq->txq_dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE); bus_dmamap_unload(sc->sc_dmat, txq->txq_dmamap); @@ -1499,7 +1505,7 @@ re_txeof(struct rl_softc *sc) * to restart the channel here to flush them out. This only * seems to be required with the PCIe devices. */ - if (sc->rl_ldata.rl_tx_free < RL_TX_DESC_CNT(sc)) + if (sc->rl_ldata.rl_tx_free < sc->rl_ldata.rl_tx_desc_cnt) CSR_WRITE_1(sc, sc->rl_txstart, RL_TXSTART_START); else ifp->if_timer = 0; @@ -1758,8 +1764,8 @@ re_encap(struct rl_softc *sc, struct mbuf *m, int *idx) printf("%s: tried to map busy TX descriptor\n", sc->sc_dev.dv_xname); for (; seg > 0; seg --) { - uidx = (curidx + RL_TX_DESC_CNT(sc) - seg) % - RL_TX_DESC_CNT(sc); + uidx = (curidx + sc->rl_ldata.rl_tx_desc_cnt - + seg) % sc->rl_ldata.rl_tx_desc_cnt; sc->rl_ldata.rl_tx_list[uidx].rl_cmdstat = 0; RL_TXDESCSYNC(sc, uidx, BUS_DMASYNC_PREREAD|BUS_DMASYNC_PREWRITE); @@ -1775,7 +1781,7 @@ re_encap(struct rl_softc *sc, struct mbuf *m, int *idx) cmdstat |= RL_TDESC_CMD_SOF; else cmdstat |= RL_TDESC_CMD_OWN; - if (curidx == (RL_TX_DESC_CNT(sc) - 1)) + if (curidx == sc->rl_ldata.rl_tx_desc_cnt - 1) cmdstat |= RL_TDESC_CMD_EOR; if (seg == nsegs - 1) { cmdstat |= RL_TDESC_CMD_EOF; @@ -1792,7 +1798,7 @@ re_encap(struct rl_softc *sc, struct mbuf *m, int *idx) cmdstat = csum_flags | RL_TDESC_CMD_OWN | RL_TDESC_CMD_EOF | (RL_IP4CSUMTX_PADLEN + 1 - m->m_pkthdr.len); - if (curidx == (RL_TX_DESC_CNT(sc) - 1)) + if (curidx == sc->rl_ldata.rl_tx_desc_cnt - 1) cmdstat |= RL_TDESC_CMD_EOR; d->rl_cmdstat = htole32(cmdstat); RL_TXDESCSYNC(sc, curidx, @@ -2205,7 +2211,7 @@ re_stop(struct ifnet *ifp) } /* Free the RX list buffers. */ - for (i = 0; i < RL_RX_DESC_CNT; i++) { + for (i = 0; i < sc->rl_ldata.rl_rx_desc_cnt; i++) { if (sc->rl_ldata.rl_rxsoft[i].rxs_mbuf != NULL) { bus_dmamap_unload(sc->sc_dmat, sc->rl_ldata.rl_rxsoft[i].rxs_dmamap); diff --git a/sys/dev/ic/rtl81x9reg.h b/sys/dev/ic/rtl81x9reg.h index 1e089c4e2d7..f527c09817c 100644 --- a/sys/dev/ic/rtl81x9reg.h +++ b/sys/dev/ic/rtl81x9reg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rtl81x9reg.h,v 1.95 2015/09/04 07:05:44 jsg Exp $ */ +/* $OpenBSD: rtl81x9reg.h,v 1.96 2015/11/02 00:08:50 dlg Exp $ */ /* * Copyright (c) 1997, 1998 @@ -700,15 +700,32 @@ struct rl_stats { u_int16_t rl_rx_underruns; }; -#define RL_RX_DESC_CNT 64 -#define RL_TX_DESC_CNT_8139 64 -#define RL_TX_DESC_CNT_8169 512 +/* + * Rx/Tx descriptor parameters (8139C+ and 8169 only) + * + * 8139C+ + * Number of descriptors supported : up to 64 + * Descriptor alignment : 256 bytes + * Tx buffer : At least 4 bytes in length. + * Rx buffer : At least 8 bytes in length and 8 bytes alignment required. + * + * 8169 + * Number of descriptors supported : up to 1024 + * Descriptor alignment : 256 bytes + * Tx buffer : At least 4 bytes in length. + * Rx buffer : At least 8 bytes in length and 8 bytes alignment required. + */ +#define RL_8169_TX_DESC_CNT 1024 +#define RL_8169_RX_DESC_CNT 1024 +#define RL_8139_TX_DESC_CNT 64 +#define RL_8139_RX_DESC_CNT 64 +#define RL_TX_DESC_CNT RL_8169_TX_DESC_CNT +#define RL_RX_DESC_CNT RL_8169_RX_DESC_CNT +#define RL_8169_NTXSEGS 32 +#define RL_8139_NTXSEGS 8 #define RL_TX_QLEN 64 -#define RL_NTXSEGS 32 - -#define RL_RX_LIST_SZ (RL_RX_DESC_CNT * sizeof(struct rl_desc)) #define RL_RING_ALIGN 256 #define RL_PKTSZ(x) ((x)/* >> 3*/) #ifdef __STRICT_ALIGNMENT @@ -719,14 +736,14 @@ struct rl_stats { #define RE_RX_DESC_BUFLEN MCLBYTES #endif -#define RL_TX_DESC_CNT(sc) \ - ((sc)->rl_ldata.rl_tx_desc_cnt) #define RL_TX_LIST_SZ(sc) \ - (RL_TX_DESC_CNT(sc) * sizeof(struct rl_desc)) + ((sc)->rl_ldata.rl_tx_desc_cnt * sizeof(struct rl_desc)) +#define RL_RX_LIST_SZ(sc) \ + ((sc)->rl_ldata.rl_rx_desc_cnt * sizeof(struct rl_desc)) #define RL_NEXT_TX_DESC(sc, x) \ - (((x) + 1) % RL_TX_DESC_CNT(sc)) + (((x) + 1) % (sc)->rl_ldata.rl_tx_desc_cnt) #define RL_NEXT_RX_DESC(sc, x) \ - (((x) + 1) % RL_RX_DESC_CNT) + (((x) + 1) % (sc)->rl_ldata.rl_rx_desc_cnt) #define RL_NEXT_TXQ(sc, x) \ (((x) + 1) % RL_TX_QLEN) @@ -825,6 +842,7 @@ struct rl_list_data { struct rl_desc *rl_rx_list; int rl_rx_considx; int rl_rx_prodidx; + int rl_rx_desc_cnt; /* # of descriptors */ struct if_rxring rl_rx_ring; bus_dma_segment_t rl_rx_listseg; int rl_rx_listnseg; @@ -913,10 +931,10 @@ struct rl_softc { * because RL_TX_LIST_SZ(sc) always occupies whole page but * RL_RX_LIST_SZ is less than PAGE_SIZE so there is some unused region. */ -#define RL_RX_DMAMEM_SZ (RL_RX_LIST_SZ + RL_IP4CSUMTX_PADLEN) -#define RL_TXPADOFF RL_RX_LIST_SZ +#define RL_RX_DMAMEM_SZ(sc) (RL_RX_LIST_SZ(sc) + RL_IP4CSUMTX_PADLEN) +#define RL_TXPADOFF(sc) RL_RX_LIST_SZ(sc) #define RL_TXPADDADDR(sc) \ - ((sc)->rl_ldata.rl_rx_list_map->dm_segs[0].ds_addr + RL_TXPADOFF) + ((sc)->rl_ldata.rl_rx_list_map->dm_segs[0].ds_addr + RL_TXPADOFF(sc)) /* * register space access macros |