PCI/PM: Fold __pci_complete_power_transition() into its caller
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Tue, 5 Nov 2019 16:32:08 +0000 (17:32 +0100)
committerBjorn Helgaas <bhelgaas@google.com>
Wed, 20 Nov 2019 23:36:08 +0000 (17:36 -0600)
Because pci_set_power_state() has become the only caller of
__pci_complete_power_transition(), there is no need for the latter to
be a separate function any more, so fold it into the former, drop a
redundant check and reduce the number of lines of code somewhat.

Code rearrangement, no intentional functional impact.

Link: https://lore.kernel.org/r/15576968.k611qn3UU0@kreacher
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com>
drivers/pci/pci.c

index 2f53234..37fca1e 100644 (file)
@@ -1056,26 +1056,6 @@ void pci_bus_set_current_state(struct pci_bus *bus, pci_power_t state)
 }
 
 /**
- * __pci_complete_power_transition - Complete power transition of a PCI device
- * @dev: PCI device to handle.
- * @state: State to put the device into.
- *
- * This function should not be called directly by device drivers.
- */
-static int __pci_complete_power_transition(struct pci_dev *dev, pci_power_t state)
-{
-       int ret;
-
-       if (state <= PCI_D0)
-               return -EINVAL;
-       ret = pci_platform_power_transition(dev, state);
-       /* Power off the bridge may power off the whole hierarchy */
-       if (!ret && state == PCI_D3cold)
-               pci_bus_set_current_state(dev->subordinate, PCI_D3cold);
-       return ret;
-}
-
-/**
  * pci_set_power_state - Set the power state of a PCI device
  * @dev: PCI device to handle.
  * @state: PCI power state (D0, D1, D2, D3hot) to put the device into.
@@ -1132,10 +1112,14 @@ int pci_set_power_state(struct pci_dev *dev, pci_power_t state)
        error = pci_raw_set_power_state(dev, state > PCI_D3hot ?
                                        PCI_D3hot : state);
 
-       if (!__pci_complete_power_transition(dev, state))
-               error = 0;
+       if (pci_platform_power_transition(dev, state))
+               return error;
 
-       return error;
+       /* Powering off a bridge may power off the whole hierarchy */
+       if (state == PCI_D3cold)
+               pci_bus_set_current_state(dev->subordinate, PCI_D3cold);
+
+       return 0;
 }
 EXPORT_SYMBOL(pci_set_power_state);