Author: glebius
Date: Sun Sep 28 07:29:45 2014
New Revision: 272240
URL: http://svnweb.freebsd.org/changeset/base/272240

Log:
  Convert to if_get_counter().

Modified:
  head/sys/dev/ixgbe/ixgbe.c

Modified: head/sys/dev/ixgbe/ixgbe.c
==============================================================================
--- head/sys/dev/ixgbe/ixgbe.c  Sun Sep 28 07:27:58 2014        (r272239)
+++ head/sys/dev/ixgbe/ixgbe.c  Sun Sep 28 07:29:45 2014        (r272240)
@@ -120,6 +120,7 @@ static int      ixgbe_ioctl(struct ifnet
 static void    ixgbe_init(void *);
 static void    ixgbe_init_locked(struct adapter *);
 static void     ixgbe_stop(void *);
+static uint64_t        ixgbe_get_counter(struct ifnet *, ift_counter);
 static void     ixgbe_media_status(struct ifnet *, struct ifmediareq *);
 static int      ixgbe_media_change(struct ifnet *);
 static void     ixgbe_identify_hardware(struct adapter *);
@@ -2721,6 +2722,7 @@ ixgbe_setup_interface(device_t dev, stru
        ifp->if_softc = adapter;
        ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST;
        ifp->if_ioctl = ixgbe_ioctl;
+       ifp->if_get_counter = ixgbe_get_counter;
 #ifndef IXGBE_LEGACY_TX
        ifp->if_transmit = ixgbe_mq_start;
        ifp->if_qflush = ixgbe_qflush;
@@ -5364,10 +5366,8 @@ ixgbe_reinit_fdir(void *context, int pen
 static void
 ixgbe_update_stats_counters(struct adapter *adapter)
 {
-       struct ifnet   *ifp = adapter->ifp;
        struct ixgbe_hw *hw = &adapter->hw;
        u32  missed_rx = 0, bprc, lxon, lxoff, total;
-       u64  total_missed_rx = 0;
 
        adapter->stats.crcerrs += IXGBE_READ_REG(hw, IXGBE_CRCERRS);
        adapter->stats.illerrc += IXGBE_READ_REG(hw, IXGBE_ILLERRC);
@@ -5386,8 +5386,6 @@ ixgbe_update_stats_counters(struct adapt
                missed_rx += mp;
                /* global total per queue */
                adapter->stats.mpc[i] += mp;
-               /* Running comprehensive total for stats display */
-               total_missed_rx += adapter->stats.mpc[i];
                if (hw->mac.type == ixgbe_mac_82598EB) {
                        adapter->stats.rnbc[i] +=
                            IXGBE_READ_REG(hw, IXGBE_RNBC(i));
@@ -5497,19 +5495,41 @@ ixgbe_update_stats_counters(struct adapt
                adapter->stats.fcoedwrc += IXGBE_READ_REG(hw, IXGBE_FCOEDWRC);
                adapter->stats.fcoedwtc += IXGBE_READ_REG(hw, IXGBE_FCOEDWTC);
        }
+}
+
+static uint64_t
+ixgbe_get_counter(struct ifnet *ifp, ift_counter cnt)
+{
+       struct adapter *adapter;
+       uint64_t rv;
 
-       /* Fill out the OS statistics structure */
-       ifp->if_ipackets = adapter->stats.gprc;
-       ifp->if_opackets = adapter->stats.gptc;
-       ifp->if_ibytes = adapter->stats.gorc;
-       ifp->if_obytes = adapter->stats.gotc;
-       ifp->if_imcasts = adapter->stats.mprc;
-       ifp->if_omcasts = adapter->stats.mptc;
-       ifp->if_collisions = 0;
-
-       /* Rx Errors */
-       ifp->if_iqdrops = total_missed_rx;
-       ifp->if_ierrors = adapter->stats.crcerrs + adapter->stats.rlec;
+       adapter = if_getsoftc(ifp);
+
+       switch (cnt) {
+       case IFCOUNTER_IPACKETS:
+               return (adapter->stats.gprc);
+       case IFCOUNTER_OPACKETS:
+               return (adapter->stats.gptc);
+       case IFCOUNTER_IBYTES:
+               return (adapter->stats.gorc);
+       case IFCOUNTER_OBYTES:
+               return (adapter->stats.gotc);
+       case IFCOUNTER_IMCASTS:
+               return (adapter->stats.mprc);
+       case IFCOUNTER_OMCASTS:
+               return (adapter->stats.mptc);
+       case IFCOUNTER_COLLISIONS:
+               return (0);
+       case IFCOUNTER_IQDROPS:
+               rv = 0;
+               for (int i = 0; i < 8; i++)
+                       rv += adapter->stats.mpc[i];
+               return (rv);
+       case IFCOUNTER_IERRORS:
+               return (adapter->stats.crcerrs + adapter->stats.rlec);
+       default:
+               return (if_get_counter_default(ifp, cnt));
+       }
 }
 
 /** ixgbe_sysctl_tdh_handler - Handler function
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to