[Intel-wired-lan] [Patch 1/2] iavf: Fix panic in iavf_remove
Nguyen, Anthony L
anthony.l.nguyen at intel.com
Mon Dec 13 18:26:38 UTC 2021
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.
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