Skip to content

Commit da72dcc

Browse files
committed
Merge branch 'pci/controller/j721e'
- Add MODULE_DEVICE_TABLE() so driver can be autoloaded (Siddharth Vadapalli) - Power controller off before configuring the glue layer so the controller latches the correct values on power-on (Siddharth Vadapalli) - Correct the error message when j721e_pcie_ctrl_init() fails (Alok Tiwari) * pci/controller/j721e: PCI: j721e: Fix incorrect error message in probe() PCI: j721e: Fix programming sequence of "strap" settings PCI: j721e: Fix module autoloading
2 parents efe4466 + cfcd6ca commit da72dcc

File tree

1 file changed

+27
-1
lines changed

1 file changed

+27
-1
lines changed

drivers/pci/controller/cadence/pci-j721e.c

Lines changed: 27 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -284,6 +284,25 @@ static int j721e_pcie_ctrl_init(struct j721e_pcie *pcie)
284284
if (!ret)
285285
offset = args.args[0];
286286

287+
/*
288+
* The PCIe Controller's registers have different "reset-values"
289+
* depending on the "strap" settings programmed into the PCIEn_CTRL
290+
* register within the CTRL_MMR memory-mapped register space.
291+
* The registers latch onto a "reset-value" based on the "strap"
292+
* settings sampled after the PCIe Controller is powered on.
293+
* To ensure that the "reset-values" are sampled accurately, power
294+
* off the PCIe Controller before programming the "strap" settings
295+
* and power it on after that. The runtime PM APIs namely
296+
* pm_runtime_put_sync() and pm_runtime_get_sync() will decrement and
297+
* increment the usage counter respectively, causing GENPD to power off
298+
* and power on the PCIe Controller.
299+
*/
300+
ret = pm_runtime_put_sync(dev);
301+
if (ret < 0) {
302+
dev_err(dev, "Failed to power off PCIe Controller\n");
303+
return ret;
304+
}
305+
287306
ret = j721e_pcie_set_mode(pcie, syscon, offset);
288307
if (ret < 0) {
289308
dev_err(dev, "Failed to set pci mode\n");
@@ -302,6 +321,12 @@ static int j721e_pcie_ctrl_init(struct j721e_pcie *pcie)
302321
return ret;
303322
}
304323

324+
ret = pm_runtime_get_sync(dev);
325+
if (ret < 0) {
326+
dev_err(dev, "Failed to power on PCIe Controller\n");
327+
return ret;
328+
}
329+
305330
/* Enable ACSPCIE refclk output if the optional property exists */
306331
syscon = syscon_regmap_lookup_by_phandle_optional(node,
307332
"ti,syscon-acspcie-proxy-ctrl");
@@ -440,6 +465,7 @@ static const struct of_device_id of_j721e_pcie_match[] = {
440465
},
441466
{},
442467
};
468+
MODULE_DEVICE_TABLE(of, of_j721e_pcie_match);
443469

444470
static int j721e_pcie_probe(struct platform_device *pdev)
445471
{
@@ -549,7 +575,7 @@ static int j721e_pcie_probe(struct platform_device *pdev)
549575

550576
ret = j721e_pcie_ctrl_init(pcie);
551577
if (ret < 0) {
552-
dev_err_probe(dev, ret, "pm_runtime_get_sync failed\n");
578+
dev_err_probe(dev, ret, "j721e_pcie_ctrl_init failed\n");
553579
goto err_get_sync;
554580
}
555581

0 commit comments

Comments
 (0)