diff options
author | Thadeu Lima de Souza Cascardo <cascardo@redhat.com> | 2016-09-15 19:11:52 -0300 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-09-18 22:14:01 -0400 |
commit | 40773966ccf1985a1b2bb570a03cbeaf1cbd4e00 (patch) | |
tree | f94c6d8663b6e6131e6c06fde5849b719e7d3e2a /net/openvswitch/flow.c | |
parent | 829ff34868075ad57822783718de64acff4df303 (diff) | |
download | linux-40773966ccf1985a1b2bb570a03cbeaf1cbd4e00.tar.gz linux-40773966ccf1985a1b2bb570a03cbeaf1cbd4e00.tar.bz2 linux-40773966ccf1985a1b2bb570a03cbeaf1cbd4e00.zip |
openvswitch: fix flow stats accounting when node 0 is not possible
On a system with only node 1 as possible, all statistics is going to be
accounted on node 0 as it will have a single writer.
However, when getting and clearing the statistics, node 0 is not going
to be considered, as it's not a possible node.
Tested that statistics are not zero on a system with only node 1
possible. Also compile-tested with CONFIG_NUMA off.
Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@redhat.com>
Acked-by: Pravin B Shelar <pshelar@ovn.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/openvswitch/flow.c')
-rw-r--r-- | net/openvswitch/flow.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/net/openvswitch/flow.c b/net/openvswitch/flow.c index 1240ae3b88d2..5b80612df182 100644 --- a/net/openvswitch/flow.c +++ b/net/openvswitch/flow.c @@ -142,7 +142,8 @@ void ovs_flow_stats_get(const struct sw_flow *flow, *tcp_flags = 0; memset(ovs_stats, 0, sizeof(*ovs_stats)); - for_each_node(node) { + /* We open code this to make sure node 0 is always considered */ + for (node = 0; node < MAX_NUMNODES; node = next_node(node, node_possible_map)) { struct flow_stats *stats = rcu_dereference_ovsl(flow->stats[node]); if (stats) { @@ -165,7 +166,8 @@ void ovs_flow_stats_clear(struct sw_flow *flow) { int node; - for_each_node(node) { + /* We open code this to make sure node 0 is always considered */ + for (node = 0; node < MAX_NUMNODES; node = next_node(node, node_possible_map)) { struct flow_stats *stats = ovsl_dereference(flow->stats[node]); if (stats) { |