summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2016-01-07 07:03:56 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2016-01-07 07:03:56 +0000
commit1e0be319db43d0b607b648088b1c6919190c91f0 (patch)
tree7c76d70c405ef06761acdc935e4dd5a435ec1d18 /sys/dev
parentef85dd7e175b7b4a50e4f9b6176fb758961ea96a (diff)
prefix the rx and tx ring softc members with sc_
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/pci/if_em.c308
-rw-r--r--sys/dev/pci/if_em.h34
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