diff options
author | sam <sam@FreeBSD.org> | 2002-11-14 23:54:55 +0000 |
---|---|---|
committer | sam <sam@FreeBSD.org> | 2002-11-14 23:54:55 +0000 |
commit | 14c32b5f40c5ee3bd5649c3737f359f7e65e6944 (patch) | |
tree | 84eb7252cc6a518796c6bf88903ed6e2d12e7b91 /sys/dev/gx | |
parent | 10eb947d277840d02ef35d6c6303b64329d53806 (diff) | |
download | FreeBSD-src-14c32b5f40c5ee3bd5649c3737f359f7e65e6944.zip FreeBSD-src-14c32b5f40c5ee3bd5649c3737f359f7e65e6944.tar.gz |
network interface driver changes:
o don't strip the Ethernet header from inbound packets; pass packets
up the stack intact (required significant changes to some drivers)
o reference common definitions in net/ethernet.h (e.g. ETHER_ALIGN)
o track ether_ifattach/ether_ifdetach API changes
o track bpf changes (use BPF_TAP and BPF_MTAP)
o track vlan changes (ifnet capabilities, revised processing scheme, etc.)
o use if_input to pass packets "up"
o call ether_ioctl for default handling of ioctls
Reviewed by: many
Approved by: re
Diffstat (limited to 'sys/dev/gx')
-rw-r--r-- | sys/dev/gx/if_gx.c | 41 | ||||
-rw-r--r-- | sys/dev/gx/if_gxvar.h | 2 |
2 files changed, 13 insertions, 30 deletions
diff --git a/sys/dev/gx/if_gx.c b/sys/dev/gx/if_gx.c index e6e00b9..8d59cd6 100644 --- a/sys/dev/gx/if_gx.c +++ b/sys/dev/gx/if_gx.c @@ -348,6 +348,7 @@ gx_attach(device_t dev) ifp->if_init = gx_init; ifp->if_mtu = ETHERMTU; ifp->if_snd.ifq_maxlen = GX_TX_RING_CNT - 1; + ifp->if_capabilities |= IFCAP_VLAN_HWTAGGING; /* see if we can enable hardware checksumming */ if (gx->gx_vflags & GXF_CSUM) { @@ -382,7 +383,7 @@ gx_attach(device_t dev) /* * Call MI attach routines. */ - ether_ifattach(ifp, ETHER_BPF_SUPPORTED); + ether_ifattach(ifp, gx->arpcom.ac_enaddr); GX_UNLOCK(gx); splx(s); @@ -611,7 +612,7 @@ gx_detach(device_t dev) ifp = &gx->arpcom.ac_if; GX_LOCK(gx); - ether_ifdetach(ifp, ETHER_BPF_SUPPORTED); + ether_ifdetach(ifp); gx_reset(gx); gx_stop(gx); ifmedia_removeall(&gx->gx_media); @@ -917,10 +918,6 @@ gx_ioctl(struct ifnet *ifp, u_long command, caddr_t data) GX_LOCK(gx); switch (command) { - case SIOCSIFADDR: - case SIOCGIFADDR: - error = ether_ioctl(ifp, command, data); - break; case SIOCSIFMTU: if (ifr->ifr_mtu > GX_MAX_MTU) { error = EINVAL; @@ -971,7 +968,7 @@ gx_ioctl(struct ifnet *ifp, u_long command, caddr_t data) } break; default: - error = EINVAL; + error = ether_ioctl(ifp, command, data); break; } @@ -1220,7 +1217,6 @@ gx_setmulti(struct gx_softc *gx) static void gx_rxeof(struct gx_softc *gx) { - struct ether_header *eh; struct gx_rx_desc *rx; struct ifnet *ifp; int idx, staterr, len; @@ -1286,12 +1282,8 @@ gx_rxeof(struct gx_softc *gx) } ifp->if_ipackets++; - eh = mtod(m, struct ether_header *); m->m_pkthdr.rcvif = ifp; - /* Remove header from mbuf and pass it on. */ - m_adj(m, sizeof(struct ether_header)); - #define IP_CSMASK (GX_RXSTAT_IGNORE_CSUM | GX_RXSTAT_HAS_IP_CSUM) #define TCP_CSMASK \ (GX_RXSTAT_IGNORE_CSUM | GX_RXSTAT_HAS_TCP_CSUM | GX_RXERR_TCP_CSUM) @@ -1315,14 +1307,13 @@ gx_rxeof(struct gx_softc *gx) } } /* - * If we received a packet with a vlan tag, pass it - * to vlan_input() instead of ether_input(). + * If we received a packet with a vlan tag, + * mark the packet before it's passed up. */ if (staterr & GX_RXSTAT_VLAN_PKT) { - VLAN_INPUT_TAG(eh, m, rx->rx_special); - continue; + VLAN_INPUT_TAG(ifp, m, rx->rx_special, continue); } - ether_input(ifp, eh, m); + (*ifp->if_input)(ifp, m); continue; ierror: @@ -1471,12 +1462,7 @@ gx_encap(struct gx_softc *gx, struct mbuf *m_head) struct gx_tx_desc_ctx *tctx; struct mbuf *m; int idx, cnt, csumopts, txcontext; - struct ifvlan *ifv = NULL; - - if ((m_head->m_flags & (M_PROTO1|M_PKTHDR)) == (M_PROTO1|M_PKTHDR) && - m_head->m_pkthdr.rcvif != NULL && - m_head->m_pkthdr.rcvif->if_type == IFT_L2VLAN) - ifv = m_head->m_pkthdr.rcvif->if_softc; + struct m_tag *mtag; cnt = gx->gx_txcnt; idx = gx->gx_tx_tail_idx; @@ -1526,7 +1512,6 @@ gx_encap(struct gx_softc *gx, struct mbuf *m_head) cnt++; } context_done: - /* * Start packing the mbufs in this chain into the transmit * descriptors. Stop when we run out of descriptors or hit @@ -1562,9 +1547,10 @@ printf("overflow(2): %d, %d\n", cnt, GX_TX_RING_CNT); if (tx != NULL) { tx->tx_command |= GX_TXTCP_REPORT_STATUS | GX_TXTCP_INT_DELAY | GX_TXTCP_ETHER_CRC | GX_TXTCP_END_OF_PKT; - if (ifv != NULL) { + mtag = VLAN_OUTPUT_TAG(&gx->arpcom.ac_if, m); + if (mtag != NULL) { tx->tx_command |= GX_TXTCP_VLAN_ENABLE; - tx->tx_vlan = ifv->ifv_tag; + tx->tx_vlan = VLAN_TAG_VALUE(mtag); } gx->gx_txcnt = cnt; gx->gx_tx_tail_idx = idx; @@ -1613,8 +1599,7 @@ gx_start(struct ifnet *ifp) * If there's a BPF listener, bounce a copy of this frame * to him. */ - if (ifp->if_bpf) - bpf_mtap(ifp, m_head); + BPF_MTAP(ifp, m_head); /* * Set a timeout in case the chip goes out to lunch. diff --git a/sys/dev/gx/if_gxvar.h b/sys/dev/gx/if_gxvar.h index c70aa0c..8570a50 100644 --- a/sys/dev/gx/if_gxvar.h +++ b/sys/dev/gx/if_gxvar.h @@ -49,8 +49,6 @@ struct mtx { int filler; }; #define PCIM_CMD_MWIEN 0x0010 #endif -#define ETHER_ALIGN 2 - /* CSR_WRITE_8 assumes the register is in low/high order */ #define CSR_WRITE_8(gx, reg, val) do { \ bus_space_write_4((gx)->gx_btag, (gx)->gx_bhandle, \ |