diff options
author | Yanguo Li <yanguo.li@corigine.com> | 2023-10-09 13:21:55 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2023-10-11 10:34:38 +0100 |
commit | 14690995c14109852c7ba6e316045c02e4254272 (patch) | |
tree | 8e6a8cc5ed7687fa3dbada95faef3400303c212f /net/smc/smc_stats.h | |
parent | 8f8abb863fa5a4cc18955c6a0e17af0ded3e4a76 (diff) |
nfp: flower: avoid rmmod nfp crash issues
When there are CT table entries, and you rmmod nfp, the following
events can happen:
task1:
nfp_net_pci_remove
↓
nfp_flower_stop->(asynchronous)tcf_ct_flow_table_cleanup_work(3)
↓
nfp_zone_table_entry_destroy(1)
task2:
nfp_fl_ct_handle_nft_flow(2)
When the execution order is (1)->(2)->(3), it will crash. Therefore, in
the function nfp_fl_ct_del_flow, nf_flow_table_offload_del_cb needs to
be executed synchronously.
At the same time, in order to solve the deadlock problem and the problem
of rtnl_lock sometimes failing, replace rtnl_lock with the private
nfp_fl_lock.
Fixes: 7cc93d888df7 ("nfp: flower-ct: remove callback delete deadlock")
Cc: stable@vger.kernel.org
Signed-off-by: Yanguo Li <yanguo.li@corigine.com>
Signed-off-by: Louis Peens <louis.peens@corigine.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/smc/smc_stats.h')
0 files changed, 0 insertions, 0 deletions