summaryrefslogtreecommitdiff
path: root/sys/dev/hyperv
diff options
context:
space:
mode:
authorSepherosa Ziehau <sephe@FreeBSD.org>2017-08-14 05:30:02 +0000
committerSepherosa Ziehau <sephe@FreeBSD.org>2017-08-14 05:30:02 +0000
commit3bed4e54f8dcb536798699b189c8fb100a56545d (patch)
tree695c27d6a46e0264eef6967eaff40feabd79cf7f /sys/dev/hyperv
parenta6e709f29c93a3e84e7991e98c0420193ecb9aa4 (diff)
Notes
Diffstat (limited to 'sys/dev/hyperv')
-rw-r--r--sys/dev/hyperv/netvsc/if_hn.c31
1 files changed, 26 insertions, 5 deletions
diff --git a/sys/dev/hyperv/netvsc/if_hn.c b/sys/dev/hyperv/netvsc/if_hn.c
index e16b42d4ebc71..9c49356e7ce42 100644
--- a/sys/dev/hyperv/netvsc/if_hn.c
+++ b/sys/dev/hyperv/netvsc/if_hn.c
@@ -1266,16 +1266,37 @@ hn_xpnt_vf_input(struct ifnet *vf_ifp, struct mbuf *m)
rm_runlock(&hn_vfmap_lock, &pt);
if (hn_ifp != NULL) {
- /*
- * Fix up rcvif and go through hn(4)'s if_input and
- * increase ipackets.
- */
for (mn = m; mn != NULL; mn = mn->m_nextpkt) {
- /* Allow tapping on the VF. */
+ /*
+ * Allow tapping on the VF.
+ */
ETHER_BPF_MTAP(vf_ifp, mn);
+
+ /*
+ * Update VF stats.
+ */
+ if ((vf_ifp->if_capenable & IFCAP_HWSTATS) == 0) {
+ if_inc_counter(vf_ifp, IFCOUNTER_IBYTES,
+ mn->m_pkthdr.len);
+ }
+ /*
+ * XXX IFCOUNTER_IMCAST
+ * This stat updating is kinda invasive, since it
+ * requires two checks on the mbuf: the length check
+ * and the ethernet header check. As of this write,
+ * all multicast packets go directly to hn(4), which
+ * makes imcast stat updating in the VF a try in vian.
+ */
+
+ /*
+ * Fix up rcvif and increase hn(4)'s ipackets.
+ */
mn->m_pkthdr.rcvif = hn_ifp;
if_inc_counter(hn_ifp, IFCOUNTER_IPACKETS, 1);
}
+ /*
+ * Go through hn(4)'s if_input.
+ */
hn_ifp->if_input(hn_ifp, m);
} else {
/*