svn commit: r185506 - head/sys/dev/cxgb
Navdeep Parhar
nparhar at gmail.com
Sun Nov 30 22:47:27 PST 2008
Kip,
pi->mac.stats are not updated too frequently, especially when compared
to the rates at which packets/bytes are sent and received. The ifp->
counters will lag behind the actual values. This will affect the
"realtime-ness" of the stats seen via utilities like netstat.
We should continue to increment the ifp's counters as best as we can
during tx/rx. It is good to sync them up with mac.stats every so often,
but relying exclusively on mac.stats may not be best.
Regards,
Navdeep
On Mon, Dec 01, 2008 at 04:41:45AM +0000, Kip Macy wrote:
> Author: kmacy
> Date: Mon Dec 1 04:41:45 2008
> New Revision: 185506
> URL: http://svn.freebsd.org/changeset/base/185506
>
> Log:
> Proper fix for tracking ifnet statistics
>
> Modified:
> head/sys/dev/cxgb/cxgb_main.c
>
> Modified: head/sys/dev/cxgb/cxgb_main.c
> ==============================================================================
> --- head/sys/dev/cxgb/cxgb_main.c Mon Dec 1 04:03:17 2008 (r185505)
> +++ head/sys/dev/cxgb/cxgb_main.c Mon Dec 1 04:41:45 2008 (r185506)
> @@ -2203,6 +2203,58 @@ cxgb_tick_handler(void *arg, int count)
> if (p->linkpoll_period)
> check_link_status(sc);
>
> +
> + for (i = 0; i < sc->params.nports; i++) {
> + struct port_info *pi = &sc->port[i];
> + struct ifnet *ifp = pi->ifp;
> + struct mac_stats *mstats = &pi->mac.stats;
> +
> + ifp->if_opackets =
> + mstats->tx_frames_64 +
> + mstats->tx_frames_65_127 +
> + mstats->tx_frames_128_255 +
> + mstats->tx_frames_256_511 +
> + mstats->tx_frames_512_1023 +
> + mstats->tx_frames_1024_1518 +
> + mstats->tx_frames_1519_max;
> +
> + ifp->if_ipackets =
> + mstats->rx_frames_64 +
> + mstats->rx_frames_65_127 +
> + mstats->rx_frames_128_255 +
> + mstats->rx_frames_256_511 +
> + mstats->rx_frames_512_1023 +
> + mstats->rx_frames_1024_1518 +
> + mstats->rx_frames_1519_max;
> +
> + ifp->if_obytes = mstats->tx_octets;
> + ifp->if_ibytes = mstats->rx_octets;
> + ifp->if_omcasts = mstats->tx_mcast_frames;
> + ifp->if_imcasts = mstats->rx_mcast_frames;
> +
> + ifp->if_collisions =
> + mstats->tx_total_collisions;
> +
> + ifp->if_iqdrops = mstats->rx_cong_drops;
> +
> + ifp->if_oerrors =
> + mstats->tx_excess_collisions +
> + mstats->tx_underrun +
> + mstats->tx_len_errs +
> + mstats->tx_mac_internal_errs +
> + mstats->tx_excess_deferral +
> + mstats->tx_fcs_errs;
> + ifp->if_ierrors =
> + mstats->rx_jabber +
> + mstats->rx_data_errs +
> + mstats->rx_sequence_errs +
> + mstats->rx_runt +
> + mstats->rx_too_long +
> + mstats->rx_mac_internal_errs +
> + mstats->rx_short +
> + mstats->rx_fcs_errs;
> + }
> +
> sc->check_task_cnt++;
>
> /*
> _______________________________________________
> svn-src-all at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/svn-src-all
> To unsubscribe, send any mail to "svn-src-all-unsubscribe at freebsd.org"
More information about the svn-src-all
mailing list