net/sched: Fix update of lastuse in act modules implementing stats_update
We need to update lastuse to to the most updated value between what is already set and the new value. If HW matching fails, i.e. because of an issue, the stats are not updated but it could be that software did match and updated lastuse. Fixes:5712bf9c5c
("net/sched: act_mirred: Use passed lastuse argument") Fixes:9fea47d93b
("net/sched: act_gact: Update statistics when offloaded to hardware") Signed-off-by: Roi Dayan <roid@mellanox.com> Reviewed-by: Paul Blakey <paulb@mellanox.com> Acked-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
90045fc9c7
commit
3bb23421a5
|
@ -159,7 +159,7 @@ static void tcf_gact_stats_update(struct tc_action *a, u64 bytes, u32 packets,
|
||||||
if (action == TC_ACT_SHOT)
|
if (action == TC_ACT_SHOT)
|
||||||
this_cpu_ptr(gact->common.cpu_qstats)->drops += packets;
|
this_cpu_ptr(gact->common.cpu_qstats)->drops += packets;
|
||||||
|
|
||||||
tm->lastuse = lastuse;
|
tm->lastuse = max_t(u64, tm->lastuse, lastuse);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tcf_gact_dump(struct sk_buff *skb, struct tc_action *a,
|
static int tcf_gact_dump(struct sk_buff *skb, struct tc_action *a,
|
||||||
|
|
|
@ -239,7 +239,7 @@ static void tcf_stats_update(struct tc_action *a, u64 bytes, u32 packets,
|
||||||
struct tcf_t *tm = &m->tcf_tm;
|
struct tcf_t *tm = &m->tcf_tm;
|
||||||
|
|
||||||
_bstats_cpu_update(this_cpu_ptr(a->cpu_bstats), bytes, packets);
|
_bstats_cpu_update(this_cpu_ptr(a->cpu_bstats), bytes, packets);
|
||||||
tm->lastuse = lastuse;
|
tm->lastuse = max_t(u64, tm->lastuse, lastuse);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tcf_mirred_dump(struct sk_buff *skb, struct tc_action *a, int bind,
|
static int tcf_mirred_dump(struct sk_buff *skb, struct tc_action *a, int bind,
|
||||||
|
|
Loading…
Reference in New Issue