netfilter: flowtable: add counter support in HW offload
authorwenxu <wenxu@ucloud.cn>
Sat, 28 Mar 2020 00:57:54 +0000 (08:57 +0800)
committerPablo Neira Ayuso <pablo@netfilter.org>
Mon, 30 Mar 2020 00:05:40 +0000 (02:05 +0200)
Store the conntrack counters to the conntrack entry in the
HW flowtable offload.

Signed-off-by: wenxu <wenxu@ucloud.cn>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nf_flow_table_offload.c

index a9b3b88bd0f10661f4fe1da50748a5539688d058..d9547c3d1b85028d633a809e70310870880ae3b8 100644 (file)
@@ -9,6 +9,7 @@
 #include <net/netfilter/nf_flow_table.h>
 #include <net/netfilter/nf_tables.h>
 #include <net/netfilter/nf_conntrack.h>
+#include <net/netfilter/nf_conntrack_acct.h>
 #include <net/netfilter/nf_conntrack_core.h>
 #include <net/netfilter/nf_conntrack_tuple.h>
 
@@ -783,6 +784,17 @@ static void flow_offload_work_stats(struct flow_offload_work *offload)
        lastused = max_t(u64, stats[0].lastused, stats[1].lastused);
        offload->flow->timeout = max_t(u64, offload->flow->timeout,
                                       lastused + NF_FLOW_TIMEOUT);
+
+       if (offload->flowtable->flags & NF_FLOWTABLE_COUNTER) {
+               if (stats[0].pkts)
+                       nf_ct_acct_add(offload->flow->ct,
+                                      FLOW_OFFLOAD_DIR_ORIGINAL,
+                                      stats[0].pkts, stats[0].bytes);
+               if (stats[1].pkts)
+                       nf_ct_acct_add(offload->flow->ct,
+                                      FLOW_OFFLOAD_DIR_REPLY,
+                                      stats[1].pkts, stats[1].bytes);
+       }
 }
 
 static void flow_offload_work_handler(struct work_struct *work)