summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--drivers/pci/host/pci-msm.c25
1 files changed, 16 insertions, 9 deletions
diff --git a/drivers/pci/host/pci-msm.c b/drivers/pci/host/pci-msm.c
index a741c9c7d115..0ecf64f4afe9 100644
--- a/drivers/pci/host/pci-msm.c
+++ b/drivers/pci/host/pci-msm.c
@@ -6865,17 +6865,24 @@ static int msm_pcie_pm_resume(struct pci_dev *dev,
dev->bus->number, dev->bus->primary);
if (!(options & MSM_PCIE_CONFIG_NO_CFG_RESTORE)) {
- PCIE_DBG(pcie_dev,
- "RC%d: entry of PCI framework restore state\n",
- pcie_dev->rc_idx);
+ if (pcie_dev->saved_state) {
+ PCIE_DBG(pcie_dev,
+ "RC%d: entry of PCI framework restore state\n",
+ pcie_dev->rc_idx);
- pci_load_and_free_saved_state(dev,
- &pcie_dev->saved_state);
- pci_restore_state(dev);
+ pci_load_and_free_saved_state(dev,
+ &pcie_dev->saved_state);
+ pci_restore_state(dev);
- PCIE_DBG(pcie_dev,
- "RC%d: exit of PCI framework restore state\n",
- pcie_dev->rc_idx);
+ PCIE_DBG(pcie_dev,
+ "RC%d: exit of PCI framework restore state\n",
+ pcie_dev->rc_idx);
+ } else {
+ PCIE_DBG(pcie_dev,
+ "RC%d: restore rc config space using shadow recovery\n",
+ pcie_dev->rc_idx);
+ msm_pcie_cfg_recover(pcie_dev, true);
+ }
}
}