r8169: use pci_prepare_to_sleep in rtl_shutdown
authorHeiner Kallweit <hkallweit1@gmail.com>
Mon, 21 Apr 2025 09:25:18 +0000 (11:25 +0200)
committerJakub Kicinski <kuba@kernel.org>
Wed, 23 Apr 2025 00:22:02 +0000 (17:22 -0700)
Use pci_prepare_to_sleep() like PCI core does in pci_pm_suspend_noirq.
This aligns setting a low-power mode during shutdown with the handling
of the transition to system suspend. Also the transition to runtime
suspend uses pci_target_state() instead of setting D3hot unconditionally.

Note: pci_prepare_to_sleep() uses device_may_wakeup() to check whether
      device may generate wakeup events. So we don't lose anything by
      not passing tp->saved_wolopts any longer.

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
Link: https://patch.msgid.link/f573fdbd-ba6d-41c1-b68f-311d3c88db2c@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/realtek/r8169_main.c

index 635785d91790225ed69d856a4cc330c55527bf0f..3ef7126f8ec507d03d530f0c51d1b88d97b507ae 100644 (file)
@@ -5039,10 +5039,8 @@ static void rtl_shutdown(struct pci_dev *pdev)
        /* Restore original MAC address */
        rtl_rar_set(tp, tp->dev->perm_addr);
 
-       if (system_state == SYSTEM_POWER_OFF && !tp->dash_enabled) {
-               pci_wake_from_d3(pdev, tp->saved_wolopts);
-               pci_set_power_state(pdev, PCI_D3hot);
-       }
+       if (system_state == SYSTEM_POWER_OFF && !tp->dash_enabled)
+               pci_prepare_to_sleep(pdev);
 }
 
 static void rtl_remove_one(struct pci_dev *pdev)