igc: Complete to commit Add basic skeleton for PTP
authorSasha Neftin <sasha.neftin@intel.com>
Wed, 22 Jan 2020 09:21:13 +0000 (11:21 +0200)
committerJeff Kirsher <jeffrey.t.kirsher@intel.com>
Thu, 20 Feb 2020 00:51:28 +0000 (16:51 -0800)
commit 5f2958052c58 ("igc: Add basic skeleton for PTP") added basic
support for PTP, what's missing is support for suspending.
Legacy power management has been added. Now we can add
the suspend method to the igc_shutdown.
By cleaning the runtime storage for timestamp this avoids a possible
invalid memory access when the system comes back from suspend state.

Signed-off-by: Sasha Neftin <sasha.neftin@intel.com>
Tested-by: Aaron Brown <aaron.f.brown@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
drivers/net/ethernet/intel/igc/igc.h
drivers/net/ethernet/intel/igc/igc_main.c
drivers/net/ethernet/intel/igc/igc_ptp.c

index cb1362188c2aa3a8e54b0a23747c3ca68a1e3844..5e9c2dd8b8e448e8fa4e76de82fa27b12335429d 100644 (file)
@@ -556,6 +556,7 @@ int igc_erase_filter(struct igc_adapter *adapter,
 
 void igc_ptp_init(struct igc_adapter *adapter);
 void igc_ptp_reset(struct igc_adapter *adapter);
+void igc_ptp_suspend(struct igc_adapter *adapter);
 void igc_ptp_stop(struct igc_adapter *adapter);
 void igc_ptp_rx_rgtstamp(struct igc_q_vector *q_vector, struct sk_buff *skb);
 void igc_ptp_rx_pktstamp(struct igc_q_vector *q_vector, void *va,
index 3c748d23942377ed34cf46a8830d4c2f18073364..b805323e1be6afa1f100f85f60300b15fb128f3c 100644 (file)
@@ -4899,6 +4899,8 @@ static int __igc_shutdown(struct pci_dev *pdev, bool *enable_wake,
        if (netif_running(netdev))
                __igc_close(netdev, true);
 
+       igc_ptp_suspend(adapter);
+
        igc_clear_interrupt_scheme(adapter);
        rtnl_unlock();
 
index 389a969fe5f4da6d9bdf29dc9b9ac6b1b4182eba..f99c514ad0f47afb3aae83d494fb8cde44cf3d73 100644 (file)
@@ -641,7 +641,7 @@ void igc_ptp_init(struct igc_adapter *adapter)
  * This function stops the overflow check work and PTP Tx timestamp work, and
  * will prepare the device for OS suspend.
  */
-static void igc_ptp_suspend(struct igc_adapter *adapter)
+void igc_ptp_suspend(struct igc_adapter *adapter)
 {
        if (!(adapter->ptp_flags & IGC_PTP_ENABLED))
                return;