pci: PCIe driver for Marvell Armada 370/XP systems
This driver implements the support for the PCIe interfaces on the
Marvell Armada 370/XP ARM SoCs. In the future, it might be extended to
cover earlier families of Marvell SoCs, such as Dove, Orion and
Kirkwood.
The driver implements the hw_pci operations needed by the core ARM PCI
code to setup PCI devices and get their corresponding IRQs, and the
pci_ops operations that are used by the PCI core to read/write the
configuration space of PCI devices.
Since the PCIe interfaces of Marvell SoCs are completely separate and
not linked together in a bus, this driver sets up an emulated PCI host
bridge, with one PCI-to-PCI bridge as child for each hardware PCIe
interface.
In addition, this driver enumerates the different PCIe slots, and for
those having a device plugged in, it sets up the necessary address
decoding windows, using the mvebu-mbus driver.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Acked-by: Bjorn Helgaas <bhelgaas@google.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
2013-05-16 22:55:22 +07:00
|
|
|
menu "PCI host controller drivers"
|
|
|
|
depends on PCI
|
|
|
|
|
2014-07-23 04:23:45 +07:00
|
|
|
config PCI_DRA7XX
|
|
|
|
bool "TI DRA7xx PCIe controller"
|
|
|
|
select PCIE_DW
|
|
|
|
depends on OF && HAS_IOMEM && TI_PIPE3
|
|
|
|
help
|
|
|
|
Enables support for the PCIe controller in the DRA7xx SoC. There
|
|
|
|
are two instances of PCIe controller in DRA7xx. This controller can
|
|
|
|
act both as EP and RC. This reuses the Designware core.
|
|
|
|
|
pci: PCIe driver for Marvell Armada 370/XP systems
This driver implements the support for the PCIe interfaces on the
Marvell Armada 370/XP ARM SoCs. In the future, it might be extended to
cover earlier families of Marvell SoCs, such as Dove, Orion and
Kirkwood.
The driver implements the hw_pci operations needed by the core ARM PCI
code to setup PCI devices and get their corresponding IRQs, and the
pci_ops operations that are used by the PCI core to read/write the
configuration space of PCI devices.
Since the PCIe interfaces of Marvell SoCs are completely separate and
not linked together in a bus, this driver sets up an emulated PCI host
bridge, with one PCI-to-PCI bridge as child for each hardware PCIe
interface.
In addition, this driver enumerates the different PCIe slots, and for
those having a device plugged in, it sets up the necessary address
decoding windows, using the mvebu-mbus driver.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Acked-by: Bjorn Helgaas <bhelgaas@google.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
2013-05-16 22:55:22 +07:00
|
|
|
config PCI_MVEBU
|
|
|
|
bool "Marvell EBU PCIe controller"
|
2014-07-11 04:36:29 +07:00
|
|
|
depends on ARCH_MVEBU || ARCH_DOVE
|
2013-08-09 17:35:50 +07:00
|
|
|
depends on OF
|
pci: PCIe driver for Marvell Armada 370/XP systems
This driver implements the support for the PCIe interfaces on the
Marvell Armada 370/XP ARM SoCs. In the future, it might be extended to
cover earlier families of Marvell SoCs, such as Dove, Orion and
Kirkwood.
The driver implements the hw_pci operations needed by the core ARM PCI
code to setup PCI devices and get their corresponding IRQs, and the
pci_ops operations that are used by the PCI core to read/write the
configuration space of PCI devices.
Since the PCIe interfaces of Marvell SoCs are completely separate and
not linked together in a bus, this driver sets up an emulated PCI host
bridge, with one PCI-to-PCI bridge as child for each hardware PCIe
interface.
In addition, this driver enumerates the different PCIe slots, and for
those having a device plugged in, it sets up the necessary address
decoding windows, using the mvebu-mbus driver.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Acked-by: Bjorn Helgaas <bhelgaas@google.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
2013-05-16 22:55:22 +07:00
|
|
|
|
2013-06-21 14:24:54 +07:00
|
|
|
config PCIE_DW
|
|
|
|
bool
|
|
|
|
|
|
|
|
config PCI_EXYNOS
|
|
|
|
bool "Samsung Exynos PCIe controller"
|
|
|
|
depends on SOC_EXYNOS5440
|
|
|
|
select PCIEPORTBUS
|
|
|
|
select PCIE_DW
|
|
|
|
|
2013-09-26 10:24:47 +07:00
|
|
|
config PCI_IMX6
|
|
|
|
bool "Freescale i.MX6 PCIe controller"
|
|
|
|
depends on SOC_IMX6Q
|
|
|
|
select PCIEPORTBUS
|
|
|
|
select PCIE_DW
|
|
|
|
|
2013-08-09 21:49:19 +07:00
|
|
|
config PCI_TEGRA
|
|
|
|
bool "NVIDIA Tegra PCIe controller"
|
2014-11-12 20:53:37 +07:00
|
|
|
depends on ARCH_TEGRA && !ARM64
|
2014-11-12 20:53:38 +07:00
|
|
|
help
|
|
|
|
Say Y here if you want support for the PCIe host controller found
|
|
|
|
on NVIDIA Tegra SoCs.
|
2013-08-09 21:49:19 +07:00
|
|
|
|
2013-10-29 23:12:51 +07:00
|
|
|
config PCI_RCAR_GEN2
|
|
|
|
bool "Renesas R-Car Gen2 Internal PCI controller"
|
2014-02-18 09:12:01 +07:00
|
|
|
depends on ARCH_SHMOBILE || (ARM && COMPILE_TEST)
|
2013-10-29 23:12:51 +07:00
|
|
|
help
|
|
|
|
Say Y here if you want internal PCI support on R-Car Gen2 SoC.
|
|
|
|
There are 3 internal PCI controllers available with a single
|
|
|
|
built-in EHCI/OHCI host controller present on each one.
|
|
|
|
|
2014-05-12 17:57:48 +07:00
|
|
|
config PCI_RCAR_GEN2_PCIE
|
|
|
|
bool "Renesas R-Car PCIe controller"
|
|
|
|
depends on ARCH_SHMOBILE || (ARM && COMPILE_TEST)
|
|
|
|
help
|
|
|
|
Say Y here if you want PCIe controller support on R-Car Gen2 SoCs.
|
|
|
|
|
2013-11-22 23:14:41 +07:00
|
|
|
config PCI_HOST_GENERIC
|
|
|
|
bool "Generic PCI host controller"
|
2015-08-05 03:53:40 +07:00
|
|
|
depends on (ARM || ARM64) && OF
|
2013-11-22 23:14:41 +07:00
|
|
|
help
|
|
|
|
Say Y here if you want to support a simple generic PCI host
|
|
|
|
controller, such as the one emulated by kvmtool.
|
|
|
|
|
2014-02-11 13:09:26 +07:00
|
|
|
config PCIE_SPEAR13XX
|
2014-08-18 11:09:16 +07:00
|
|
|
bool "STMicroelectronics SPEAr PCIe controller"
|
2014-02-11 13:09:26 +07:00
|
|
|
depends on ARCH_SPEAR13XX
|
|
|
|
select PCIEPORTBUS
|
|
|
|
select PCIE_DW
|
|
|
|
help
|
|
|
|
Say Y here if you want PCIe support on SPEAr13XX SoCs.
|
|
|
|
|
2014-09-03 06:26:19 +07:00
|
|
|
config PCI_KEYSTONE
|
|
|
|
bool "TI Keystone PCIe controller"
|
|
|
|
depends on ARCH_KEYSTONE
|
|
|
|
select PCIE_DW
|
|
|
|
select PCIEPORTBUS
|
|
|
|
help
|
|
|
|
Say Y here if you want to enable PCI controller support on Keystone
|
|
|
|
SoCs. The PCI controller on Keystone is based on Designware hardware
|
|
|
|
and therefore the driver re-uses the Designware core functions to
|
|
|
|
implement the driver.
|
2014-09-05 23:57:20 +07:00
|
|
|
|
2014-08-20 23:26:02 +07:00
|
|
|
config PCIE_XILINX
|
|
|
|
bool "Xilinx AXI PCIe host bridge support"
|
|
|
|
depends on ARCH_ZYNQ
|
|
|
|
help
|
|
|
|
Say 'Y' here if you want kernel to support the Xilinx AXI PCIe
|
|
|
|
Host Bridge driver.
|
|
|
|
|
2014-10-02 02:01:35 +07:00
|
|
|
config PCI_XGENE
|
|
|
|
bool "X-Gene PCIe controller"
|
|
|
|
depends on ARCH_XGENE
|
|
|
|
depends on OF
|
|
|
|
select PCIEPORTBUS
|
2015-06-06 03:56:34 +07:00
|
|
|
select PCI_MSI_IRQ_DOMAIN if PCI_MSI
|
2014-10-02 02:01:35 +07:00
|
|
|
help
|
|
|
|
Say Y here if you want internal PCI support on APM X-Gene SoC.
|
|
|
|
There are 5 internal PCIe ports available. Each port is GEN3 capable
|
|
|
|
and have varied lanes from x1 to x8.
|
|
|
|
|
2015-06-06 03:56:34 +07:00
|
|
|
config PCI_XGENE_MSI
|
|
|
|
bool "X-Gene v1 PCIe MSI feature"
|
|
|
|
depends on PCI_XGENE && PCI_MSI
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Say Y here if you want PCIe MSI support for the APM X-Gene v1 SoC.
|
|
|
|
This MSI driver supports 5 PCIe ports on the APM X-Gene v1 SoC.
|
|
|
|
|
2014-11-05 15:45:11 +07:00
|
|
|
config PCI_LAYERSCAPE
|
|
|
|
bool "Freescale Layerscape PCIe controller"
|
|
|
|
depends on OF && ARM
|
|
|
|
select PCIE_DW
|
|
|
|
select MFD_SYSCON
|
|
|
|
help
|
|
|
|
Say Y here if you want PCIe controller support on Layerscape SoCs.
|
|
|
|
|
2015-01-28 23:16:18 +07:00
|
|
|
config PCI_VERSATILE
|
|
|
|
bool "ARM Versatile PB PCI controller"
|
|
|
|
depends on ARCH_VERSATILE
|
|
|
|
|
2015-04-09 01:21:35 +07:00
|
|
|
config PCIE_IPROC
|
|
|
|
tristate "Broadcom iProc PCIe controller"
|
2015-07-28 05:42:19 +07:00
|
|
|
depends on OF && (ARM || ARM64)
|
2015-04-09 01:21:35 +07:00
|
|
|
default n
|
|
|
|
help
|
|
|
|
This enables the iProc PCIe core controller support for Broadcom's
|
|
|
|
iProc family of SoCs. An appropriate bus interface driver also needs
|
|
|
|
to be enabled
|
|
|
|
|
|
|
|
config PCIE_IPROC_PLATFORM
|
|
|
|
tristate "Broadcom iProc PCIe platform bus driver"
|
|
|
|
depends on ARCH_BCM_IPROC || (ARM && COMPILE_TEST)
|
|
|
|
depends on OF
|
|
|
|
select PCIE_IPROC
|
|
|
|
default ARCH_BCM_IPROC
|
|
|
|
help
|
|
|
|
Say Y here if you want to use the Broadcom iProc PCIe controller
|
|
|
|
through the generic platform bus interface
|
|
|
|
|
2015-05-13 04:23:01 +07:00
|
|
|
config PCIE_IPROC_BCMA
|
2015-07-26 02:15:24 +07:00
|
|
|
tristate "Broadcom iProc PCIe BCMA bus driver"
|
2015-07-30 00:12:53 +07:00
|
|
|
depends on ARM && (ARCH_BCM_IPROC || COMPILE_TEST)
|
2015-05-13 04:23:01 +07:00
|
|
|
select PCIE_IPROC
|
|
|
|
select BCMA
|
|
|
|
select PCI_DOMAINS
|
|
|
|
default ARCH_BCM_5301X
|
|
|
|
help
|
|
|
|
Say Y here if you want to use the Broadcom iProc PCIe controller
|
|
|
|
through the BCMA bus interface
|
|
|
|
|
pci: PCIe driver for Marvell Armada 370/XP systems
This driver implements the support for the PCIe interfaces on the
Marvell Armada 370/XP ARM SoCs. In the future, it might be extended to
cover earlier families of Marvell SoCs, such as Dove, Orion and
Kirkwood.
The driver implements the hw_pci operations needed by the core ARM PCI
code to setup PCI devices and get their corresponding IRQs, and the
pci_ops operations that are used by the PCI core to read/write the
configuration space of PCI devices.
Since the PCIe interfaces of Marvell SoCs are completely separate and
not linked together in a bus, this driver sets up an emulated PCI host
bridge, with one PCI-to-PCI bridge as child for each hardware PCIe
interface.
In addition, this driver enumerates the different PCIe slots, and for
those having a device plugged in, it sets up the necessary address
decoding windows, using the mvebu-mbus driver.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Acked-by: Bjorn Helgaas <bhelgaas@google.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
2013-05-16 22:55:22 +07:00
|
|
|
endmenu
|