[Intel-wired-lan] [Patch 1/2] iavf: Fix panic in iavf_remove

Ken Cox jkc at redhat.com
Tue Dec 14 13:18:57 UTC 2021



On 12/13/21 12:26, Nguyen, Anthony L wrote:
> On Wed, 2021-12-08 at 04:21 -0600, Ken Cox wrote:
>> It's possible for the client_task to get scheduled by the watchdog
>> after cancel_delayed_work_sync(&adapter->client_task);  This can
>> cause
>> a panic because free_netdev() is called with the client_task still
>> queued
>> on the work queue.
>>
>> The stack backtrace usually looks similar to:
>>
>> [  121.272963] Workqueue:  0x0 (iavf)
>> [  121.272969] RIP: 0010:__list_del_entry_valid.cold.1+0x20/0x4c
>> ...
>> [  121.272980] Call Trace:
>> [  121.272985]  move_linked_works+0x49/0xa0
>> [  121.272988]  pwq_activate_delayed_work+0x43/0x100
>> [  121.272991]  pwq_dec_nr_in_flight+0x5d/0x90
>> [  121.272993]  worker_thread+0x30/0x370
>> [  121.272995]  ? process_one_work+0x420/0x420
>> [  121.272998]  kthread+0x15d/0x180
>> [  121.273000]  ? __kthread_parkme+0xa0/0xa0
>> [  121.273003]  ret_from_fork+0x1f/0x40
>>
>> Signed-off-by: Ken Cox <jkc at redhat.com>
>> ---
>>   drivers/net/ethernet/intel/iavf/iavf_main.c | 2 +-
>>   1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/drivers/net/ethernet/intel/iavf/iavf_main.c
>> b/drivers/net/ethernet/intel/iavf/iavf_main.c
>> index 6c2afbc8acbcd..63eec7edbf60a 100644
>> --- a/drivers/net/ethernet/intel/iavf/iavf_main.c
>> +++ b/drivers/net/ethernet/intel/iavf/iavf_main.c
>> @@ -3940,7 +3940,6 @@ static void iavf_remove(struct pci_dev *pdev)
>>          set_bit(__IAVF_IN_REMOVE_TASK, &adapter->crit_section);
>>          cancel_delayed_work_sync(&adapter->init_task);
>>          cancel_work_sync(&adapter->reset_task);
>> -       cancel_delayed_work_sync(&adapter->client_task);
>>          if (adapter->netdev_registered) {
>>                  unregister_netdev(netdev);
>>                  adapter->netdev_registered = false;
>> @@ -3974,6 +3973,7 @@ static void iavf_remove(struct pci_dev *pdev)
>>          iavf_free_q_vectors(adapter);
>>   
>>          cancel_delayed_work_sync(&adapter->watchdog_task);
>> +       cancel_delayed_work_sync(&adapter->client_task);
>>   
>>          cancel_work_sync(&adapter->adminq_task);
>>   
> 
> Hi Ken,
> 
> What tree is this patch based on? This doesn't apply to either of the
> IWL trees or the netdev trees.
Sorry, I was in the wrong branch when I generated these patches.  Please 
disregard.  I will re-evaluate and resend if necessary.

> 
> The ordering looks correct on the kernel tree with watchdog_task being
> cancelled before the client_task [1]. However, we do have an extra
> 'cancel_delayed_work_sync(&adapter->watchdog_task)'. I'll get a patch
> together to remove the extra one.
> 
> Thanks,
> Tony
> 
> 
> [1] https://elixir.bootlin.com/linux/v5.16-
> rc5/source/drivers/net/ethernet/intel/iavf/iavf_main.c#3979
> 



More information about the Intel-wired-lan mailing list