X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=secchan%2Fofproto.c;h=94c4bfe3fab19e3402baf4c7e730b91d49f53102;hb=cdd35cff225bf39767ea9e2e535cf2940b0e5127;hp=9836e0f8306306f8dcd3d97cabeb5d54f1173d36;hpb=6cfaf517a342e23775b33cc1f67f58554125fac3;p=openvswitch diff --git a/secchan/ofproto.c b/secchan/ofproto.c index 9836e0f8..94c4bfe3 100644 --- a/secchan/ofproto.c +++ b/secchan/ofproto.c @@ -2420,19 +2420,22 @@ query_stats(struct ofproto *p, struct rule *rule, struct odp_flow *odp_flows; size_t n_odp_flows; + packet_count = rule->packet_count; + byte_count = rule->byte_count; + n_odp_flows = rule->cr.wc.wildcards ? list_size(&rule->list) : 1; odp_flows = xcalloc(1, n_odp_flows * sizeof *odp_flows); if (rule->cr.wc.wildcards) { size_t i = 0; LIST_FOR_EACH (subrule, struct rule, list, &rule->list) { odp_flows[i++].key = subrule->cr.flow; + packet_count += subrule->packet_count; + byte_count += subrule->byte_count; } } else { odp_flows[0].key = rule->cr.flow; } - packet_count = rule->packet_count; - byte_count = rule->byte_count; if (!dpif_flow_get_multiple(&p->dpif, odp_flows, n_odp_flows)) { size_t i; for (i = 0; i < n_odp_flows; i++) {