Commit 2c4b58dc authored by Petr Machata's avatar Petr Machata Committed by David S. Miller

net: sched: Fix hw_stats_type setting in pedit loop

In the commit referenced below, hw_stats_type of an entry is set for every
entry that corresponds to a pedit action. However, the assignment is only
done after the entry pointer is bumped, and therefore could overwrite
memory outside of the entries array.

The reason for this positioning may have been that the current entry's
hw_stats_type is already set above, before the action-type dispatch.
However, if there are no more actions, the assignment is wrong. And if
there are, the next round of the for_each_action loop will make the
assignment before the action-type dispatch anyway.

Therefore fix this issue by simply reordering the two lines.

Fixes: 74522e7b ("net: sched: set the hw_stats_type in pedit loop")
Signed-off-by: default avatarPetr Machata <petrm@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent dd13f4df
...@@ -3613,8 +3613,8 @@ int tc_setup_flow_action(struct flow_action *flow_action, ...@@ -3613,8 +3613,8 @@ int tc_setup_flow_action(struct flow_action *flow_action,
entry->mangle.mask = tcf_pedit_mask(act, k); entry->mangle.mask = tcf_pedit_mask(act, k);
entry->mangle.val = tcf_pedit_val(act, k); entry->mangle.val = tcf_pedit_val(act, k);
entry->mangle.offset = tcf_pedit_offset(act, k); entry->mangle.offset = tcf_pedit_offset(act, k);
entry = &flow_action->entries[++j];
entry->hw_stats_type = act->hw_stats_type; entry->hw_stats_type = act->hw_stats_type;
entry = &flow_action->entries[++j];
} }
} else if (is_tcf_csum(act)) { } else if (is_tcf_csum(act)) {
entry->id = FLOW_ACTION_CSUM; entry->id = FLOW_ACTION_CSUM;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment