sh: Make SH7786 PCIe port reset logic more aggressive.
authorPaul Mundt <lethal@linux-sh.org>
Tue, 7 Sep 2010 07:11:04 +0000 (16:11 +0900)
committerPaul Mundt <lethal@linux-sh.org>
Tue, 7 Sep 2010 07:11:04 +0000 (16:11 +0900)
This attempts a more complete port reset, building on top of the existing
approach.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/drivers/pci/pcie-sh7786.c

index 03e6d8217b0cdb015c24cbe206850910b8305608..40b0ed042236376a6dc6ebb43d7925908b2bf973 100644 (file)
@@ -204,6 +204,16 @@ static int phy_init(struct pci_channel *chan)
        return -ETIMEDOUT;
 }
 
+static void pcie_reset(struct sh7786_pcie_port *port)
+{
+       struct pci_channel *chan = port->hose;
+
+       pci_write_reg(chan, 1, SH4A_PCIESRSTR);
+       pci_write_reg(chan, 0, SH4A_PCIETCTLR);
+       pci_write_reg(chan, 0, SH4A_PCIESRSTR);
+       pci_write_reg(chan, 0, SH4A_PCIETXVC0SR);
+}
+
 static int pcie_init(struct sh7786_pcie_port *port)
 {
        struct pci_channel *chan = port->hose;
@@ -213,7 +223,7 @@ static int pcie_init(struct sh7786_pcie_port *port)
        int ret, i;
 
        /* Begin initialization */
-       pci_write_reg(chan, 0, SH4A_PCIETCTLR);
+       pcie_reset(port);
 
        /* Initialize as type1. */
        data = pci_read_reg(chan, SH4A_PCIEPCICONF3);