This was required for old compatibility code. Now vswitchd
has dropped it. This support was always deprecated, so
finally removing it.

Signed-off-by: Pravin B Shelar <pshe...@nicira.com>
---
 datapath/datapath.c |  8 --------
 datapath/vport.c    | 46 ++++++++++++++--------------------------------
 datapath/vport.h    |  6 +-----
 3 files changed, 15 insertions(+), 45 deletions(-)

diff --git a/datapath/datapath.c b/datapath/datapath.c
index ed9d7bd..3e5ff72 100644
--- a/datapath/datapath.c
+++ b/datapath/datapath.c
@@ -1831,10 +1831,6 @@ static int ovs_vport_cmd_new(struct sk_buff *skb, struct 
genl_info *info)
        if (IS_ERR(vport))
                goto exit_unlock_free;
 
-       err = 0;
-       if (a[OVS_VPORT_ATTR_STATS])
-               ovs_vport_set_stats(vport, nla_data(a[OVS_VPORT_ATTR_STATS]));
-
        err = ovs_vport_cmd_fill_info(vport, reply, info->snd_portid,
                                      info->snd_seq, 0, OVS_VPORT_CMD_NEW);
        BUG_ON(err < 0);
@@ -1878,10 +1874,6 @@ static int ovs_vport_cmd_set(struct sk_buff *skb, struct 
genl_info *info)
                        goto exit_unlock_free;
        }
 
-       if (a[OVS_VPORT_ATTR_STATS])
-               ovs_vport_set_stats(vport, nla_data(a[OVS_VPORT_ATTR_STATS]));
-
-
        if (a[OVS_VPORT_ATTR_UPCALL_PID]) {
                err = ovs_vport_set_upcall_portids(vport,
                                                   
a[OVS_VPORT_ATTR_UPCALL_PID]);
diff --git a/datapath/vport.c b/datapath/vport.c
index cf7f917..f7e66d1 100644
--- a/datapath/vport.c
+++ b/datapath/vport.c
@@ -243,26 +243,6 @@ void ovs_vport_del(struct vport *vport)
 }
 
 /**
- *     ovs_vport_set_stats - sets offset device stats
- *
- * @vport: vport on which to set stats
- * @stats: stats to set
- *
- * Provides a set of transmit, receive, and error stats to be added as an
- * offset to the collected data when stats are retrieved.  Some devices may not
- * support setting the stats, in which case the result will always be
- * -EOPNOTSUPP.
- *
- * Must be called with ovs_mutex.
- */
-void ovs_vport_set_stats(struct vport *vport, struct ovs_vport_stats *stats)
-{
-       spin_lock_bh(&vport->stats_lock);
-       vport->offset_stats = *stats;
-       spin_unlock_bh(&vport->stats_lock);
-}
-
-/**
  *     ovs_vport_get_stats - retrieve device stats
  *
  * @vport: vport from which to retrieve the stats
@@ -276,25 +256,27 @@ void ovs_vport_get_stats(struct vport *vport, struct 
ovs_vport_stats *stats)
 {
        int i;
 
-       /* We potentially have 3 sources of stats that need to be
+       stats->rx_bytes         = 0;
+       stats->rx_packets       = 0;
+       stats->tx_bytes         = 0;
+       stats->tx_packets       = 0;
+
+       /* We potentially have two surces of stats that need to be
         * combined: those we have collected (split into err_stats and
-        * percpu_stats), offset_stats from set_stats(), and device
-        * error stats from netdev->get_stats() (for errors that happen
-        * downstream and therefore aren't reported through our
-        * vport_record_error() function).
-        * Stats from first two sources are merged and reported by ovs over
+        * percpu_stats), and device error stats from netdev->get_stats()
+        * (for errors that happen downstream and therefore aren't
+        * reported through our vport_record_error() function).
+        * Stats from first source are reported by ovs over
         * OVS_VPORT_ATTR_STATS.
         * netdev-stats can be directly read over netlink-ioctl.
         */
 
        spin_lock_bh(&vport->stats_lock);
 
-       *stats = vport->offset_stats;
-
-       stats->rx_errors        += vport->err_stats.rx_errors;
-       stats->tx_errors        += vport->err_stats.tx_errors;
-       stats->tx_dropped       += vport->err_stats.tx_dropped;
-       stats->rx_dropped       += vport->err_stats.rx_dropped;
+       stats->rx_errors        = vport->err_stats.rx_errors;
+       stats->tx_errors        = vport->err_stats.tx_errors;
+       stats->tx_dropped       = vport->err_stats.tx_dropped;
+       stats->rx_dropped       = vport->err_stats.rx_dropped;
 
        spin_unlock_bh(&vport->stats_lock);
 
diff --git a/datapath/vport.h b/datapath/vport.h
index 8c3da05..07a9d5d 100644
--- a/datapath/vport.h
+++ b/datapath/vport.h
@@ -45,7 +45,6 @@ void ovs_vport_del(struct vport *);
 
 struct vport *ovs_vport_locate(struct net *net, const char *name);
 
-void ovs_vport_set_stats(struct vport *, struct ovs_vport_stats *);
 void ovs_vport_get_stats(struct vport *, struct ovs_vport_stats *);
 
 int ovs_vport_set_options(struct vport *, struct nlattr *options);
@@ -101,10 +100,8 @@ struct vport_portids {
  * @dp_hash_node: Element in @datapath->ports hash table in datapath.c.
  * @ops: Class structure.
  * @percpu_stats: Points to per-CPU statistics used and maintained by vport
- * @stats_lock: Protects @err_stats and @offset_stats.
+ * @stats_lock: Protects @err_stats.
  * @err_stats: Points to error statistics used and maintained by vport
- * @offset_stats: Added to actual statistics as a sop to compatibility with
- * XAPI for Citrix XenServer.  Deprecated.
  */
 struct vport {
        struct rcu_head rcu;
@@ -120,7 +117,6 @@ struct vport {
 
        spinlock_t stats_lock;
        struct vport_err_stats err_stats;
-       struct ovs_vport_stats offset_stats;
 };
 
 /**
-- 
1.9.3

_______________________________________________
dev mailing list
dev@openvswitch.org
http://openvswitch.org/mailman/listinfo/dev

Reply via email to