Skip to content

Commit adde556

Browse files
committed
Merge branch 'Implement-stats_update-callback-for-pedit-and-skbedit'
Petr Machata says: ==================== Implement stats_update callback for pedit and skbedit The stats_update callback is used for adding HW counters to the SW ones. Both skbedit and pedit actions are actually recognized by flow_offload.h, but do not implement these callbacks. As a consequence, the reported values are only the SW ones, even where there is a HW counter available. Patch #1 adds the callback to action skbedit, patch #2 adds it to action pedit. Patch #3 tweaks an skbedit selftest with a check that would have caught this problem. The pedit test is not likewise tweaked, because the iproute2 pedit action currently does not support JSON dumping. This will be addressed later. ==================== Signed-off-by: David S. Miller <[email protected]>
2 parents 92b7e62 + 2a0b130 commit adde556

File tree

3 files changed

+29
-2
lines changed

3 files changed

+29
-2
lines changed

net/sched/act_pedit.c

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -409,6 +409,16 @@ static int tcf_pedit_act(struct sk_buff *skb, const struct tc_action *a,
409409
return p->tcf_action;
410410
}
411411

412+
static void tcf_pedit_stats_update(struct tc_action *a, u64 bytes, u32 packets,
413+
u64 lastuse, bool hw)
414+
{
415+
struct tcf_pedit *d = to_pedit(a);
416+
struct tcf_t *tm = &d->tcf_tm;
417+
418+
tcf_action_update_stats(a, bytes, packets, false, hw);
419+
tm->lastuse = max_t(u64, tm->lastuse, lastuse);
420+
}
421+
412422
static int tcf_pedit_dump(struct sk_buff *skb, struct tc_action *a,
413423
int bind, int ref)
414424
{
@@ -485,6 +495,7 @@ static struct tc_action_ops act_pedit_ops = {
485495
.id = TCA_ID_PEDIT,
486496
.owner = THIS_MODULE,
487497
.act = tcf_pedit_act,
498+
.stats_update = tcf_pedit_stats_update,
488499
.dump = tcf_pedit_dump,
489500
.cleanup = tcf_pedit_cleanup,
490501
.init = tcf_pedit_init,

net/sched/act_skbedit.c

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -73,6 +73,16 @@ static int tcf_skbedit_act(struct sk_buff *skb, const struct tc_action *a,
7373
return TC_ACT_SHOT;
7474
}
7575

76+
static void tcf_skbedit_stats_update(struct tc_action *a, u64 bytes,
77+
u32 packets, u64 lastuse, bool hw)
78+
{
79+
struct tcf_skbedit *d = to_skbedit(a);
80+
struct tcf_t *tm = &d->tcf_tm;
81+
82+
tcf_action_update_stats(a, bytes, packets, false, hw);
83+
tm->lastuse = max_t(u64, tm->lastuse, lastuse);
84+
}
85+
7686
static const struct nla_policy skbedit_policy[TCA_SKBEDIT_MAX + 1] = {
7787
[TCA_SKBEDIT_PARMS] = { .len = sizeof(struct tc_skbedit) },
7888
[TCA_SKBEDIT_PRIORITY] = { .len = sizeof(u32) },
@@ -323,6 +333,7 @@ static struct tc_action_ops act_skbedit_ops = {
323333
.id = TCA_ID_SKBEDIT,
324334
.owner = THIS_MODULE,
325335
.act = tcf_skbedit_act,
336+
.stats_update = tcf_skbedit_stats_update,
326337
.dump = tcf_skbedit_dump,
327338
.init = tcf_skbedit_init,
328339
.cleanup = tcf_skbedit_cleanup,

tools/testing/selftests/net/forwarding/skbedit_priority.sh

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -120,14 +120,19 @@ test_skbedit_priority_one()
120120
flower action skbedit priority $prio
121121

122122
local pkt0=$(qdisc_parent_stats_get $swp2 $classid .packets)
123+
local pkt2=$(tc_rule_handle_stats_get "$locus" 101)
123124
$MZ $h1 -t udp "sp=54321,dp=12345" -c 10 -d 20msec -p 100 \
124125
-a own -b $h2mac -A 192.0.2.1 -B 192.0.2.2 -q
126+
125127
local pkt1
126128
pkt1=$(busywait "$HIT_TIMEOUT" until_counter_is ">= $((pkt0 + 10))" \
127129
qdisc_parent_stats_get $swp2 $classid .packets)
130+
check_err $? "Expected to get 10 packets on class $classid, but got $((pkt1 - pkt0))."
131+
132+
local pkt3=$(tc_rule_handle_stats_get "$locus" 101)
133+
((pkt3 >= pkt2 + 10))
134+
check_err $? "Expected to get 10 packets on skbedit rule but got $((pkt3 - pkt2))."
128135

129-
check_err $? "Expected to get 10 packets on class $classid, but got
130-
$((pkt1 - pkt0))."
131136
log_test "$locus skbedit priority $prio -> classid $classid"
132137

133138
tc filter del $locus pref 1

0 commit comments

Comments
 (0)