Patch "idpf: disable local BH when scheduling napi for marker packets" has been added to the 6.7-stable tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This is a note to let you know that I've just added the patch titled

    idpf: disable local BH when scheduling napi for marker packets

to the 6.7-stable tree which can be found at:
    http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary

The filename of the patch is:
     idpf-disable-local-bh-when-scheduling-napi-for-marke.patch
and it can be found in the queue-6.7 subdirectory.

If you, or anyone else, feels it should not be added to the stable tree,
please let <stable@xxxxxxxxxxxxxxx> know about it.



commit 9f585b98c5fb027c982c9e5b9c67aa5b0288446f
Author: Emil Tantilov <emil.s.tantilov@xxxxxxxxx>
Date:   Wed Feb 7 16:42:43 2024 -0800

    idpf: disable local BH when scheduling napi for marker packets
    
    [ Upstream commit 330068589389ccae3452db15ecacc3e147ac9c1c ]
    
    Fix softirq's not being handled during napi_schedule() call when
    receiving marker packets for queue disable by disabling local bottom
    half.
    
    The issue can be seen on ifdown:
    NOHZ tick-stop error: Non-RCU local softirq work is pending, handler #08!!!
    
    Using ftrace to catch the failing scenario:
    ifconfig   [003] d.... 22739.830624: softirq_raise: vec=3 [action=NET_RX]
    <idle>-0   [003] ..s.. 22739.831357: softirq_entry: vec=3 [action=NET_RX]
    
    No interrupt and CPU is idle.
    
    After the patch when disabling local BH before calling napi_schedule:
    ifconfig   [003] d.... 22993.928336: softirq_raise: vec=3 [action=NET_RX]
    ifconfig   [003] ..s1. 22993.928337: softirq_entry: vec=3 [action=NET_RX]
    
    Fixes: c2d548cad150 ("idpf: add TX splitq napi poll support")
    Reviewed-by: Jesse Brandeburg <jesse.brandeburg@xxxxxxxxx>
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@xxxxxxxxx>
    Signed-off-by: Emil Tantilov <emil.s.tantilov@xxxxxxxxx>
    Signed-off-by: Alan Brady <alan.brady@xxxxxxxxx>
    Reviewed-by: Simon Horman <horms@xxxxxxxxxx>
    Tested-by: Krishneil Singh <krishneil.k.singh@xxxxxxxxx>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@xxxxxxxxx>
    Signed-off-by: Sasha Levin <sashal@xxxxxxxxxx>

diff --git a/drivers/net/ethernet/intel/idpf/idpf_virtchnl.c b/drivers/net/ethernet/intel/idpf/idpf_virtchnl.c
index 2c1b051fdc0d4..b0c52f17848f6 100644
--- a/drivers/net/ethernet/intel/idpf/idpf_virtchnl.c
+++ b/drivers/net/ethernet/intel/idpf/idpf_virtchnl.c
@@ -2087,8 +2087,10 @@ int idpf_send_disable_queues_msg(struct idpf_vport *vport)
 		set_bit(__IDPF_Q_POLL_MODE, vport->txqs[i]->flags);
 
 	/* schedule the napi to receive all the marker packets */
+	local_bh_disable();
 	for (i = 0; i < vport->num_q_vectors; i++)
 		napi_schedule(&vport->q_vectors[i].napi);
+	local_bh_enable();
 
 	return idpf_wait_for_marker_event(vport);
 }




[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux