diff options
author | wenxu <wenxu@ucloud.cn> | 2021-03-17 12:02:43 +0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2021-03-17 11:56:25 -0700 |
commit | afa536d8405a9ca36e45ba035554afbb8da27b82 (patch) | |
tree | bf491e264711d7d3ff00d72e36237d1e8ab0e792 /lib/mpi/mpi-mod.c | |
parent | d2c21422323b06938b3c070361dc544f047489d7 (diff) |
net/sched: cls_flower: fix only mask bit check in the validate_ct_state
The ct_state validate should not only check the mask bit and also
check mask_bit & key_bit..
For the +new+est case example, The 'new' and 'est' bits should be
set in both state_mask and state flags. Or the -new-est case also
will be reject by kernel.
When Openvswitch with two flows
ct_state=+trk+new,action=commit,forward
ct_state=+trk+est,action=forward
A packet go through the kernel and the contrack state is invalid,
The ct_state will be +trk-inv. Upcall to the ovs-vswitchd, the
finally dp action will be drop with -new-est+trk.
Fixes: 1bcc51ac0731 ("net/sched: cls_flower: Reject invalid ct_state flags rules")
Fixes: 3aed8b63336c ("net/sched: cls_flower: validate ct_state for invalid and reply flags")
Signed-off-by: wenxu <wenxu@ucloud.cn>
Reviewed-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'lib/mpi/mpi-mod.c')
0 files changed, 0 insertions, 0 deletions