Module Name: src Committed By: martin Date: Mon Apr 16 14:34:43 UTC 2018
Modified Files: src/sys/arch/x86/pci [netbsd-8]: if_vmx.c Log Message: Pull up following revision(s) (requested by nonaka in ticket #767): sys/arch/x86/pci/if_vmx.c: revision 1.23,1.24 vmx(4): handled SIOCZIFDATA. vmx(4): compute if_ibytes using rxq->vxrxq_stats.vmrxs_ibytes. To generate a diff of this commit: cvs rdiff -u -r1.19.6.3 -r1.19.6.4 src/sys/arch/x86/pci/if_vmx.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/arch/x86/pci/if_vmx.c diff -u src/sys/arch/x86/pci/if_vmx.c:1.19.6.3 src/sys/arch/x86/pci/if_vmx.c:1.19.6.4 --- src/sys/arch/x86/pci/if_vmx.c:1.19.6.3 Mon Apr 16 14:18:53 2018 +++ src/sys/arch/x86/pci/if_vmx.c Mon Apr 16 14:34:43 2018 @@ -1,4 +1,4 @@ -/* $NetBSD: if_vmx.c,v 1.19.6.3 2018/04/16 14:18:53 martin Exp $ */ +/* $NetBSD: if_vmx.c,v 1.19.6.4 2018/04/16 14:34:43 martin Exp $ */ /* $OpenBSD: if_vmx.c,v 1.16 2014/01/22 06:04:17 brad Exp $ */ /* @@ -19,7 +19,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: if_vmx.c,v 1.19.6.3 2018/04/16 14:18:53 martin Exp $"); +__KERNEL_RCSID(0, "$NetBSD: if_vmx.c,v 1.19.6.4 2018/04/16 14:34:43 martin Exp $"); #include <sys/param.h> #include <sys/cpu.h> @@ -2892,27 +2892,40 @@ vmxnet3_ioctl(struct ifnet *ifp, u_long splx(s); break; case SIOCGIFDATA: + case SIOCZIFDATA: ifp->if_ipackets = 0; + ifp->if_ibytes = 0; ifp->if_iqdrops = 0; ifp->if_ierrors = 0; for (int i = 0; i < sc->vmx_nrxqueues; i++) { - ifp->if_ipackets += - sc->vmx_rxq[i].vxrxq_stats.vmrxs_ipackets; - ifp->if_iqdrops += - sc->vmx_rxq[i].vxrxq_stats.vmrxs_iqdrops; - ifp->if_ierrors += - sc->vmx_rxq[i].vxrxq_stats.vmrxs_ierrors; + struct vmxnet3_rxqueue *rxq = &sc->vmx_rxq[i]; + + VMXNET3_RXQ_LOCK(rxq); + ifp->if_ipackets += rxq->vxrxq_stats.vmrxs_ipackets; + ifp->if_ibytes += rxq->vxrxq_stats.vmrxs_ibytes; + ifp->if_iqdrops += rxq->vxrxq_stats.vmrxs_iqdrops; + ifp->if_ierrors += rxq->vxrxq_stats.vmrxs_ierrors; + if (cmd == SIOCZIFDATA) { + memset(&rxq->vxrxq_stats, 0, + sizeof(rxq->vxrxq_stats)); + } + VMXNET3_RXQ_UNLOCK(rxq); } ifp->if_opackets = 0; ifp->if_obytes = 0; ifp->if_omcasts = 0; for (int i = 0; i < sc->vmx_ntxqueues; i++) { - ifp->if_opackets += - sc->vmx_txq[i].vxtxq_stats.vmtxs_opackets; - ifp->if_obytes += - sc->vmx_txq[i].vxtxq_stats.vmtxs_obytes; - ifp->if_omcasts += - sc->vmx_txq[i].vxtxq_stats.vmtxs_omcasts; + struct vmxnet3_txqueue *txq = &sc->vmx_txq[i]; + + VMXNET3_TXQ_LOCK(txq); + ifp->if_opackets += txq->vxtxq_stats.vmtxs_opackets; + ifp->if_obytes += txq->vxtxq_stats.vmtxs_obytes; + ifp->if_omcasts += txq->vxtxq_stats.vmtxs_omcasts; + if (cmd == SIOCZIFDATA) { + memset(&txq->vxtxq_stats, 0, + sizeof(txq->vxtxq_stats)); + } + VMXNET3_TXQ_UNLOCK(txq); } /* FALLTHROUGH */ default: