net/sched: optimize action stats api calls
authorOz Shlomo <ozsh@nvidia.com>
Sun, 12 Feb 2023 13:25:12 +0000 (15:25 +0200)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 14 Feb 2023 10:00:00 +0000 (11:00 +0100)
Currently the hw action stats update is called from tcf_exts_hw_stats_update,
when a tc filter is dumped, and from tcf_action_copy_stats, when a hw
action is dumped.
However, the tcf_action_copy_stats is also called from tcf_action_dump.
As such, the hw action stats update cb is called 3 times for every
tc flower filter dump.

Move the tc action hw stats update from tcf_action_copy_stats to
tcf_dump_walker to update the hw action stats when tc action is dumped.

Signed-off-by: Oz Shlomo <ozsh@nvidia.com>
Reviewed-by: Simon Horman <simon.horman@corigine.com>
Reviewed-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Acked-by: Jamal Hadi Salim <jhs@mojatatu.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
net/sched/act_api.c

index cd09ef49df22d5c75ae22b4394c994f40e0e2fcc..f4fa6d7340f8d91e1e47a5da804f361967c3a612 100644 (file)
@@ -539,6 +539,8 @@ static int tcf_dump_walker(struct tcf_idrinfo *idrinfo, struct sk_buff *skb,
                               (unsigned long)p->tcfa_tm.lastuse))
                        continue;
 
+               tcf_action_update_hw_stats(p);
+
                nest = nla_nest_start_noflag(skb, n_i);
                if (!nest) {
                        index--;
@@ -1539,9 +1541,6 @@ int tcf_action_copy_stats(struct sk_buff *skb, struct tc_action *p,
        if (p == NULL)
                goto errout;
 
-       /* update hw stats for this action */
-       tcf_action_update_hw_stats(p);
-
        /* compat_mode being true specifies a call that is supposed
         * to add additional backward compatibility statistic TLVs.
         */