Mechanically convert ps3 if_glc(4) to IfAPI

Sponsored by:	Juniper Networks, Inc.
Differential Revision: https://reviews.freebsd.org/D37792
This commit is contained in:
Justin Hibbits 2022-03-01 09:52:25 -06:00
parent 44e65355a3
commit 3df047e3f3
2 changed files with 52 additions and 54 deletions

View File

@ -64,8 +64,8 @@
static int glc_probe(device_t); static int glc_probe(device_t);
static int glc_attach(device_t); static int glc_attach(device_t);
static void glc_init(void *xsc); static void glc_init(void *xsc);
static void glc_start(struct ifnet *ifp); static void glc_start(if_t ifp);
static int glc_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data); static int glc_ioctl(if_t ifp, u_long cmd, caddr_t data);
static void glc_set_multicast(struct glc_softc *sc); static void glc_set_multicast(struct glc_softc *sc);
static int glc_add_rxbuf(struct glc_softc *sc, int idx); static int glc_add_rxbuf(struct glc_softc *sc, int idx);
static int glc_add_rxbuf_dma(struct glc_softc *sc, int idx); static int glc_add_rxbuf_dma(struct glc_softc *sc, int idx);
@ -74,8 +74,8 @@ static int glc_encap(struct glc_softc *sc, struct mbuf **m_head,
static int glc_intr_filter(void *xsc); static int glc_intr_filter(void *xsc);
static void glc_intr(void *xsc); static void glc_intr(void *xsc);
static void glc_tick(void *xsc); static void glc_tick(void *xsc);
static void glc_media_status(struct ifnet *ifp, struct ifmediareq *ifmr); static void glc_media_status(if_t ifp, struct ifmediareq *ifmr);
static int glc_media_change(struct ifnet *ifp); static int glc_media_change(if_t ifp);
static MALLOC_DEFINE(M_GLC, "gelic", "PS3 GELIC ethernet"); static MALLOC_DEFINE(M_GLC, "gelic", "PS3 GELIC ethernet");
@ -145,7 +145,7 @@ glc_attach(device_t dev)
lv1_net_stop_rx_dma(sc->sc_bus, sc->sc_dev, 0); lv1_net_stop_rx_dma(sc->sc_bus, sc->sc_dev, 0);
sc->sc_ifp = if_alloc(IFT_ETHER); sc->sc_ifp = if_alloc(IFT_ETHER);
sc->sc_ifp->if_softc = sc; if_setsoftc(sc->sc_ifp, sc);
/* /*
* Get MAC address and VLAN id * Get MAC address and VLAN id
@ -253,14 +253,14 @@ glc_attach(device_t dev)
*/ */
if_initname(sc->sc_ifp, device_get_name(dev), device_get_unit(dev)); if_initname(sc->sc_ifp, device_get_name(dev), device_get_unit(dev));
sc->sc_ifp->if_mtu = ETHERMTU; if_setmtu(sc->sc_ifp, ETHERMTU);
sc->sc_ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; if_setflags(sc->sc_ifp, IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST);
sc->sc_ifp->if_hwassist = CSUM_TCP | CSUM_UDP; if_sethwassist(sc->sc_ifp, CSUM_TCP | CSUM_UDP);
sc->sc_ifp->if_capabilities = IFCAP_HWCSUM | IFCAP_RXCSUM; if_setcapabilities(sc->sc_ifp, IFCAP_HWCSUM | IFCAP_RXCSUM);
sc->sc_ifp->if_capenable = IFCAP_HWCSUM | IFCAP_RXCSUM; if_setcapenable(sc->sc_ifp, IFCAP_HWCSUM | IFCAP_RXCSUM);
sc->sc_ifp->if_start = glc_start; if_setstartfn(sc->sc_ifp, glc_start);
sc->sc_ifp->if_ioctl = glc_ioctl; if_setioctlfn(sc->sc_ifp, glc_ioctl);
sc->sc_ifp->if_init = glc_init; if_setinitfn(sc->sc_ifp, glc_init);
ifmedia_init(&sc->sc_media, IFM_IMASK, glc_media_change, ifmedia_init(&sc->sc_media, IFM_IMASK, glc_media_change,
glc_media_status); glc_media_status);
@ -272,12 +272,11 @@ glc_attach(device_t dev)
ifmedia_add(&sc->sc_media, IFM_ETHER | IFM_AUTO, 0, NULL); ifmedia_add(&sc->sc_media, IFM_ETHER | IFM_AUTO, 0, NULL);
ifmedia_set(&sc->sc_media, IFM_ETHER | IFM_AUTO); ifmedia_set(&sc->sc_media, IFM_ETHER | IFM_AUTO);
IFQ_SET_MAXLEN(&sc->sc_ifp->if_snd, GLC_MAX_TX_PACKETS); if_setsendqlen(sc->sc_ifp, GLC_MAX_TX_PACKETS);
sc->sc_ifp->if_snd.ifq_drv_maxlen = GLC_MAX_TX_PACKETS; if_setsendqready(sc->sc_ifp);
IFQ_SET_READY(&sc->sc_ifp->if_snd);
ether_ifattach(sc->sc_ifp, sc->sc_enaddr); ether_ifattach(sc->sc_ifp, sc->sc_enaddr);
sc->sc_ifp->if_hwassist = 0; if_sethwassist(sc->sc_ifp, 0);
return (0); return (0);
@ -339,9 +338,9 @@ glc_init_locked(struct glc_softc *sc)
device_printf(sc->sc_self, device_printf(sc->sc_self,
"lv1_net_start_rx_dma error: %d\n", error); "lv1_net_start_rx_dma error: %d\n", error);
sc->sc_ifp->if_drv_flags |= IFF_DRV_RUNNING; if_setdrvflagbits(sc->sc_ifp, IFF_DRV_RUNNING, 0);
sc->sc_ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; if_setdrvflagbits(sc->sc_ifp, 0, IFF_DRV_OACTIVE);
sc->sc_ifpflags = sc->sc_ifp->if_flags; sc->sc_ifpflags = if_getflags(sc->sc_ifp);
sc->sc_wdog_timer = 0; sc->sc_wdog_timer = 0;
callout_reset(&sc->sc_tick_ch, hz, glc_tick, sc); callout_reset(&sc->sc_tick_ch, hz, glc_tick, sc);
@ -395,9 +394,9 @@ glc_tick(void *xsc)
} }
static void static void
glc_start_locked(struct ifnet *ifp) glc_start_locked(if_t ifp)
{ {
struct glc_softc *sc = ifp->if_softc; struct glc_softc *sc = if_getsoftc(ifp);
bus_addr_t first, pktdesc; bus_addr_t first, pktdesc;
int kickstart = 0; int kickstart = 0;
int error; int error;
@ -406,15 +405,15 @@ glc_start_locked(struct ifnet *ifp)
mtx_assert(&sc->sc_mtx, MA_OWNED); mtx_assert(&sc->sc_mtx, MA_OWNED);
first = 0; first = 0;
if ((ifp->if_drv_flags & (IFF_DRV_RUNNING | IFF_DRV_OACTIVE)) != if ((if_getdrvflags(ifp) & (IFF_DRV_RUNNING | IFF_DRV_OACTIVE)) !=
IFF_DRV_RUNNING) IFF_DRV_RUNNING)
return; return;
if (STAILQ_EMPTY(&sc->sc_txdirtyq)) if (STAILQ_EMPTY(&sc->sc_txdirtyq))
kickstart = 1; kickstart = 1;
while (!IFQ_DRV_IS_EMPTY(&ifp->if_snd)) { while (!if_sendq_empty(ifp)) {
IFQ_DRV_DEQUEUE(&ifp->if_snd, mb_head); mb_head = if_dequeue(ifp);
if (mb_head == NULL) if (mb_head == NULL)
break; break;
@ -422,8 +421,8 @@ glc_start_locked(struct ifnet *ifp)
/* Check if the ring buffer is full */ /* Check if the ring buffer is full */
if (sc->bsy_txdma_slots > 125) { if (sc->bsy_txdma_slots > 125) {
/* Put the packet back and stop */ /* Put the packet back and stop */
ifp->if_drv_flags |= IFF_DRV_OACTIVE; if_setdrvflagbits(ifp, IFF_DRV_OACTIVE, 0);
IFQ_DRV_PREPEND(&ifp->if_snd, mb_head); if_sendq_prepend(ifp, mb_head);
break; break;
} }
@ -433,7 +432,7 @@ glc_start_locked(struct ifnet *ifp)
mb_head = ether_vlanencap(mb_head, sc->sc_tx_vlan); mb_head = ether_vlanencap(mb_head, sc->sc_tx_vlan);
if (glc_encap(sc, &mb_head, &pktdesc)) { if (glc_encap(sc, &mb_head, &pktdesc)) {
ifp->if_drv_flags |= IFF_DRV_OACTIVE; if_setdrvflagbits(ifp, IFF_DRV_OACTIVE, 0);
break; break;
} }
@ -451,9 +450,9 @@ glc_start_locked(struct ifnet *ifp)
} }
static void static void
glc_start(struct ifnet *ifp) glc_start(if_t ifp)
{ {
struct glc_softc *sc = ifp->if_softc; struct glc_softc *sc = if_getsoftc(ifp);
mtx_lock(&sc->sc_mtx); mtx_lock(&sc->sc_mtx);
glc_start_locked(ifp); glc_start_locked(ifp);
@ -461,26 +460,26 @@ glc_start(struct ifnet *ifp)
} }
static int static int
glc_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) glc_ioctl(if_t ifp, u_long cmd, caddr_t data)
{ {
struct glc_softc *sc = ifp->if_softc; struct glc_softc *sc = if_getsoftc(ifp);
struct ifreq *ifr = (struct ifreq *)data; struct ifreq *ifr = (struct ifreq *)data;
int err = 0; int err = 0;
switch (cmd) { switch (cmd) {
case SIOCSIFFLAGS: case SIOCSIFFLAGS:
mtx_lock(&sc->sc_mtx); mtx_lock(&sc->sc_mtx);
if ((ifp->if_flags & IFF_UP) != 0) { if ((if_getflags(ifp) & IFF_UP) != 0) {
if ((ifp->if_drv_flags & IFF_DRV_RUNNING) != 0 && if ((if_getdrvflags(ifp) & IFF_DRV_RUNNING) != 0 &&
((ifp->if_flags ^ sc->sc_ifpflags) & ((if_getflags(ifp) ^ sc->sc_ifpflags) &
(IFF_ALLMULTI | IFF_PROMISC)) != 0) (IFF_ALLMULTI | IFF_PROMISC)) != 0)
glc_set_multicast(sc); glc_set_multicast(sc);
else else
glc_init_locked(sc); glc_init_locked(sc);
} }
else if ((ifp->if_drv_flags & IFF_DRV_RUNNING) != 0) else if ((if_getdrvflags(ifp) & IFF_DRV_RUNNING) != 0)
glc_stop(sc); glc_stop(sc);
sc->sc_ifpflags = ifp->if_flags; sc->sc_ifpflags = if_getflags(ifp);
mtx_unlock(&sc->sc_mtx); mtx_unlock(&sc->sc_mtx);
break; break;
case SIOCADDMULTI: case SIOCADDMULTI:
@ -525,7 +524,7 @@ glc_add_maddr(void *arg, struct sockaddr_dl *sdl, u_int cnt)
static void static void
glc_set_multicast(struct glc_softc *sc) glc_set_multicast(struct glc_softc *sc)
{ {
struct ifnet *ifp = sc->sc_ifp; if_t ifp = sc->sc_ifp;
int naddrs; int naddrs;
/* Clear multicast filter */ /* Clear multicast filter */
@ -535,7 +534,7 @@ glc_set_multicast(struct glc_softc *sc)
lv1_net_add_multicast_address(sc->sc_bus, sc->sc_dev, lv1_net_add_multicast_address(sc->sc_bus, sc->sc_dev,
0xffffffffffffL, 0); 0xffffffffffffL, 0);
if ((ifp->if_flags & IFF_ALLMULTI) != 0) { if ((if_getflags(ifp) & IFF_ALLMULTI) != 0) {
lv1_net_add_multicast_address(sc->sc_bus, sc->sc_dev, 0, 1); lv1_net_add_multicast_address(sc->sc_bus, sc->sc_dev, 0, 1);
} else { } else {
naddrs = if_foreach_llmaddr(ifp, glc_add_maddr, sc); naddrs = if_foreach_llmaddr(ifp, glc_add_maddr, sc);
@ -711,7 +710,7 @@ glc_rxintr(struct glc_softc *sc)
{ {
int i, restart_rxdma, error; int i, restart_rxdma, error;
struct mbuf *m; struct mbuf *m;
struct ifnet *ifp = sc->sc_ifp; if_t ifp = sc->sc_ifp;
bus_dmamap_sync(sc->sc_dmadesc_tag, sc->sc_rxdmadesc_map, bus_dmamap_sync(sc->sc_dmadesc_tag, sc->sc_rxdmadesc_map,
BUS_DMASYNC_POSTREAD); BUS_DMASYNC_POSTREAD);
@ -760,7 +759,7 @@ glc_rxintr(struct glc_softc *sc)
m_adj(m, 2); m_adj(m, 2);
mtx_unlock(&sc->sc_mtx); mtx_unlock(&sc->sc_mtx);
(*ifp->if_input)(ifp, m); if_input(ifp, m);
mtx_lock(&sc->sc_mtx); mtx_lock(&sc->sc_mtx);
requeue: requeue:
@ -782,7 +781,7 @@ glc_rxintr(struct glc_softc *sc)
static void static void
glc_txintr(struct glc_softc *sc) glc_txintr(struct glc_softc *sc)
{ {
struct ifnet *ifp = sc->sc_ifp; if_t ifp = sc->sc_ifp;
struct glc_txsoft *txs; struct glc_txsoft *txs;
int progress = 0, kickstart = 0, error; int progress = 0, kickstart = 0, error;
@ -840,11 +839,11 @@ glc_txintr(struct glc_softc *sc)
* We freed some descriptors, so reset IFF_DRV_OACTIVE * We freed some descriptors, so reset IFF_DRV_OACTIVE
* and restart. * and restart.
*/ */
ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; if_setdrvflagbits(ifp, 0, IFF_DRV_OACTIVE);
sc->sc_wdog_timer = STAILQ_EMPTY(&sc->sc_txdirtyq) ? 0 : 5; sc->sc_wdog_timer = STAILQ_EMPTY(&sc->sc_txdirtyq) ? 0 : 5;
if ((ifp->if_drv_flags & IFF_DRV_RUNNING) && if ((if_getdrvflags(ifp) & IFF_DRV_RUNNING) &&
!IFQ_DRV_IS_EMPTY(&ifp->if_snd)) !if_sendq_empty(ifp))
glc_start_locked(ifp); glc_start_locked(ifp);
} }
} }
@ -852,7 +851,7 @@ glc_txintr(struct glc_softc *sc)
static int static int
glc_intr_filter(void *xsc) glc_intr_filter(void *xsc)
{ {
struct glc_softc *sc = xsc; struct glc_softc *sc = xsc;
powerpc_sync(); powerpc_sync();
atomic_set_64(&sc->sc_interrupt_status, *sc->sc_hwirq_status); atomic_set_64(&sc->sc_interrupt_status, *sc->sc_hwirq_status);
@ -862,7 +861,7 @@ glc_intr_filter(void *xsc)
static void static void
glc_intr(void *xsc) glc_intr(void *xsc)
{ {
struct glc_softc *sc = xsc; struct glc_softc *sc = xsc;
uint64_t status, linkstat, junk; uint64_t status, linkstat, junk;
mtx_lock(&sc->sc_mtx); mtx_lock(&sc->sc_mtx);
@ -886,17 +885,16 @@ glc_intr(void *xsc)
linkstat = (linkstat & GELIC_LINK_UP) ? linkstat = (linkstat & GELIC_LINK_UP) ?
LINK_STATE_UP : LINK_STATE_DOWN; LINK_STATE_UP : LINK_STATE_DOWN;
if (linkstat != sc->sc_ifp->if_link_state) if_link_state_change(sc->sc_ifp, linkstat);
if_link_state_change(sc->sc_ifp, linkstat);
} }
mtx_unlock(&sc->sc_mtx); mtx_unlock(&sc->sc_mtx);
} }
static void static void
glc_media_status(struct ifnet *ifp, struct ifmediareq *ifmr) glc_media_status(if_t ifp, struct ifmediareq *ifmr)
{ {
struct glc_softc *sc = ifp->if_softc; struct glc_softc *sc = if_getsoftc(ifp);
uint64_t status, junk; uint64_t status, junk;
ifmr->ifm_status = IFM_AVALID; ifmr->ifm_status = IFM_AVALID;
@ -922,9 +920,9 @@ glc_media_status(struct ifnet *ifp, struct ifmediareq *ifmr)
} }
static int static int
glc_media_change(struct ifnet *ifp) glc_media_change(if_t ifp)
{ {
struct glc_softc *sc = ifp->if_softc; struct glc_softc *sc = if_getsoftc(ifp);
uint64_t mode, junk; uint64_t mode, junk;
int result; int result;

View File

@ -65,7 +65,7 @@ struct glc_rxsoft {
}; };
struct glc_softc { struct glc_softc {
struct ifnet *sc_ifp; if_t sc_ifp;
device_t sc_self; device_t sc_self;
struct mtx sc_mtx; struct mtx sc_mtx;
u_char sc_enaddr[ETHER_ADDR_LEN]; u_char sc_enaddr[ETHER_ADDR_LEN];