diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2016-01-07 07:03:56 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2016-01-07 07:03:56 +0000 |
commit | 1e0be319db43d0b607b648088b1c6919190c91f0 (patch) | |
tree | 7c76d70c405ef06761acdc935e4dd5a435ec1d18 /sys/dev | |
parent | ef85dd7e175b7b4a50e4f9b6176fb758961ea96a (diff) |
prefix the rx and tx ring softc members with sc_
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/pci/if_em.c | 308 | ||||
-rw-r--r-- | sys/dev/pci/if_em.h | 34 |
2 files changed, 172 insertions, 170 deletions
diff --git a/sys/dev/pci/if_em.c b/sys/dev/pci/if_em.c index e386f38a21a..6112071dc29 100644 --- a/sys/dev/pci/if_em.c +++ b/sys/dev/pci/if_em.c @@ -31,7 +31,7 @@ POSSIBILITY OF SUCH DAMAGE. ***************************************************************************/ -/* $OpenBSD: if_em.c,v 1.322 2016/01/07 06:49:04 dlg Exp $ */ +/* $OpenBSD: if_em.c,v 1.323 2016/01/07 07:03:55 dlg Exp $ */ /* $FreeBSD: if_em.c,v 1.46 2004/09/29 18:28:28 mlaier Exp $ */ #include <dev/pci/if_em.h> @@ -308,8 +308,8 @@ em_defer_attach(struct device *self) em_stop(sc, 1); em_free_pci_resources(sc); - em_dma_free(sc, &sc->rxdma); - em_dma_free(sc, &sc->txdma); + em_dma_free(sc, &sc->sc_rxdma); + em_dma_free(sc, &sc->sc_txdma); return; } @@ -362,11 +362,11 @@ em_attach(struct device *parent, struct device *self, void *aux) /* Parameters (to be read from user) */ if (sc->hw.mac_type >= em_82544) { - sc->num_tx_desc = EM_MAX_TXD; - sc->num_rx_desc = EM_MAX_RXD; + sc->sc_num_tx_desc = EM_MAX_TXD; + sc->sc_num_rx_desc = EM_MAX_RXD; } else { - sc->num_tx_desc = EM_MAX_TXD_82543; - sc->num_rx_desc = EM_MAX_RXD_82543; + sc->sc_num_tx_desc = EM_MAX_TXD_82543; + sc->sc_num_rx_desc = EM_MAX_RXD_82543; } sc->tx_int_delay = EM_TIDV; sc->tx_abs_int_delay = EM_TADV; @@ -376,7 +376,7 @@ em_attach(struct device *parent, struct device *self, void *aux) sc->hw.wait_autoneg_complete = WAIT_FOR_AUTO_NEG_DEFAULT; sc->hw.autoneg_advertised = AUTONEG_ADV_DEFAULT; sc->hw.tbi_compatibility_en = TRUE; - sc->rx_buffer_len = EM_RXBUFFER_2048; + sc->sc_rx_buffer_len = EM_RXBUFFER_2048; sc->hw.phy_init_script = 1; sc->hw.phy_reset_disable = FALSE; @@ -454,22 +454,22 @@ em_attach(struct device *parent, struct device *self, void *aux) ETHER_MIN_LEN + ETHER_CRC_LEN; /* Allocate Transmit Descriptor ring */ - if (em_dma_malloc(sc, sc->num_tx_desc * sizeof(struct em_tx_desc), - &sc->txdma) != 0) { + if (em_dma_malloc(sc, sc->sc_num_tx_desc * sizeof(struct em_tx_desc), + &sc->sc_txdma) != 0) { printf("%s: Unable to allocate tx_desc memory\n", DEVNAME(sc)); goto err_tx_desc; } - sc->tx_desc_base = (struct em_tx_desc *)sc->txdma.dma_vaddr; + sc->sc_tx_desc_base = (struct em_tx_desc *)sc->sc_txdma.dma_vaddr; /* Allocate Receive Descriptor ring */ - if (em_dma_malloc(sc, sc->num_rx_desc * sizeof(struct em_rx_desc), - &sc->rxdma) != 0) { + if (em_dma_malloc(sc, sc->sc_num_rx_desc * sizeof(struct em_rx_desc), + &sc->sc_rxdma) != 0) { printf("%s: Unable to allocate rx_desc memory\n", DEVNAME(sc)); goto err_rx_desc; } - sc->rx_desc_base = (struct em_rx_desc *)sc->rxdma.dma_vaddr; + sc->sc_rx_desc_base = (struct em_rx_desc *)sc->sc_rxdma.dma_vaddr; /* Initialize the hardware */ if ((defer = em_hardware_init(sc))) { @@ -551,9 +551,9 @@ em_attach(struct device *parent, struct device *self, void *aux) err_mac_addr: err_hw_init: - em_dma_free(sc, &sc->rxdma); + em_dma_free(sc, &sc->sc_rxdma); err_rx_desc: - em_dma_free(sc, &sc->txdma); + em_dma_free(sc, &sc->sc_txdma); err_tx_desc: err_pci: em_free_pci_resources(sc); @@ -582,13 +582,13 @@ em_start(struct ifnet *ifp) } if (sc->hw.mac_type != em_82547) { - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); } for (;;) { - if (EM_MAX_SCATTER + 1 > sc->num_tx_desc_avail) { + if (EM_MAX_SCATTER + 1 > sc->sc_num_tx_desc_avail) { ifq_set_oactive(&ifp->if_snd); break; } @@ -616,16 +616,18 @@ em_start(struct ifnet *ifp) } if (sc->hw.mac_type != em_82547) { - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); /* * Advance the Transmit Descriptor Tail (Tdt), * this tells the E1000 that this frame is * available to transmit. */ - if (post) - E1000_WRITE_REG(&sc->hw, TDT, sc->next_avail_tx_desc); + if (post) { + E1000_WRITE_REG(&sc->hw, TDT, + sc->sc_next_avail_tx_desc); + } } } @@ -685,7 +687,7 @@ em_ioctl(struct ifnet *ifp, u_long command, caddr_t data) case SIOCGIFRXR: error = if_rxr_ioctl((struct if_rxrinfo *)ifr->ifr_data, - NULL, EM_MCLBYTES, &sc->rx_ring); + NULL, EM_MCLBYTES, &sc->sc_rx_ring); break; default: @@ -727,8 +729,8 @@ em_watchdog(struct ifnet *ifp) return; } printf("%s: watchdog: cons %u prod %u free %u TDH %u TDT %u\n", - DEVNAME(sc), sc->next_tx_to_clean, - sc->next_avail_tx_desc, sc->num_tx_desc_avail, + DEVNAME(sc), sc->sc_next_tx_to_clean, + sc->sc_next_avail_tx_desc, sc->sc_num_tx_desc_avail, E1000_READ_REG(&sc->hw, TDH), E1000_READ_REG(&sc->hw, TDT)); em_init(sc); @@ -902,7 +904,7 @@ em_intr(void *arg) if (em_rxeof(sc) || ISSET(reg_icr, E1000_ICR_RXO)) { if (em_rxfill(sc)) { E1000_WRITE_REG(&sc->hw, RDT, - sc->last_rx_desc_filled); + sc->sc_last_rx_desc_filled); } } } @@ -1095,8 +1097,8 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) * of the EOP which is the only one that * no gets a DONE bit writeback. */ - first = sc->next_avail_tx_desc; - tx_buffer = &sc->tx_buffer_area[first]; + first = sc->sc_next_avail_tx_desc; + tx_buffer = &sc->sc_tx_buffer_area[first]; tx_buffer_mapped = tx_buffer; map = tx_buffer->map; @@ -1117,8 +1119,8 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) } if (sc->hw.mac_type == em_82547) { - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); } @@ -1129,7 +1131,7 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) else txd_upper = txd_lower = 0; - i = sc->next_avail_tx_desc; + i = sc->sc_next_avail_tx_desc; for (j = 0; j < map->dm_nsegs; j++) { /* If sc is 82544 and on PCI-X bus */ @@ -1142,16 +1144,16 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) map->dm_segs[j].ds_addr, map->dm_segs[j].ds_len, &desc_array); for (counter = 0; counter < array_elements; counter++) { - tx_buffer = &sc->tx_buffer_area[i]; - current_tx_desc = &sc->tx_desc_base[i]; + tx_buffer = &sc->sc_tx_buffer_area[i]; + current_tx_desc = &sc->sc_tx_desc_base[i]; current_tx_desc->buffer_addr = htole64( desc_array.descriptor[counter].address); current_tx_desc->lower.data = htole32( - (sc->txd_cmd | txd_lower | + (sc->sc_txd_cmd | txd_lower | (u_int16_t)desc_array.descriptor[counter].length)); current_tx_desc->upper.data = htole32((txd_upper)); last = i; - if (++i == sc->num_tx_desc) + if (++i == sc->sc_num_tx_desc) i = 0; tx_buffer->m_head = NULL; @@ -1159,15 +1161,15 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) txd_used++; } } else { - tx_buffer = &sc->tx_buffer_area[i]; - current_tx_desc = &sc->tx_desc_base[i]; + tx_buffer = &sc->sc_tx_buffer_area[i]; + current_tx_desc = &sc->sc_tx_desc_base[i]; current_tx_desc->buffer_addr = htole64(map->dm_segs[j].ds_addr); current_tx_desc->lower.data = htole32( - sc->txd_cmd | txd_lower | map->dm_segs[j].ds_len); + sc->sc_txd_cmd | txd_lower | map->dm_segs[j].ds_len); current_tx_desc->upper.data = htole32(txd_upper); last = i; - if (++i == sc->num_tx_desc) + if (++i == sc->sc_num_tx_desc) i = 0; tx_buffer->m_head = NULL; @@ -1175,11 +1177,11 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) } } - sc->next_avail_tx_desc = i; + sc->sc_next_avail_tx_desc = i; if (sc->pcix_82544) - atomic_sub_int(&sc->num_tx_desc_avail, txd_used); + atomic_sub_int(&sc->sc_num_tx_desc_avail, txd_used); else - atomic_sub_int(&sc->num_tx_desc_avail, map->dm_nsegs); + atomic_sub_int(&sc->sc_num_tx_desc_avail, map->dm_nsegs); #if NVLAN > 0 /* Find out if we are in VLAN mode */ @@ -1211,7 +1213,7 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) * Keep track in the first buffer which * descriptor will be written back */ - tx_buffer = &sc->tx_buffer_area[first]; + tx_buffer = &sc->sc_tx_buffer_area[first]; tx_buffer->next_eop = last; /* @@ -1220,8 +1222,8 @@ em_encap(struct em_softc *sc, struct mbuf *m_head) * available to transmit. */ if (sc->hw.mac_type == em_82547) { - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); if (sc->link_duplex == HALF_DUPLEX) em_82547_move_tail_locked(sc); @@ -1252,13 +1254,13 @@ em_82547_move_tail_locked(struct em_softc *sc) boolean_t eop = 0; hw_tdt = E1000_READ_REG(&sc->hw, TDT); - sw_tdt = sc->next_avail_tx_desc; + sw_tdt = sc->sc_next_avail_tx_desc; while (hw_tdt != sw_tdt) { - tx_desc = &sc->tx_desc_base[hw_tdt]; + tx_desc = &sc->sc_tx_desc_base[hw_tdt]; length += tx_desc->lower.flags.length; eop = tx_desc->lower.data & E1000_TXD_CMD_EOP; - if (++hw_tdt == sc->num_tx_desc) + if (++hw_tdt == sc->sc_num_tx_desc) hw_tdt = 0; if (eop) { @@ -1828,7 +1830,7 @@ em_setup_interface(struct em_softc *sc) ifp->if_watchdog = em_watchdog; ifp->if_hardmtu = sc->hw.max_frame_size - ETHER_HDR_LEN - ETHER_CRC_LEN; - IFQ_SET_MAXLEN(&ifp->if_snd, sc->num_tx_desc - 1); + IFQ_SET_MAXLEN(&ifp->if_snd, sc->sc_num_tx_desc - 1); IFQ_SET_READY(&ifp->if_snd); ifp->if_capabilities = IFCAP_VLAN_MTU; @@ -1895,13 +1897,13 @@ em_detach(struct device *self, int flags) em_free_pci_resources(sc); - if (sc->rx_desc_base != NULL) { - em_dma_free(sc, &sc->rxdma); - sc->rx_desc_base = NULL; + if (sc->sc_rx_desc_base != NULL) { + em_dma_free(sc, &sc->sc_rxdma); + sc->sc_rx_desc_base = NULL; } - if (sc->tx_desc_base != NULL) { - em_dma_free(sc, &sc->txdma); - sc->tx_desc_base = NULL; + if (sc->sc_tx_desc_base != NULL) { + em_dma_free(sc, &sc->sc_txdma); + sc->sc_tx_desc_base = NULL; } ether_ifdetach(ifp); @@ -2053,11 +2055,11 @@ em_dma_free(struct em_softc *sc, struct em_dma_alloc *dma) int em_allocate_transmit_structures(struct em_softc *sc) { - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); - if (!(sc->tx_buffer_area = mallocarray(sc->num_tx_desc, + if (!(sc->sc_tx_buffer_area = mallocarray(sc->sc_num_tx_desc, sizeof(struct em_buffer), M_DEVBUF, M_NOWAIT | M_ZERO))) { printf("%s: Unable to allocate tx_buffer memory\n", DEVNAME(sc)); @@ -2081,11 +2083,11 @@ em_setup_transmit_structures(struct em_softc *sc) if ((error = em_allocate_transmit_structures(sc)) != 0) goto fail; - bzero((void *) sc->tx_desc_base, - (sizeof(struct em_tx_desc)) * sc->num_tx_desc); + bzero((void *) sc->sc_tx_desc_base, + (sizeof(struct em_tx_desc)) * sc->sc_num_tx_desc); - tx_buffer = sc->tx_buffer_area; - for (i = 0; i < sc->num_tx_desc; i++) { + tx_buffer = sc->sc_tx_buffer_area; + for (i = 0; i < sc->sc_num_tx_desc; i++) { error = bus_dmamap_create(sc->sc_dmat, MAX_JUMBO_FRAME_SIZE, EM_MAX_SCATTER / (sc->pcix_82544 ? 2 : 1), MAX_JUMBO_FRAME_SIZE, 0, BUS_DMA_NOWAIT, &tx_buffer->map); @@ -2097,11 +2099,11 @@ em_setup_transmit_structures(struct em_softc *sc) tx_buffer++; } - sc->next_avail_tx_desc = 0; - sc->next_tx_to_clean = 0; + sc->sc_next_avail_tx_desc = 0; + sc->sc_next_tx_to_clean = 0; /* Set number of descriptors available */ - sc->num_tx_desc_avail = sc->num_tx_desc; + sc->sc_num_tx_desc_avail = sc->sc_num_tx_desc; /* Set checksum context */ sc->active_checksum_context = OFFLOAD_NONE; @@ -2127,9 +2129,9 @@ em_initialize_transmit_unit(struct em_softc *sc) INIT_DEBUGOUT("em_initialize_transmit_unit: begin"); /* Setup the Base and Length of the Tx Descriptor Ring */ - bus_addr = sc->txdma.dma_map->dm_segs[0].ds_addr; + bus_addr = sc->sc_txdma.dma_map->dm_segs[0].ds_addr; E1000_WRITE_REG(&sc->hw, TDLEN, - sc->num_tx_desc * + sc->sc_num_tx_desc * sizeof(struct em_tx_desc)); E1000_WRITE_REG(&sc->hw, TDBAH, (u_int32_t)(bus_addr >> 32)); E1000_WRITE_REG(&sc->hw, TDBAL, (u_int32_t)bus_addr); @@ -2171,7 +2173,7 @@ em_initialize_transmit_unit(struct em_softc *sc) E1000_WRITE_REG(&sc->hw, TADV, sc->tx_abs_int_delay); /* Setup Transmit Descriptor Base Settings */ - sc->txd_cmd = E1000_TXD_CMD_IFCS; + sc->sc_txd_cmd = E1000_TXD_CMD_IFCS; if (sc->hw.mac_type == em_82575 || sc->hw.mac_type == em_82580 || sc->hw.mac_type == em_i210 || sc->hw.mac_type == em_i350) { @@ -2180,7 +2182,7 @@ em_initialize_transmit_unit(struct em_softc *sc) reg_tctl |= E1000_TXDCTL_QUEUE_ENABLE; E1000_WRITE_REG(&sc->hw, TXDCTL, reg_tctl); } else if (sc->tx_int_delay > 0) - sc->txd_cmd |= E1000_TXD_CMD_IDE; + sc->sc_txd_cmd |= E1000_TXD_CMD_IDE; /* Program the Transmit Control Register */ reg_tctl = E1000_TCTL_PSP | E1000_TCTL_EN | @@ -2208,9 +2210,9 @@ em_free_transmit_structures(struct em_softc *sc) INIT_DEBUGOUT("free_transmit_structures: begin"); - if (sc->tx_buffer_area != NULL) { - tx_buffer = sc->tx_buffer_area; - for (i = 0; i < sc->num_tx_desc; i++, tx_buffer++) { + if (sc->sc_tx_buffer_area != NULL) { + tx_buffer = sc->sc_tx_buffer_area; + for (i = 0; i < sc->sc_num_tx_desc; i++, tx_buffer++) { if (tx_buffer->map != NULL && tx_buffer->map->dm_nsegs > 0) { bus_dmamap_sync(sc->sc_dmat, tx_buffer->map, @@ -2230,14 +2232,14 @@ em_free_transmit_structures(struct em_softc *sc) } } } - if (sc->tx_buffer_area != NULL) { - free(sc->tx_buffer_area, M_DEVBUF, - sc->num_tx_desc * sizeof(struct em_buffer)); - sc->tx_buffer_area = NULL; + if (sc->sc_tx_buffer_area != NULL) { + free(sc->sc_tx_buffer_area, M_DEVBUF, + sc->sc_num_tx_desc * sizeof(struct em_buffer)); + sc->sc_tx_buffer_area = NULL; } - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); } @@ -2285,9 +2287,9 @@ em_transmit_checksum_setup(struct em_softc *sc, struct mbuf *mp, /* If we reach this point, the checksum offload context * needs to be reset. */ - curr_txd = sc->next_avail_tx_desc; - tx_buffer = &sc->tx_buffer_area[curr_txd]; - TXD = (struct em_context_desc *) &sc->tx_desc_base[curr_txd]; + curr_txd = sc->sc_next_avail_tx_desc; + tx_buffer = &sc->sc_tx_buffer_area[curr_txd]; + TXD = (struct em_context_desc *) &sc->sc_tx_desc_base[curr_txd]; TXD->lower_setup.ip_fields.ipcss = ETHER_HDR_LEN; TXD->lower_setup.ip_fields.ipcso = @@ -2310,16 +2312,16 @@ em_transmit_checksum_setup(struct em_softc *sc, struct mbuf *mp, } TXD->tcp_seg_setup.data = htole32(0); - TXD->cmd_and_length = htole32(sc->txd_cmd | E1000_TXD_CMD_DEXT); + TXD->cmd_and_length = htole32(sc->sc_txd_cmd | E1000_TXD_CMD_DEXT); tx_buffer->m_head = NULL; tx_buffer->next_eop = -1; - if (++curr_txd == sc->num_tx_desc) + if (++curr_txd == sc->sc_num_tx_desc) curr_txd = 0; - atomic_dec_int(&sc->num_tx_desc_avail); - sc->next_avail_tx_desc = curr_txd; + atomic_dec_int(&sc->sc_num_tx_desc_avail); + sc->sc_next_avail_tx_desc = curr_txd; } /********************************************************************** @@ -2337,14 +2339,14 @@ em_txeof(struct em_softc *sc) struct em_tx_desc *tx_desc, *eop_desc; struct ifnet *ifp = &sc->sc_ac.ac_if; - if (sc->num_tx_desc_avail == sc->num_tx_desc) + if (sc->sc_num_tx_desc_avail == sc->sc_num_tx_desc) return; - first = sc->next_tx_to_clean; - tx_desc = &sc->tx_desc_base[first]; - tx_buffer = &sc->tx_buffer_area[first]; + first = sc->sc_next_tx_to_clean; + tx_desc = &sc->sc_tx_desc_base[first]; + tx_buffer = &sc->sc_tx_buffer_area[first]; last = tx_buffer->next_eop; - eop_desc = &sc->tx_desc_base[last]; + eop_desc = &sc->sc_tx_desc_base[last]; /* * What this does is get the index of the @@ -2352,12 +2354,12 @@ em_txeof(struct em_softc *sc) * first packet, that way we can do the * simple comparison on the inner while loop. */ - if (++last == sc->num_tx_desc) + if (++last == sc->sc_num_tx_desc) last = 0; done = last; - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD); while (eop_desc->upper.fields.status & E1000_TXD_STAT_DD) { /* We clean the range of the packet */ @@ -2381,34 +2383,34 @@ em_txeof(struct em_softc *sc) } tx_buffer->next_eop = -1; - if (++first == sc->num_tx_desc) + if (++first == sc->sc_num_tx_desc) first = 0; - tx_buffer = &sc->tx_buffer_area[first]; - tx_desc = &sc->tx_desc_base[first]; + tx_buffer = &sc->sc_tx_buffer_area[first]; + tx_desc = &sc->sc_tx_desc_base[first]; } /* See if we can continue to the next packet */ last = tx_buffer->next_eop; if (last != -1) { - eop_desc = &sc->tx_desc_base[last]; + eop_desc = &sc->sc_tx_desc_base[last]; /* Get new done point */ - if (++last == sc->num_tx_desc) + if (++last == sc->sc_num_tx_desc) last = 0; done = last; } else break; } - bus_dmamap_sync(sc->sc_dmat, sc->txdma.dma_map, - 0, sc->txdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_txdma.dma_map, + 0, sc->sc_txdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD); - sc->next_tx_to_clean = first; + sc->sc_next_tx_to_clean = first; - num_avail = atomic_add_int_nv(&sc->num_tx_desc_avail, free); + num_avail = atomic_add_int_nv(&sc->sc_num_tx_desc_avail, free); if (ifq_is_oactive(&ifp->if_snd)) ifq_restart(&ifp->if_snd); - else if (num_avail == sc->num_tx_desc) + else if (num_avail == sc->sc_num_tx_desc) ifp->if_timer = 0; } @@ -2425,8 +2427,8 @@ em_get_buf(struct em_softc *sc, int i) struct em_rx_desc *desc; int error; - pkt = &sc->rx_buffer_area[i]; - desc = &sc->rx_desc_base[i]; + pkt = &sc->sc_rx_buffer_area[i]; + desc = &sc->sc_rx_desc_base[i]; if (pkt->m_head != NULL) { printf("%s: em_get_buf: slot %d already has an mbuf\n", @@ -2474,19 +2476,19 @@ em_allocate_receive_structures(struct em_softc *sc) int i, error; struct em_buffer *rx_buffer; - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE); - if (!(sc->rx_buffer_area = mallocarray(sc->num_rx_desc, + if (!(sc->sc_rx_buffer_area = mallocarray(sc->sc_num_rx_desc, sizeof(struct em_buffer), M_DEVBUF, M_NOWAIT | M_ZERO))) { printf("%s: Unable to allocate rx_buffer memory\n", DEVNAME(sc)); return (ENOMEM); } - rx_buffer = sc->rx_buffer_area; - for (i = 0; i < sc->num_rx_desc; i++, rx_buffer++) { + rx_buffer = sc->sc_rx_buffer_area; + for (i = 0; i < sc->sc_num_rx_desc; i++, rx_buffer++) { error = bus_dmamap_create(sc->sc_dmat, EM_MCLBYTES, 1, EM_MCLBYTES, 0, BUS_DMA_NOWAIT, &rx_buffer->map); if (error != 0) { @@ -2516,18 +2518,18 @@ em_setup_receive_structures(struct em_softc *sc) struct ifnet *ifp = &sc->sc_ac.ac_if; u_int lwm; - memset(sc->rx_desc_base, 0, - sizeof(struct em_rx_desc) * sc->num_rx_desc); + memset(sc->sc_rx_desc_base, 0, + sizeof(struct em_rx_desc) * sc->sc_num_rx_desc); if (em_allocate_receive_structures(sc)) return (ENOMEM); /* Setup our descriptor pointers */ - sc->next_rx_desc_to_check = 0; - sc->last_rx_desc_filled = sc->num_rx_desc - 1; + sc->sc_next_rx_desc_to_check = 0; + sc->sc_last_rx_desc_filled = sc->sc_num_rx_desc - 1; lwm = max(4, 2 * ((ifp->if_hardmtu / MCLBYTES) + 1)); - if_rxr_init(&sc->rx_ring, lwm, sc->num_rx_desc); + if_rxr_init(&sc->sc_rx_ring, lwm, sc->sc_num_rx_desc); if (em_rxfill(sc) == 0) { printf("%s: unable to fill any rx descriptors\n", @@ -2568,8 +2570,8 @@ em_initialize_receive_unit(struct em_softc *sc) } /* Setup the Base and Length of the Rx Descriptor Ring */ - bus_addr = sc->rxdma.dma_map->dm_segs[0].ds_addr; - E1000_WRITE_REG(&sc->hw, RDLEN, sc->num_rx_desc * + bus_addr = sc->sc_rxdma.dma_map->dm_segs[0].ds_addr; + E1000_WRITE_REG(&sc->hw, RDLEN, sc->sc_num_rx_desc * sizeof(struct em_rx_desc)); E1000_WRITE_REG(&sc->hw, RDBAH, (u_int32_t)(bus_addr >> 32)); E1000_WRITE_REG(&sc->hw, RDBAL, (u_int32_t)bus_addr); @@ -2590,7 +2592,7 @@ em_initialize_receive_unit(struct em_softc *sc) if (sc->hw.mac_type == em_i210 || sc->hw.mac_type == em_i350) reg_rctl |= E1000_RCTL_SECRC; - switch (sc->rx_buffer_len) { + switch (sc->sc_rx_buffer_len) { default: case EM_RXBUFFER_2048: reg_rctl |= E1000_RCTL_SZ_2048; @@ -2637,7 +2639,7 @@ em_initialize_receive_unit(struct em_softc *sc) /* Setup the HW Rx Head and Tail Descriptor Pointers */ E1000_WRITE_REG(&sc->hw, RDH, 0); - E1000_WRITE_REG(&sc->hw, RDT, sc->last_rx_desc_filled); + E1000_WRITE_REG(&sc->hw, RDT, sc->sc_last_rx_desc_filled); } /********************************************************************* @@ -2653,15 +2655,15 @@ em_free_receive_structures(struct em_softc *sc) INIT_DEBUGOUT("free_receive_structures: begin"); - if_rxr_init(&sc->rx_ring, 0, 0); + if_rxr_init(&sc->sc_rx_ring, 0, 0); - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD | BUS_DMASYNC_POSTWRITE); - if (sc->rx_buffer_area != NULL) { - rx_buffer = sc->rx_buffer_area; - for (i = 0; i < sc->num_rx_desc; i++, rx_buffer++) { + if (sc->sc_rx_buffer_area != NULL) { + rx_buffer = sc->sc_rx_buffer_area; + for (i = 0; i < sc->sc_num_rx_desc; i++, rx_buffer++) { if (rx_buffer->m_head != NULL) { bus_dmamap_sync(sc->sc_dmat, rx_buffer->map, 0, rx_buffer->map->dm_mapsize, @@ -2673,10 +2675,10 @@ em_free_receive_structures(struct em_softc *sc) bus_dmamap_destroy(sc->sc_dmat, rx_buffer->map); } } - if (sc->rx_buffer_area != NULL) { - free(sc->rx_buffer_area, M_DEVBUF, - sc->num_rx_desc * sizeof(struct em_buffer)); - sc->rx_buffer_area = NULL; + if (sc->sc_rx_buffer_area != NULL) { + free(sc->sc_rx_buffer_area, M_DEVBUF, + sc->sc_num_rx_desc * sizeof(struct em_buffer)); + sc->sc_rx_buffer_area = NULL; } if (sc->fmp != NULL) { @@ -2693,28 +2695,28 @@ em_rxfill(struct em_softc *sc) int post = 0; int i; - i = sc->last_rx_desc_filled; + i = sc->sc_last_rx_desc_filled; - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTWRITE); - for (slots = if_rxr_get(&sc->rx_ring, sc->num_rx_desc); + for (slots = if_rxr_get(&sc->sc_rx_ring, sc->sc_num_rx_desc); slots > 0; slots--) { - if (++i == sc->num_rx_desc) + if (++i == sc->sc_num_rx_desc) i = 0; if (em_get_buf(sc, i) != 0) break; - sc->last_rx_desc_filled = i; + sc->sc_last_rx_desc_filled = i; post = 1; } - if_rxr_put(&sc->rx_ring, slots); + if_rxr_put(&sc->sc_rx_ring, slots); - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_PREWRITE); return (post); @@ -2743,20 +2745,20 @@ em_rxeof(struct em_softc *sc) struct em_buffer *pkt; u_int8_t status; - if (if_rxr_inuse(&sc->rx_ring) == 0) + if (if_rxr_inuse(&sc->sc_rx_ring) == 0) return (0); - i = sc->next_rx_desc_to_check; + i = sc->sc_next_rx_desc_to_check; - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_POSTREAD); do { m = NULL; - desc = &sc->rx_desc_base[i]; - pkt = &sc->rx_buffer_area[i]; + desc = &sc->sc_rx_desc_base[i]; + pkt = &sc->sc_rx_buffer_area[i]; status = desc->status; if (!ISSET(status, E1000_RXD_STAT_DD)) @@ -2772,11 +2774,11 @@ em_rxeof(struct em_softc *sc) if (m == NULL) { panic("em_rxeof: NULL mbuf in slot %d " "(nrx %d, filled %d)", i, - if_rxr_inuse(&sc->rx_ring), - sc->last_rx_desc_filled); + if_rxr_inuse(&sc->sc_rx_ring), + sc->sc_last_rx_desc_filled); } - if_rxr_put(&sc->rx_ring, 1); + if_rxr_put(&sc->sc_rx_ring, 1); rv = 1; accept_frame = 1; @@ -2872,15 +2874,15 @@ em_rxeof(struct em_softc *sc) } /* Advance our pointers to the next descriptor. */ - if (++i == sc->num_rx_desc) + if (++i == sc->sc_num_rx_desc) i = 0; - } while (if_rxr_inuse(&sc->rx_ring) > 0); + } while (if_rxr_inuse(&sc->sc_rx_ring) > 0); - bus_dmamap_sync(sc->sc_dmat, sc->rxdma.dma_map, - 0, sc->rxdma.dma_map->dm_mapsize, + bus_dmamap_sync(sc->sc_dmat, sc->sc_rxdma.dma_map, + 0, sc->sc_rxdma.dma_map->dm_mapsize, BUS_DMASYNC_PREREAD); - sc->next_rx_desc_to_check = i; + sc->sc_next_rx_desc_to_check = i; if_input(ifp, &ml); diff --git a/sys/dev/pci/if_em.h b/sys/dev/pci/if_em.h index bc8203f2e1d..74a95338f91 100644 --- a/sys/dev/pci/if_em.h +++ b/sys/dev/pci/if_em.h @@ -32,7 +32,7 @@ POSSIBILITY OF SUCH DAMAGE. ***************************************************************************/ /* $FreeBSD: if_em.h,v 1.26 2004/09/01 23:22:41 pdeuskar Exp $ */ -/* $OpenBSD: if_em.h,v 1.67 2016/01/07 06:25:35 dlg Exp $ */ +/* $OpenBSD: if_em.h,v 1.68 2016/01/07 07:03:55 dlg Exp $ */ #ifndef _EM_H_DEFINED_ #define _EM_H_DEFINED_ @@ -347,14 +347,14 @@ struct em_softc { * The index of the next available descriptor is next_avail_tx_desc. * The number of remaining tx_desc is num_tx_desc_avail. */ - struct em_dma_alloc txdma; /* bus_dma glue for tx desc */ - struct em_tx_desc *tx_desc_base; - u_int32_t next_avail_tx_desc; - u_int32_t next_tx_to_clean; - volatile u_int32_t num_tx_desc_avail; - u_int32_t num_tx_desc; - u_int32_t txd_cmd; - struct em_buffer *tx_buffer_area; + struct em_dma_alloc sc_txdma; /* bus_dma glue for tx desc */ + struct em_tx_desc *sc_tx_desc_base; + u_int32_t sc_next_avail_tx_desc; + u_int32_t sc_next_tx_to_clean; + volatile u_int32_t sc_num_tx_desc_avail; + u_int32_t sc_num_tx_desc; + u_int32_t sc_txd_cmd; + struct em_buffer *sc_tx_buffer_area; /* * Receive definitions @@ -364,14 +364,14 @@ struct em_softc { * (at rx_buffer_area). * The next pair to check on receive is at offset next_rx_desc_to_check */ - struct em_dma_alloc rxdma; /* bus_dma glue for rx desc */ - struct em_rx_desc *rx_desc_base; - struct if_rxring rx_ring; - u_int32_t next_rx_desc_to_check; - u_int32_t last_rx_desc_filled; - u_int32_t rx_buffer_len; - u_int16_t num_rx_desc; - struct em_buffer *rx_buffer_area; + struct em_dma_alloc sc_rxdma; /* bus_dma glue for rx desc */ + struct em_rx_desc *sc_rx_desc_base; + struct if_rxring sc_rx_ring; + u_int32_t sc_next_rx_desc_to_check; + u_int32_t sc_last_rx_desc_filled; + u_int32_t sc_rx_buffer_len; + u_int16_t sc_num_rx_desc; + struct em_buffer *sc_rx_buffer_area; /* * First/last mbuf pointers, for |