Skip to content

Commit d8214d0

Browse files
Michael Chankuba-moo
authored andcommitted
bnxt_en: Fix RCU locking for ntuple filters in bnxt_rx_flow_steer()
Similar to the previous patch, RCU locking was released too early in bnxt_rx_flow_steer(). Fix it to unlock after reading fltr->base.sw_id to guarantee that fltr won't be freed while we are still reading it. Fixes: cb5bdd2 ("bnxt_en: Add bnxt_lookup_ntp_filter_from_idx() function") Reported-by: Simon Horman <horms@kernel.org> Link: https://lore.kernel.org/netdev/20231225165653.GH5962@kernel.org/ Signed-off-by: Michael Chan <michael.chan@broadcom.com> Reviewed-by: Simon Horman <horms@kernel.org> Link: https://lore.kernel.org/r/20240105235439.28282-4-michael.chan@broadcom.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
1 parent fd77697 commit d8214d0

1 file changed

Lines changed: 1 addition & 1 deletion

File tree

  • drivers/net/ethernet/broadcom/bnxt

drivers/net/ethernet/broadcom/bnxt/bnxt.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14020,8 +14020,8 @@ static int bnxt_rx_flow_steer(struct net_device *dev, const struct sk_buff *skb,
1402014020
rcu_read_lock();
1402114021
fltr = bnxt_lookup_ntp_filter_from_idx(bp, new_fltr, idx);
1402214022
if (fltr) {
14023-
rcu_read_unlock();
1402414023
rc = fltr->base.sw_id;
14024+
rcu_read_unlock();
1402514025
goto err_free;
1402614026
}
1402714027
rcu_read_unlock();

0 commit comments

Comments
 (0)