sfc: Only cancel the PPS workqueue if it exists
authorMartin Habets <mhabets@solarflare.com>
Thu, 21 Nov 2019 17:52:15 +0000 (17:52 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 21 Nov 2019 20:06:06 +0000 (12:06 -0800)
The workqueue only exists for the primary PF. For other functions
we hit a WARN_ON in kernel/workqueue.c.

Fixes: 7c236c43b838 ("sfc: Add support for IEEE-1588 PTP")
Signed-off-by: Martin Habets <mhabets@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/sfc/ptp.c

index 02ed6d1b716c254d807f6d0ea153ee8f89b4a974..af15a737c675611919a65d5394447900dbac3f26 100644 (file)
@@ -1531,7 +1531,8 @@ void efx_ptp_remove(struct efx_nic *efx)
        (void)efx_ptp_disable(efx);
 
        cancel_work_sync(&efx->ptp_data->work);
-       cancel_work_sync(&efx->ptp_data->pps_work);
+       if (efx->ptp_data->pps_workwq)
+               cancel_work_sync(&efx->ptp_data->pps_work);
 
        skb_queue_purge(&efx->ptp_data->rxq);
        skb_queue_purge(&efx->ptp_data->txq);