PCI: armada8k: Fix clock resource by adding a register clock
authorGregory CLEMENT <gregory.clement@bootlin.com>
Wed, 28 Feb 2018 16:35:30 +0000 (17:35 +0100)
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Thu, 8 Mar 2018 15:23:47 +0000 (15:23 +0000)
On Armada 7K/8K we need to explicitly enable the register clock. This
clock is optional because not all the SoCs using this IP need it but at
least for Armada 7K/8K it is actually mandatory.

The binding documentation is updated accordingly.

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Documentation/devicetree/bindings/pci/pci-armada8k.txt
drivers/pci/dwc/pcie-armada8k.c

index c1e4c3d10a747c008c2b914c89194228caed395e..9e3fc15e1af88d0853e07b78ebc0b5e62a9d064a 100644 (file)
@@ -12,7 +12,10 @@ Required properties:
    - "ctrl" for the control register region
    - "config" for the config space region
 - interrupts: Interrupt specifier for the PCIe controler
-- clocks: reference to the PCIe controller clock
+- clocks: reference to the PCIe controller clocks
+- clock-names: mandatory if there is a second clock, in this case the
+   name must be "core" for the first clock and "reg" for the second
+   one
 
 Example:
 
index f9b1aec25c5cd34261d9e8b39b34d595395ee50a..072fd7ecc29f2758ccb082ac5443335f8407be58 100644 (file)
@@ -28,6 +28,7 @@
 struct armada8k_pcie {
        struct dw_pcie *pci;
        struct clk *clk;
+       struct clk *clk_reg;
 };
 
 #define PCIE_VENDOR_REGS_OFFSET                0x8000
@@ -229,23 +230,36 @@ static int armada8k_pcie_probe(struct platform_device *pdev)
        if (ret)
                return ret;
 
+       pcie->clk_reg = devm_clk_get(dev, "reg");
+       if (pcie->clk_reg == ERR_PTR(-EPROBE_DEFER)) {
+               ret = -EPROBE_DEFER;
+               goto fail;
+       }
+       if (!IS_ERR(pcie->clk_reg)) {
+               ret = clk_prepare_enable(pcie->clk_reg);
+               if (ret)
+                       goto fail_clkreg;
+       }
+
        /* Get the dw-pcie unit configuration/control registers base. */
        base = platform_get_resource_byname(pdev, IORESOURCE_MEM, "ctrl");
        pci->dbi_base = devm_pci_remap_cfg_resource(dev, base);
        if (IS_ERR(pci->dbi_base)) {
                dev_err(dev, "couldn't remap regs base %p\n", base);
                ret = PTR_ERR(pci->dbi_base);
-               goto fail;
+               goto fail_clkreg;
        }
 
        platform_set_drvdata(pdev, pcie);
 
        ret = armada8k_add_pcie_port(pcie, pdev);
        if (ret)
-               goto fail;
+               goto fail_clkreg;
 
        return 0;
 
+fail_clkreg:
+       clk_disable_unprepare(pcie->clk_reg);
 fail:
        clk_disable_unprepare(pcie->clk);