From nobody Mon Feb 06 17:54:18 2023 X-Original-To: dev-commits-src-main@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4P9YmV72Szz3n0dY; Mon, 6 Feb 2023 17:54:18 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4P9YmV5Gxtz4YGy; Mon, 6 Feb 2023 17:54:18 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1675706058; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=13kMDkWSqLGmXRPRLfzZQDXJCzcs8VTr8F7kRNQQuo4=; b=J7JVDozjFbMzLHYA7bR5Yv6O6pCjq6HdRTJqV6OTucnx99DqH01vU/Cyw8U1Nc933ansPN bWjr93x2zC1T7w4TwUrk3Y5JjLNJXQFW3/ztLwFbDgTSi+uwodBLP9E2CaCmePsmkMhQLU I58HWR3twWodywa0JGTCZuAxn3gRga+7uflLOyMImTp+4fxcAFqdPEoDARr6f94HymZpUH cr7BnFCIOmVeaYBfWnQfJbkJEYBgV7smlbhCOiTUi9XM4lLNttWsfbvNI8k3tHUtBNyrT5 PkYi9sQltnDyIIadcU6TdjWA+1ab7P3la3IeHDro244aRYO/9M3Hn6cBI9ApPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1675706058; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=13kMDkWSqLGmXRPRLfzZQDXJCzcs8VTr8F7kRNQQuo4=; b=QIzlXBVbh3281z5a0ZZOheEJlhStgYtjO+PHYpkpJduPgiRwmsyuMPidZHjNBZQabFISbA 9IUHTifqOhWSPEVYwdCL288brILeK9BoixPAzRQ/y8mAnUO0Jpv+Abm8/v/R31ug7O5ddQ CYzEJiCzbld/bC831Wt4dP37Fbufr0qK4ePMr9F378aTvm0y1/1z0veaOPz0NsFdi7eXAb QLjaepQfiTzYcMioANFYjLNcm5cOvR4uc3qyjmapbq33wXvSE4sC78NI1ix7k1BF4VUmRW YMZLb+ktsUbqwhwQN0j8hOAeSIxxzlT7N9uZhx/+LWCHCIxp8nVyTJD4WZg9Yg== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1675706058; a=rsa-sha256; cv=none; b=JC1LjIIKxCpIMccVqUEw0Of5MgaXIditFyYpbe9RJKbzn0JlN5xEWJYnDT1uAQbSs+7+gE UuXKPzKEZtBU8a1cXJflQ7n4etUuTBe/zQamd9OlfV2PL8qM+91CTthTgzRHhvv+E7mmF4 TVAiWV96cs0LXl/+hRVN6Q77dnr3nPQhlZ+k+Y9aT3tvUkx6tNLNhT8/8nAlu2MszhH0ot 9QrDOVJlPQ+iS54x5D1RJU2HiwIsQdsfT7Wk3WLdrcQLFY6vI85qFXB7smMvB3BjUGpI+H cgtL/+2KRQ0aWkY1kAk5N1xDdjGYAkOP1t9At9AUN7almp83F3PYNUtcMN4JhA== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4P9YmV4KJNzk6P; Mon, 6 Feb 2023 17:54:18 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 316HsIo0074745; Mon, 6 Feb 2023 17:54:18 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 316HsIO3074744; Mon, 6 Feb 2023 17:54:18 GMT (envelope-from git) Date: Mon, 6 Feb 2023 17:54:18 GMT Message-Id: <202302061754.316HsIO3074744@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Justin Hibbits Subject: git: 0292389aca30 - main - Mechanically convert bce(4) to IfAPI List-Id: Commit messages for the main branch of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-main List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-main@freebsd.org X-BeenThere: dev-commits-src-main@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: jhibbits X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 0292389aca300090c674c85616084db079d8b200 Auto-Submitted: auto-generated X-ThisMailContainsUnwantedMimeParts: N The branch main has been updated by jhibbits: URL: https://cgit.FreeBSD.org/src/commit/?id=0292389aca300090c674c85616084db079d8b200 commit 0292389aca300090c674c85616084db079d8b200 Author: Justin Hibbits AuthorDate: 2022-08-19 19:15:44 +0000 Commit: Justin Hibbits CommitDate: 2023-02-06 17:32:11 +0000 Mechanically convert bce(4) to IfAPI Sponsored by: Juniper Networks, Inc. Differential Revision: https://reviews.freebsd.org/D37841 --- sys/dev/bce/if_bce.c | 229 ++++++++++++++++++++++++------------------------ sys/dev/bce/if_bcereg.h | 2 +- 2 files changed, 115 insertions(+), 116 deletions(-) diff --git a/sys/dev/bce/if_bce.c b/sys/dev/bce/if_bce.c index 86b64db34410..9aad4ba54671 100644 --- a/sys/dev/bce/if_bce.c +++ b/sys/dev/bce/if_bce.c @@ -453,14 +453,14 @@ static void bce_free_pg_chain (struct bce_softc *); static struct mbuf *bce_tso_setup (struct bce_softc *, struct mbuf **, u16 *); static int bce_tx_encap (struct bce_softc *, struct mbuf **); -static void bce_start_locked (struct ifnet *); -static void bce_start (struct ifnet *); -static int bce_ioctl (struct ifnet *, u_long, caddr_t); -static uint64_t bce_get_counter (struct ifnet *, ift_counter); +static void bce_start_locked (if_t); +static void bce_start (if_t); +static int bce_ioctl (if_t, u_long, caddr_t); +static uint64_t bce_get_counter (if_t, ift_counter); static void bce_watchdog (struct bce_softc *); -static int bce_ifmedia_upd (struct ifnet *); -static int bce_ifmedia_upd_locked (struct ifnet *); -static void bce_ifmedia_sts (struct ifnet *, struct ifmediareq *); +static int bce_ifmedia_upd (if_t); +static int bce_ifmedia_upd_locked (if_t); +static void bce_ifmedia_sts (if_t, struct ifmediareq *); static void bce_ifmedia_sts_rphy (struct bce_softc *, struct ifmediareq *); static void bce_init_locked (struct bce_softc *); static void bce_init (void *); @@ -1052,7 +1052,7 @@ static int bce_attach(device_t dev) { struct bce_softc *sc; - struct ifnet *ifp; + if_t ifp; u32 val; int count, error, rc = 0, rid; @@ -1371,28 +1371,28 @@ bce_attach(device_t dev) } /* Initialize the ifnet interface. */ - ifp->if_softc = sc; + if_setsoftc(ifp, sc); if_initname(ifp, device_get_name(dev), device_get_unit(dev)); - ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST; - ifp->if_ioctl = bce_ioctl; - ifp->if_start = bce_start; - ifp->if_get_counter = bce_get_counter; - ifp->if_init = bce_init; - ifp->if_mtu = ETHERMTU; + if_setflags(ifp, IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST); + if_setioctlfn(ifp, bce_ioctl); + if_setstartfn(ifp, bce_start); + if_setgetcounterfn(ifp, bce_get_counter); + if_setinitfn(ifp, bce_init); + if_setmtu(ifp, ETHERMTU); if (bce_tso_enable) { - ifp->if_hwassist = BCE_IF_HWASSIST | CSUM_TSO; - ifp->if_capabilities = BCE_IF_CAPABILITIES | IFCAP_TSO4 | - IFCAP_VLAN_HWTSO; + if_sethwassist(ifp, BCE_IF_HWASSIST | CSUM_TSO); + if_setcapabilities(ifp, BCE_IF_CAPABILITIES | IFCAP_TSO4 | + IFCAP_VLAN_HWTSO); } else { - ifp->if_hwassist = BCE_IF_HWASSIST; - ifp->if_capabilities = BCE_IF_CAPABILITIES; + if_sethwassist(ifp, BCE_IF_HWASSIST); + if_setcapabilities(ifp, BCE_IF_CAPABILITIES); } if ((sc->bce_phy_flags & BCE_PHY_REMOTE_CAP_FLAG) != 0) - ifp->if_capabilities |= IFCAP_LINKSTATE; + if_setcapabilitiesbit(ifp, IFCAP_LINKSTATE, 0); - ifp->if_capenable = ifp->if_capabilities; + if_setcapenable(ifp, if_getcapabilities(ifp)); /* * Assume standard mbuf sizes for buffer allocation. @@ -1403,14 +1403,13 @@ bce_attach(device_t dev) (ETHER_MAX_LEN - ETHER_HDR_LEN - ETHER_CRC_LEN)); /* Recalculate our buffer allocation sizes. */ - ifp->if_snd.ifq_drv_maxlen = USABLE_TX_BD_ALLOC; - IFQ_SET_MAXLEN(&ifp->if_snd, ifp->if_snd.ifq_drv_maxlen); - IFQ_SET_READY(&ifp->if_snd); + if_setsendqlen(ifp, USABLE_TX_BD_ALLOC); + if_setsendqready(ifp); if (sc->bce_phy_flags & BCE_PHY_2_5G_CAPABLE_FLAG) - ifp->if_baudrate = IF_Mbps(2500ULL); + if_setbaudrate(ifp, IF_Mbps(2500ULL)); else - ifp->if_baudrate = IF_Mbps(1000); + if_setbaudrate(ifp, IF_Mbps(1000)); /* Handle any special PHY initialization for SerDes PHYs. */ bce_init_media(sc); @@ -1534,7 +1533,7 @@ static int bce_detach(device_t dev) { struct bce_softc *sc = device_get_softc(dev); - struct ifnet *ifp; + if_t ifp; u32 msg; DBENTER(BCE_VERBOSE_UNLOAD | BCE_VERBOSE_RESET); @@ -4835,7 +4834,7 @@ bce_set_mac_addr(struct bce_softc *sc) static void bce_stop(struct bce_softc *sc) { - struct ifnet *ifp; + if_t ifp; DBENTER(BCE_VERBOSE_RESET); @@ -4865,7 +4864,7 @@ bce_stop(struct bce_softc *sc) sc->bce_link_up = FALSE; - ifp->if_drv_flags &= ~(IFF_DRV_RUNNING | IFF_DRV_OACTIVE); + if_setdrvflagbits(ifp, 0, (IFF_DRV_RUNNING | IFF_DRV_OACTIVE)); DBEXIT(BCE_VERBOSE_RESET); } @@ -6072,9 +6071,9 @@ bce_get_rphy_link(struct bce_softc *sc) /* 0 for success, positive value for failure. */ /****************************************************************************/ static int -bce_ifmedia_upd(struct ifnet *ifp) +bce_ifmedia_upd(if_t ifp) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); int error; DBENTER(BCE_VERBOSE); @@ -6094,9 +6093,9 @@ bce_ifmedia_upd(struct ifnet *ifp) /* Nothing. */ /****************************************************************************/ static int -bce_ifmedia_upd_locked(struct ifnet *ifp) +bce_ifmedia_upd_locked(if_t ifp) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); struct mii_data *mii; struct mii_softc *miisc; struct ifmedia *ifm; @@ -6212,7 +6211,7 @@ bce_ifmedia_upd_locked(struct ifnet *ifp) static void bce_ifmedia_sts_rphy(struct bce_softc *sc, struct ifmediareq *ifmr) { - struct ifnet *ifp; + if_t ifp; u32 link; ifp = sc->bce_ifp; @@ -6226,39 +6225,39 @@ bce_ifmedia_sts_rphy(struct bce_softc *sc, struct ifmediareq *ifmr) ifmr->ifm_status |= IFM_ACTIVE; else { ifmr->ifm_active |= IFM_NONE; - ifp->if_baudrate = 0; + if_setbaudrate(ifp, 0); return; } switch (link & BCE_LINK_STATUS_SPEED_MASK) { case BCE_LINK_STATUS_10HALF: ifmr->ifm_active |= IFM_10_T | IFM_HDX; - ifp->if_baudrate = IF_Mbps(10UL); + if_setbaudrate(ifp, IF_Mbps(10UL)); break; case BCE_LINK_STATUS_10FULL: ifmr->ifm_active |= IFM_10_T | IFM_FDX; - ifp->if_baudrate = IF_Mbps(10UL); + if_setbaudrate(ifp, IF_Mbps(10UL)); break; case BCE_LINK_STATUS_100HALF: ifmr->ifm_active |= IFM_100_TX | IFM_HDX; - ifp->if_baudrate = IF_Mbps(100UL); + if_setbaudrate(ifp, IF_Mbps(100UL)); break; case BCE_LINK_STATUS_100FULL: ifmr->ifm_active |= IFM_100_TX | IFM_FDX; - ifp->if_baudrate = IF_Mbps(100UL); + if_setbaudrate(ifp, IF_Mbps(100UL)); break; case BCE_LINK_STATUS_1000HALF: if ((sc->bce_phy_flags & BCE_PHY_REMOTE_PORT_FIBER_FLAG) == 0) ifmr->ifm_active |= IFM_1000_T | IFM_HDX; else ifmr->ifm_active |= IFM_1000_SX | IFM_HDX; - ifp->if_baudrate = IF_Mbps(1000UL); + if_setbaudrate(ifp, IF_Mbps(1000UL)); break; case BCE_LINK_STATUS_1000FULL: if ((sc->bce_phy_flags & BCE_PHY_REMOTE_PORT_FIBER_FLAG) == 0) ifmr->ifm_active |= IFM_1000_T | IFM_FDX; else ifmr->ifm_active |= IFM_1000_SX | IFM_FDX; - ifp->if_baudrate = IF_Mbps(1000UL); + if_setbaudrate(ifp, IF_Mbps(1000UL)); break; case BCE_LINK_STATUS_2500HALF: if ((sc->bce_phy_flags & BCE_PHY_REMOTE_PORT_FIBER_FLAG) == 0) { @@ -6266,7 +6265,7 @@ bce_ifmedia_sts_rphy(struct bce_softc *sc, struct ifmediareq *ifmr) return; } else ifmr->ifm_active |= IFM_2500_SX | IFM_HDX; - ifp->if_baudrate = IF_Mbps(2500UL); + if_setbaudrate(ifp, IF_Mbps(2500UL)); break; case BCE_LINK_STATUS_2500FULL: if ((sc->bce_phy_flags & BCE_PHY_REMOTE_PORT_FIBER_FLAG) == 0) { @@ -6274,7 +6273,7 @@ bce_ifmedia_sts_rphy(struct bce_softc *sc, struct ifmediareq *ifmr) return; } else ifmr->ifm_active |= IFM_2500_SX | IFM_FDX; - ifp->if_baudrate = IF_Mbps(2500UL); + if_setbaudrate(ifp, IF_Mbps(2500UL)); break; default: ifmr->ifm_active |= IFM_NONE; @@ -6294,16 +6293,16 @@ bce_ifmedia_sts_rphy(struct bce_softc *sc, struct ifmediareq *ifmr) /* Nothing. */ /****************************************************************************/ static void -bce_ifmedia_sts(struct ifnet *ifp, struct ifmediareq *ifmr) +bce_ifmedia_sts(if_t ifp, struct ifmediareq *ifmr) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); struct mii_data *mii; DBENTER(BCE_VERBOSE_PHY); BCE_LOCK(sc); - if ((ifp->if_flags & IFF_UP) == 0) { + if ((if_getflags(ifp) & IFF_UP) == 0) { BCE_UNLOCK(sc); return; } @@ -6415,7 +6414,7 @@ bce_get_hw_rx_cons(struct bce_softc *sc) static void bce_rx_intr(struct bce_softc *sc) { - struct ifnet *ifp = sc->bce_ifp; + if_t ifp = sc->bce_ifp; struct l2_fhdr *l2fhdr; struct ether_vlan_header *vh; unsigned int pkt_len; @@ -6642,7 +6641,7 @@ bce_rx_intr(struct bce_softc *sc) m0->m_pkthdr.csum_flags = 0; /* Validate the checksum if offload enabled. */ - if (ifp->if_capenable & IFCAP_RXCSUM) { + if (if_getcapenable(ifp) & IFCAP_RXCSUM) { /* Check for an IP datagram. */ if (!(status & L2_FHDR_STATUS_SPLIT) && (status & L2_FHDR_STATUS_IP_DATAGRAM)) { @@ -6674,7 +6673,7 @@ bce_rx_intr(struct bce_softc *sc) if ((status & L2_FHDR_STATUS_L2_VLAN_TAG) && !(sc->rx_mode & BCE_EMAC_RX_MODE_KEEP_VLAN_TAG)) { DBRUN(sc->vlan_tagged_frames_rcvd++); - if (ifp->if_capenable & IFCAP_VLAN_HWTAGGING) { + if (if_getcapenable(ifp) & IFCAP_VLAN_HWTAGGING) { DBRUN(sc->vlan_tagged_frames_stripped++); m0->m_pkthdr.ether_vtag = l2fhdr->l2_fhdr_vlan_tag; @@ -6716,7 +6715,7 @@ bce_rx_intr_next_rx: sc->pg_cons = sw_pg_cons; BCE_UNLOCK(sc); - (*ifp->if_input)(ifp, m0); + if_input(ifp, m0); BCE_LOCK(sc); /* Recover our place. */ @@ -6785,7 +6784,7 @@ bce_get_hw_tx_cons(struct bce_softc *sc) static void bce_tx_intr(struct bce_softc *sc) { - struct ifnet *ifp = sc->bce_ifp; + if_t ifp = sc->bce_ifp; u16 hw_tx_cons, sw_tx_cons, sw_tx_chain_cons; DBENTER(BCE_VERBOSE_SEND | BCE_VERBOSE_INTR); @@ -6878,11 +6877,11 @@ bce_tx_intr(struct bce_softc *sc) /* Clear the tx hardware queue full flag. */ if (sc->used_tx_bd < sc->max_tx_bd) { - DBRUNIF((ifp->if_drv_flags & IFF_DRV_OACTIVE), + DBRUNIF((if_getdrvflags(ifp) & IFF_DRV_OACTIVE), DBPRINT(sc, BCE_INFO_SEND, "%s(): Open TX chain! %d/%d (used/total)\n", __FUNCTION__, sc->used_tx_bd, sc->max_tx_bd)); - ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; + if_setdrvflagbits(ifp, 0, IFF_DRV_OACTIVE); } sc->tx_cons = sw_tx_cons; @@ -6944,7 +6943,7 @@ bce_enable_intr(struct bce_softc *sc, int coal_now) static void bce_init_locked(struct bce_softc *sc) { - struct ifnet *ifp; + if_t ifp; u32 ether_mtu = 0; DBENTER(BCE_VERBOSE_RESET); @@ -6954,7 +6953,7 @@ bce_init_locked(struct bce_softc *sc) ifp = sc->bce_ifp; /* Check if the driver is still running and bail out if it is. */ - if (ifp->if_drv_flags & IFF_DRV_RUNNING) + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) goto bce_init_locked_exit; bce_stop(sc); @@ -6978,30 +6977,30 @@ bce_init_locked(struct bce_softc *sc) } /* Load our MAC address. */ - bcopy(IF_LLADDR(sc->bce_ifp), sc->eaddr, ETHER_ADDR_LEN); + bcopy(if_getlladdr(sc->bce_ifp), sc->eaddr, ETHER_ADDR_LEN); bce_set_mac_addr(sc); if (bce_hdr_split == FALSE) - bce_get_rx_buffer_sizes(sc, ifp->if_mtu); + bce_get_rx_buffer_sizes(sc, if_getmtu(ifp)); /* * Calculate and program the hardware Ethernet MTU * size. Be generous on the receive if we have room * and allowed by the user. */ if (bce_strict_rx_mtu == TRUE) - ether_mtu = ifp->if_mtu; + ether_mtu = if_getmtu(ifp); else { if (bce_hdr_split == TRUE) { - if (ifp->if_mtu <= sc->rx_bd_mbuf_data_len + MCLBYTES) + if (if_getmtu(ifp) <= sc->rx_bd_mbuf_data_len + MCLBYTES) ether_mtu = sc->rx_bd_mbuf_data_len + MCLBYTES; else - ether_mtu = ifp->if_mtu; + ether_mtu = if_getmtu(ifp); } else { - if (ifp->if_mtu <= sc->rx_bd_mbuf_data_len) + if (if_getmtu(ifp) <= sc->rx_bd_mbuf_data_len) ether_mtu = sc->rx_bd_mbuf_data_len; else - ether_mtu = ifp->if_mtu; + ether_mtu = if_getmtu(ifp); } } @@ -7038,8 +7037,8 @@ bce_init_locked(struct bce_softc *sc) bce_ifmedia_upd_locked(ifp); /* Let the OS know the driver is up and running. */ - ifp->if_drv_flags |= IFF_DRV_RUNNING; - ifp->if_drv_flags &= ~IFF_DRV_OACTIVE; + if_setdrvflagbits(ifp, IFF_DRV_RUNNING, 0); + if_setdrvflagbits(ifp, 0, IFF_DRV_OACTIVE); callout_reset(&sc->bce_tick_callout, hz, bce_tick, sc); @@ -7057,7 +7056,7 @@ bce_init_locked_exit: static void bce_mgmt_init_locked(struct bce_softc *sc) { - struct ifnet *ifp; + if_t ifp; DBENTER(BCE_VERBOSE_RESET); @@ -7425,9 +7424,9 @@ bce_tx_encap_exit: /* Nothing. */ /****************************************************************************/ static void -bce_start_locked(struct ifnet *ifp) +bce_start_locked(if_t ifp) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); struct mbuf *m_head = NULL; int count = 0; u16 tx_prod, tx_chain_prod __unused; @@ -7452,7 +7451,7 @@ bce_start_locked(struct ifnet *ifp) goto bce_start_locked_exit; } - if (IFQ_DRV_IS_EMPTY(&ifp->if_snd)) { + if (if_sendq_empty(ifp)) { DBPRINT(sc, BCE_INFO_SEND, "%s(): Transmit queue empty.\n", __FUNCTION__); goto bce_start_locked_exit; @@ -7463,7 +7462,7 @@ bce_start_locked(struct ifnet *ifp) */ while (sc->used_tx_bd < sc->max_tx_bd) { /* Check for any frames to send. */ - IFQ_DRV_DEQUEUE(&ifp->if_snd, m_head); + m_head = if_dequeue(ifp); /* Stop when the transmit queue is empty. */ if (m_head == NULL) @@ -7477,8 +7476,8 @@ bce_start_locked(struct ifnet *ifp) */ if (bce_tx_encap(sc, &m_head)) { if (m_head != NULL) - IFQ_DRV_PREPEND(&ifp->if_snd, m_head); - ifp->if_drv_flags |= IFF_DRV_OACTIVE; + if_sendq_prepend(ifp, m_head); + if_setdrvflagbits(ifp, IFF_DRV_OACTIVE, 0); DBPRINT(sc, BCE_INFO_SEND, "TX chain is closed for business! Total " "tx_bd used = %d\n", sc->used_tx_bd); @@ -7518,9 +7517,9 @@ bce_start_locked_exit: /* Nothing. */ /****************************************************************************/ static void -bce_start(struct ifnet *ifp) +bce_start(if_t ifp) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); DBENTER(BCE_VERBOSE_SEND); @@ -7538,9 +7537,9 @@ bce_start(struct ifnet *ifp) /* 0 for success, positive value for failure. */ /****************************************************************************/ static int -bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) +bce_ioctl(if_t ifp, u_long command, caddr_t data) { - struct bce_softc *sc = ifp->if_softc; + struct bce_softc *sc = if_getsoftc(ifp); struct ifreq *ifr = (struct ifreq *) data; struct mii_data *mii; int mask, error = 0; @@ -7559,12 +7558,12 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) DBPRINT(sc, BCE_INFO_MISC, "SIOCSIFMTU: Changing MTU from %d to %d\n", - (int) ifp->if_mtu, (int) ifr->ifr_mtu); + (int) if_getmtu(ifp), (int) ifr->ifr_mtu); BCE_LOCK(sc); - ifp->if_mtu = ifr->ifr_mtu; - if (ifp->if_drv_flags & IFF_DRV_RUNNING) { - ifp->if_drv_flags &= ~IFF_DRV_RUNNING; + if_setmtu(ifp, ifr->ifr_mtu); + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) { + if_setdrvflagbits(ifp, 0, IFF_DRV_RUNNING); bce_init_locked(sc); } BCE_UNLOCK(sc); @@ -7577,8 +7576,8 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) BCE_LOCK(sc); /* Check if the interface is up. */ - if (ifp->if_flags & IFF_UP) { - if (ifp->if_drv_flags & IFF_DRV_RUNNING) { + if (if_getflags(ifp) & IFF_UP) { + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) { /* Change promiscuous/multicast flags as necessary. */ bce_set_rx_mode(sc); } else { @@ -7587,7 +7586,7 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) } } else { /* The interface is down, check if driver is running. */ - if (ifp->if_drv_flags & IFF_DRV_RUNNING) { + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) { bce_stop(sc); /* If MFW is running, restart the controller a bit. */ @@ -7609,7 +7608,7 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) "Received SIOCADDMULTI/SIOCDELMULTI\n"); BCE_LOCK(sc); - if (ifp->if_drv_flags & IFF_DRV_RUNNING) + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) bce_set_rx_mode(sc); BCE_UNLOCK(sc); @@ -7632,42 +7631,42 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) /* Set interface capability */ case SIOCSIFCAP: - mask = ifr->ifr_reqcap ^ ifp->if_capenable; + mask = ifr->ifr_reqcap ^ if_getcapenable(ifp); DBPRINT(sc, BCE_INFO_MISC, "Received SIOCSIFCAP = 0x%08X\n", (u32) mask); /* Toggle the TX checksum capabilities enable flag. */ if (mask & IFCAP_TXCSUM && - ifp->if_capabilities & IFCAP_TXCSUM) { - ifp->if_capenable ^= IFCAP_TXCSUM; - if (IFCAP_TXCSUM & ifp->if_capenable) - ifp->if_hwassist |= BCE_IF_HWASSIST; + if_getcapabilities(ifp) & IFCAP_TXCSUM) { + if_togglecapenable(ifp, IFCAP_TXCSUM); + if (IFCAP_TXCSUM & if_getcapenable(ifp)) + if_sethwassistbits(ifp, BCE_IF_HWASSIST, 0); else - ifp->if_hwassist &= ~BCE_IF_HWASSIST; + if_sethwassistbits(ifp, 0, BCE_IF_HWASSIST); } /* Toggle the RX checksum capabilities enable flag. */ if (mask & IFCAP_RXCSUM && - ifp->if_capabilities & IFCAP_RXCSUM) - ifp->if_capenable ^= IFCAP_RXCSUM; + if_getcapabilities(ifp) & IFCAP_RXCSUM) + if_togglecapenable(ifp, IFCAP_RXCSUM); /* Toggle the TSO capabilities enable flag. */ if (bce_tso_enable && (mask & IFCAP_TSO4) && - ifp->if_capabilities & IFCAP_TSO4) { - ifp->if_capenable ^= IFCAP_TSO4; - if (IFCAP_TSO4 & ifp->if_capenable) - ifp->if_hwassist |= CSUM_TSO; + if_getcapabilities(ifp) & IFCAP_TSO4) { + if_togglecapenable(ifp, IFCAP_TSO4); + if (IFCAP_TSO4 & if_getcapenable(ifp)) + if_sethwassistbits(ifp, CSUM_TSO, 0); else - ifp->if_hwassist &= ~CSUM_TSO; + if_sethwassistbits(ifp, 0, CSUM_TSO); } if (mask & IFCAP_VLAN_HWCSUM && - ifp->if_capabilities & IFCAP_VLAN_HWCSUM) - ifp->if_capenable ^= IFCAP_VLAN_HWCSUM; + if_getcapabilities(ifp) & IFCAP_VLAN_HWCSUM) + if_togglecapenable(ifp, IFCAP_VLAN_HWCSUM); if ((mask & IFCAP_VLAN_HWTSO) != 0 && - (ifp->if_capabilities & IFCAP_VLAN_HWTSO) != 0) - ifp->if_capenable ^= IFCAP_VLAN_HWTSO; + (if_getcapabilities(ifp) & IFCAP_VLAN_HWTSO) != 0) + if_togglecapenable(ifp, IFCAP_VLAN_HWTSO); /* * Don't actually disable VLAN tag stripping as * management firmware (ASF/IPMI/UMP) requires the @@ -7676,11 +7675,11 @@ bce_ioctl(struct ifnet *ifp, u_long command, caddr_t data) * appending stripped VLAN tag. */ if ((mask & IFCAP_VLAN_HWTAGGING) != 0 && - (ifp->if_capabilities & IFCAP_VLAN_HWTAGGING)) { - ifp->if_capenable ^= IFCAP_VLAN_HWTAGGING; - if ((ifp->if_capenable & IFCAP_VLAN_HWTAGGING) + (if_getcapabilities(ifp) & IFCAP_VLAN_HWTAGGING)) { + if_togglecapenable(ifp, IFCAP_VLAN_HWTAGGING); + if ((if_getcapenable(ifp) & IFCAP_VLAN_HWTAGGING) == 0) - ifp->if_capenable &= ~IFCAP_VLAN_HWTSO; + if_setcapenablebit(ifp, 0, IFCAP_VLAN_HWTSO); } VLAN_CAPABILITIES(ifp); break; @@ -7756,7 +7755,7 @@ bce_watchdog(struct bce_softc *sc) DBRUN(bce_breakpoint(sc)); - sc->bce_ifp->if_drv_flags &= ~IFF_DRV_RUNNING; + if_setdrvflagbits(sc->bce_ifp, 0, IFF_DRV_RUNNING); bce_init_locked(sc); sc->watchdog_timeouts++; @@ -7781,7 +7780,7 @@ static void bce_intr(void *xsc) { struct bce_softc *sc; - struct ifnet *ifp; + if_t ifp; u32 status_attn_bits; u16 hw_rx_cons, hw_tx_cons; @@ -7900,8 +7899,8 @@ bce_intr(void *xsc) bce_enable_intr(sc, 0); /* Handle any frames that arrived while handling the interrupt. */ - if (ifp->if_drv_flags & IFF_DRV_RUNNING && - !IFQ_DRV_IS_EMPTY(&ifp->if_snd)) + if (if_getdrvflags(ifp) & IFF_DRV_RUNNING && + !if_sendq_empty(ifp)) bce_start_locked(ifp); bce_intr_exit: @@ -7931,7 +7930,7 @@ bce_hash_maddr(void *arg, struct sockaddr_dl *sdl, u_int cnt) static void bce_set_rx_mode(struct bce_softc *sc) { - struct ifnet *ifp; + if_t ifp; u32 hashes[NUM_MC_HASH_REGISTERS] = { 0, 0, 0, 0, 0, 0, 0, 0 }; u32 rx_mode, sort_mode; int i; @@ -7959,13 +7958,13 @@ bce_set_rx_mode(struct bce_softc *sc) * Check for promiscuous, all multicast, or selected * multicast address filtering. */ - if (ifp->if_flags & IFF_PROMISC) { + if (if_getflags(ifp) & IFF_PROMISC) { DBPRINT(sc, BCE_INFO_MISC, "Enabling promiscuous mode.\n"); /* Enable promiscuous mode. */ rx_mode |= BCE_EMAC_RX_MODE_PROMISCUOUS; sort_mode |= BCE_RPM_SORT_USER0_PROM_EN; - } else if (ifp->if_flags & IFF_ALLMULTI) { + } else if (if_getflags(ifp) & IFF_ALLMULTI) { DBPRINT(sc, BCE_INFO_MISC, "Enabling all multicast mode.\n"); /* Enable all multicast addresses. */ @@ -8207,7 +8206,7 @@ bce_stats_update(struct bce_softc *sc) } static uint64_t -bce_get_counter(struct ifnet *ifp, ift_counter cnt) +bce_get_counter(if_t ifp, ift_counter cnt) { struct bce_softc *sc; uint64_t rv; @@ -8313,7 +8312,7 @@ bce_tick(void *xsc) { struct bce_softc *sc = xsc; struct mii_data *mii; - struct ifnet *ifp; + if_t ifp; struct ifmediareq ifmr; ifp = sc->bce_ifp; @@ -8367,7 +8366,7 @@ bce_tick(void *xsc) } if (sc->bce_link_up == TRUE) { /* Now that link is up, handle any outstanding TX traffic. */ - if (!IFQ_DRV_IS_EMPTY(&ifp->if_snd)) { + if (!if_sendq_empty(ifp)) { DBPRINT(sc, BCE_VERBOSE_MISC, "%s(): Found " "pending TX traffic.\n", __FUNCTION__); bce_start_locked(ifp); diff --git a/sys/dev/bce/if_bcereg.h b/sys/dev/bce/if_bcereg.h index 0aa3eda3a97d..2adedc254578 100644 --- a/sys/dev/bce/if_bcereg.h +++ b/sys/dev/bce/if_bcereg.h @@ -6298,7 +6298,7 @@ struct bce_softc struct mtx bce_mtx; /* Interface info */ - struct ifnet *bce_ifp; + if_t bce_ifp; /* Parent device handle */ device_t bce_dev;