Merge branches 'pci/host-designware', 'pci/host-designware-common', 'pci/host-generic...
authorBjorn Helgaas <bhelgaas@google.com>
Tue, 16 Jun 2015 13:19:55 +0000 (08:19 -0500)
committerBjorn Helgaas <bhelgaas@google.com>
Tue, 16 Jun 2015 13:19:55 +0000 (08:19 -0500)
* pci/host-designware:
  PCI: designware: Use iATU0 for cfg and IO, iATU1 for MEM
  PCI: designware: Consolidate outbound iATU programming functions
  PCI: designware: Add support for x8 links

* pci/host-designware-common:
  PCI: designware: Wait for link to come up with consistent style
  PCI: layerscape: Factor out ls_pcie_establish_link()
  PCI: layerscape: Use dw_pcie_link_up() consistently
  PCI: dra7xx: Use dw_pcie_link_up() consistently
  PCI: imx6: Rename imx6_pcie_start_link() to imx6_pcie_establish_link()

* pci/host-generic:
  of/pci: Fix pci_address_to_pio() conversion of CPU address to I/O port

* pci/host-imx6:
  PCI: imx6: Add #define PCIE_RC_LCSR
  PCI: imx6: Use "u32", not "uint32_t"
  PCI: imx6: Add speed change timeout message

* pci/host-iproc:
  PCI: iproc: Free resource list after registration
  PCI: iproc: Directly add PCI resources
  PCI: iproc: Add BCMA PCIe driver
  PCI: iproc: Allow override of device tree IRQ mapping function

* pci/host-xgene:
  arm64: dts: Add APM X-Gene PCIe MSI nodes
  PCI: xgene: Add APM X-Gene v1 PCIe MSI/MSIX termination driver

1  2  3  4  5  6  7 
drivers/pci/host/Kconfig
drivers/pci/host/Makefile
drivers/pci/host/pci-imx6.c
drivers/pci/host/pcie-designware.c

Simple merge
Simple merge
index fdb95367721e9b2e9758ee9f05beb4c878374dbd,fdb95367721e9b2e9758ee9f05beb4c878374dbd,af7da8ac8082a055e82de678324d342ff8098f11,fdb95367721e9b2e9758ee9f05beb4c878374dbd,a4ee579421dffa4037f17aa6155056544f390ff3,fdb95367721e9b2e9758ee9f05beb4c878374dbd,fdb95367721e9b2e9758ee9f05beb4c878374dbd..233a196c6e6661c8dc9aea975a5cf15bf253c2fb
@@@@@@@@ -335,23 -335,23 -335,21 -335,23 -337,40 -335,23 -335,23 +337,38 @@@@@@@@ static void imx6_pcie_init_phy(struct p
       
       static int imx6_pcie_wait_for_link(struct pcie_port *pp)
       {
-- ---- int count = 200;
++ ++++ unsigned int retries;
       
-- ---- while (!dw_pcie_link_up(pp)) {
++ ++++ for (retries = 0; retries < 200; retries++) {
++ ++++         if (dw_pcie_link_up(pp))
++ ++++                 return 0;
                usleep_range(100, 1000);
-- ----         if (--count)
-- ----                 continue;
-- ----
-- ----         dev_err(pp->dev, "phy link never came up\n");
-- ----         dev_dbg(pp->dev, "DEBUG_R0: 0x%08x, DEBUG_R1: 0x%08x\n",
-- ----                 readl(pp->dbi_base + PCIE_PHY_DEBUG_R0),
-- ----                 readl(pp->dbi_base + PCIE_PHY_DEBUG_R1));
-- ----         return -EINVAL;
        }
       
-- ---- return 0;
++ ++++ dev_err(pp->dev, "phy link never came up\n");
++ ++++ dev_dbg(pp->dev, "DEBUG_R0: 0x%08x, DEBUG_R1: 0x%08x\n",
++ ++++         readl(pp->dbi_base + PCIE_PHY_DEBUG_R0),
++ ++++         readl(pp->dbi_base + PCIE_PHY_DEBUG_R1));
++ ++++ return -EINVAL;
++ + ++}
++ + ++
++++ ++static int imx6_pcie_wait_for_speed_change(struct pcie_port *pp)
++++ ++{
++++ ++ u32 tmp;
++++ ++ unsigned int retries;
++++ ++
++++ ++ for (retries = 0; retries < 200; retries++) {
++++ ++         tmp = readl(pp->dbi_base + PCIE_LINK_WIDTH_SPEED_CONTROL);
++++ ++         /* Test if the speed change finished. */
++++ ++         if (!(tmp & PORT_LOGIC_SPEED_CHANGE))
++++ ++                 return 0;
++++ ++         usleep_range(100, 1000);
++++ ++ }
++++ ++
++++ ++ dev_err(pp->dev, "Speed change timeout\n");
++++ ++ return -EINVAL;
  +    }
  +    
       static irqreturn_t imx6_pcie_msi_handler(int irq, void *arg)
       {
        struct pcie_port *pp = arg;
        return dw_handle_msi_irq(pp);
       }
       
-- ----static int imx6_pcie_start_link(struct pcie_port *pp)
++ ++++static int imx6_pcie_establish_link(struct pcie_port *pp)
       {
        struct imx6_pcie *imx6_pcie = to_imx6_pcie(pp);
---- -- uint32_t tmp;
---- -- int ret, count;
++++ ++ u32 tmp;
++++ ++ int ret;
       
        /*
         * Force Gen1 operation when starting the link.  In case the link is
Simple merge