diff options
| author | Michael Chan <michael.chan@broadcom.com> | 2024-11-22 14:45:46 -0800 | 
|---|---|---|
| committer | Paolo Abeni <pabeni@redhat.com> | 2024-11-26 15:29:31 +0100 | 
| commit | 3661c05c54e8db7064aa96a0774654740974dffc (patch) | |
| tree | 191109e525bc600dd4d68ea4c234698d31e9e106 /drivers/platform/surface/surface_aggregator_tabletsw.c | |
| parent | 1e9614cd956268e10a669c0593e7e54d03d0c087 (diff) | |
bnxt_en: Unregister PTP during PCI shutdown and suspend
If we go through the PCI shutdown or suspend path, we shutdown the
NIC but PTP remains registered.  If the kernel continues to run for
a little bit, the periodic PTP .do_aux_work() function may be called
and it will read the PHC from the BAR register.  Since the device
has already been disabled, it will cause a PCIe completion timeout.
Fix it by calling bnxt_ptp_clear() in the PCI shutdown/suspend
handlers.  bnxt_ptp_clear() will unregister from PTP and
.do_aux_work() will be canceled.
In bnxt_resume(), we need to re-initialize PTP.
Fixes: a521c8a01d26 ("bnxt_en: Move bnxt_ptp_init() from bnxt_open() back to bnxt_init_one()")
Cc: Richard Cochran <richardcochran@gmail.com>
Reviewed-by: Somnath Kotur <somnath.kotur@broadcom.com>
Reviewed-by: Pavan Chebbi <pavan.chebbi@broadcom.com>
Reviewed-by: Kalesh AP <kalesh-anakkur.purayil@broadcom.com>
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Diffstat (limited to 'drivers/platform/surface/surface_aggregator_tabletsw.c')
0 files changed, 0 insertions, 0 deletions
