Commit 8594a7f3 authored by Sasha Neftin's avatar Sasha Neftin Committed by Jeff Kirsher

igc: Complete to commit Add legacy power management support

commit 9513d2a5 ("igc: Add legacy power management support")
Add power management resume and schedule suspend requests.
Add power management get and put synchronization.
Signed-off-by: default avatarSasha Neftin <sasha.neftin@intel.com>
Tested-by: default avatarAaron Brown <aaron.f.brown@intel.com>
Signed-off-by: default avatarJeff Kirsher <jeffrey.t.kirsher@intel.com>
parent 38db952b
...@@ -4029,6 +4029,9 @@ static void igc_watchdog_task(struct work_struct *work) ...@@ -4029,6 +4029,9 @@ static void igc_watchdog_task(struct work_struct *work)
} }
} }
if (link) { if (link) {
/* Cancel scheduled suspend requests. */
pm_runtime_resume(netdev->dev.parent);
if (!netif_carrier_ok(netdev)) { if (!netif_carrier_ok(netdev)) {
u32 ctrl; u32 ctrl;
...@@ -4114,6 +4117,8 @@ static void igc_watchdog_task(struct work_struct *work) ...@@ -4114,6 +4117,8 @@ static void igc_watchdog_task(struct work_struct *work)
return; return;
} }
} }
pm_schedule_suspend(netdev->dev.parent,
MSEC_PER_SEC * 5);
/* also check for alternate media here */ /* also check for alternate media here */
} else if (!netif_carrier_ok(netdev) && } else if (!netif_carrier_ok(netdev) &&
...@@ -4337,6 +4342,7 @@ static int igc_request_irq(struct igc_adapter *adapter) ...@@ -4337,6 +4342,7 @@ static int igc_request_irq(struct igc_adapter *adapter)
static int __igc_open(struct net_device *netdev, bool resuming) static int __igc_open(struct net_device *netdev, bool resuming)
{ {
struct igc_adapter *adapter = netdev_priv(netdev); struct igc_adapter *adapter = netdev_priv(netdev);
struct pci_dev *pdev = adapter->pdev;
struct igc_hw *hw = &adapter->hw; struct igc_hw *hw = &adapter->hw;
int err = 0; int err = 0;
int i = 0; int i = 0;
...@@ -4348,6 +4354,9 @@ static int __igc_open(struct net_device *netdev, bool resuming) ...@@ -4348,6 +4354,9 @@ static int __igc_open(struct net_device *netdev, bool resuming)
return -EBUSY; return -EBUSY;
} }
if (!resuming)
pm_runtime_get_sync(&pdev->dev);
netif_carrier_off(netdev); netif_carrier_off(netdev);
/* allocate transmit descriptors */ /* allocate transmit descriptors */
...@@ -4386,6 +4395,9 @@ static int __igc_open(struct net_device *netdev, bool resuming) ...@@ -4386,6 +4395,9 @@ static int __igc_open(struct net_device *netdev, bool resuming)
rd32(IGC_ICR); rd32(IGC_ICR);
igc_irq_enable(adapter); igc_irq_enable(adapter);
if (!resuming)
pm_runtime_put(&pdev->dev);
netif_tx_start_all_queues(netdev); netif_tx_start_all_queues(netdev);
/* start the watchdog. */ /* start the watchdog. */
...@@ -4404,6 +4416,8 @@ static int __igc_open(struct net_device *netdev, bool resuming) ...@@ -4404,6 +4416,8 @@ static int __igc_open(struct net_device *netdev, bool resuming)
igc_free_all_tx_resources(adapter); igc_free_all_tx_resources(adapter);
err_setup_tx: err_setup_tx:
igc_reset(adapter); igc_reset(adapter);
if (!resuming)
pm_runtime_put(&pdev->dev);
return err; return err;
} }
...@@ -4428,9 +4442,13 @@ static int igc_open(struct net_device *netdev) ...@@ -4428,9 +4442,13 @@ static int igc_open(struct net_device *netdev)
static int __igc_close(struct net_device *netdev, bool suspending) static int __igc_close(struct net_device *netdev, bool suspending)
{ {
struct igc_adapter *adapter = netdev_priv(netdev); struct igc_adapter *adapter = netdev_priv(netdev);
struct pci_dev *pdev = adapter->pdev;
WARN_ON(test_bit(__IGC_RESETTING, &adapter->state)); WARN_ON(test_bit(__IGC_RESETTING, &adapter->state));
if (!suspending)
pm_runtime_get_sync(&pdev->dev);
igc_down(adapter); igc_down(adapter);
igc_release_hw_control(adapter); igc_release_hw_control(adapter);
...@@ -4440,6 +4458,9 @@ static int __igc_close(struct net_device *netdev, bool suspending) ...@@ -4440,6 +4458,9 @@ static int __igc_close(struct net_device *netdev, bool suspending)
igc_free_all_tx_resources(adapter); igc_free_all_tx_resources(adapter);
igc_free_all_rx_resources(adapter); igc_free_all_rx_resources(adapter);
if (!suspending)
pm_runtime_put_sync(&pdev->dev);
return 0; return 0;
} }
...@@ -4792,6 +4813,10 @@ static int igc_probe(struct pci_dev *pdev, ...@@ -4792,6 +4813,10 @@ static int igc_probe(struct pci_dev *pdev,
pcie_print_link_status(pdev); pcie_print_link_status(pdev);
netdev_info(netdev, "MAC: %pM\n", netdev->dev_addr); netdev_info(netdev, "MAC: %pM\n", netdev->dev_addr);
dev_pm_set_driver_flags(&pdev->dev, DPM_FLAG_NEVER_SKIP);
pm_runtime_put_noidle(&pdev->dev);
return 0; return 0;
err_register: err_register:
...@@ -4826,6 +4851,8 @@ static void igc_remove(struct pci_dev *pdev) ...@@ -4826,6 +4851,8 @@ static void igc_remove(struct pci_dev *pdev)
struct net_device *netdev = pci_get_drvdata(pdev); struct net_device *netdev = pci_get_drvdata(pdev);
struct igc_adapter *adapter = netdev_priv(netdev); struct igc_adapter *adapter = netdev_priv(netdev);
pm_runtime_get_noresume(&pdev->dev);
igc_ptp_stop(adapter); igc_ptp_stop(adapter);
set_bit(__IGC_DOWN, &adapter->state); set_bit(__IGC_DOWN, &adapter->state);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment