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 17:55:22 +02:00
menu "PCI host controller drivers"
depends on PCI
2014-07-22 15:23:45 -06: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 17:55:22 +02:00
config PCI_MVEBU
bool "Marvell EBU PCIe controller"
2014-07-10 23:36:29 +02:00
depends on ARCH_MVEBU || ARCH_DOVE
2016-02-18 14:32:10 +01:00
depends on ARM
2013-08-09 12:35:50 +02: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 17:55:22 +02:00
2016-03-15 08:55:52 -05:00
2016-03-06 22:02:14 +05:30
config PCIE_XILINX_NWL
bool "NWL PCIe Core"
depends on ARCH_ZYNQMP
select PCI_MSI_IRQ_DOMAIN if PCI_MSI
help
Say 'Y' here if you want kernel support for Xilinx
NWL PCIe controller. The controller can act as Root Port
or End Point. The current option selection will only
support root port enabling.
2016-03-10 14:44:52 -06:00
config PCIE_DW_PLAT
bool "Platform bus based DesignWare PCIe Controller"
select PCIE_DW
---help---
This selects the DesignWare PCIe controller support. Select this if
you have a PCIe controller on Platform bus.
If you have a controller with this interface, say Y or M here.
If unsure, say N.
2013-06-21 16:24:54 +09: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 11:24:47 +08:00
config PCI_IMX6
bool "Freescale i.MX6 PCIe controller"
depends on SOC_IMX6Q
select PCIEPORTBUS
select PCIE_DW
2013-08-09 16:49:19 +02:00
config PCI_TEGRA
bool "NVIDIA Tegra PCIe controller"
2014-11-12 14:53:37 +01:00
depends on ARCH_TEGRA && !ARM64
2014-11-12 14:53:38 +01:00
help
Say Y here if you want support for the PCIe host controller found
on NVIDIA Tegra SoCs.
2013-08-09 16:49:19 +02:00
2013-10-29 20:12:51 +04:00
config PCI_RCAR_GEN2
bool "Renesas R-Car Gen2 Internal PCI controller"
2015-10-30 08:08:17 -05:00
depends on ARM
2016-02-25 09:45:56 +09:00
depends on ARCH_RENESAS || COMPILE_TEST
2013-10-29 20:12:51 +04: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.
2016-04-21 13:51:55 +10:00
config PCIE_RCAR
2014-05-12 11:57:48 +01:00
bool "Renesas R-Car PCIe controller"
2016-02-25 09:45:56 +09:00
depends on ARCH_RENESAS || (ARM && COMPILE_TEST)
2016-04-16 22:15:46 +02:00
select PCI_MSI
select PCI_MSI_IRQ_DOMAIN
2014-05-12 11:57:48 +01:00
help
2016-04-21 13:51:55 +10:00
Say Y here if you want PCIe controller support on R-Car SoCs.
2014-05-12 11:57:48 +01:00
2016-03-11 15:35:55 -06:00
config PCI_HOST_COMMON
bool
2016-05-11 17:34:46 -05:00
select PCI_ECAM
2016-03-11 15:35:55 -06:00
2013-11-22 16:14:41 +00:00
config PCI_HOST_GENERIC
bool "Generic PCI host controller"
2015-08-05 02:23:40 +05:30
depends on (ARM || ARM64) && OF
2016-03-11 15:35:55 -06:00
select PCI_HOST_COMMON
2013-11-22 16:14:41 +00: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 11:39:26 +05:30
config PCIE_SPEAR13XX
2014-08-17 22:09:16 -06:00
bool "STMicroelectronics SPEAr PCIe controller"
2014-02-11 11:39:26 +05:30
depends on ARCH_SPEAR13XX
select PCIEPORTBUS
select PCIE_DW
help
Say Y here if you want PCIe support on SPEAr13XX SoCs.
2014-09-02 17:26:19 -06: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 10:57:20 -06:00
2014-08-20 21:56:02 +05:30
config PCIE_XILINX
bool "Xilinx AXI PCIe host bridge support"
2016-02-11 21:58:11 +05:30
depends on ARCH_ZYNQ || MICROBLAZE
2014-08-20 21:56:02 +05:30
help
Say 'Y' here if you want kernel to support the Xilinx AXI PCIe
Host Bridge driver.
2014-10-01 13:01:35 -06:00
config PCI_XGENE
bool "X-Gene PCIe controller"
depends on ARCH_XGENE
depends on OF
select PCIEPORTBUS
2015-06-05 15:56:34 -05:00
select PCI_MSI_IRQ_DOMAIN if PCI_MSI
2014-10-01 13:01:35 -06: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-05 15:56:34 -05: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 16:45:11 +08:00
config PCI_LAYERSCAPE
bool "Freescale Layerscape PCIe controller"
2015-10-16 15:19:19 +08:00
depends on OF && (ARM || ARCH_LAYERSCAPE)
2014-11-05 16:45:11 +08:00
select PCIE_DW
select MFD_SYSCON
help
Say Y here if you want PCIe controller support on Layerscape SoCs.
2015-01-28 10:16:18 -06:00
config PCI_VERSATILE
bool "ARM Versatile PB PCI controller"
depends on ARCH_VERSATILE
2015-04-08 11:21:35 -07:00
config PCIE_IPROC
2015-11-24 15:28:48 -06:00
tristate
2015-04-08 11:21:35 -07:00
help
This enables the iProc PCIe core controller support for Broadcom's
2015-11-24 15:28:48 -06:00
iProc family of SoCs. An appropriate bus interface driver needs
to be enabled to select this.
2015-04-08 11:21:35 -07:00
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-12 23:23:01 +02:00
config PCIE_IPROC_BCMA
2015-07-25 21:15:24 +02:00
tristate "Broadcom iProc PCIe BCMA bus driver"
2015-07-29 10:12:53 -07:00
depends on ARM && (ARCH_BCM_IPROC || COMPILE_TEST)
2015-05-12 23:23:01 +02: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
2016-01-06 18:04:35 -06:00
config PCIE_IPROC_MSI
bool "Broadcom iProc PCIe MSI support"
depends on PCIE_IPROC_PLATFORM || PCIE_IPROC_BCMA
depends on PCI_MSI
select PCI_MSI_IRQ_DOMAIN
default ARCH_BCM_IPROC
help
Say Y here if you want to enable MSI support for Broadcom's iProc
PCIe controller
2015-10-23 18:27:12 +08:00
config PCIE_ALTERA
bool "Altera PCIe controller"
depends on ARM || NIOS2
depends on OF_PCI
select PCI_DOMAINS
help
Say Y here if you want to enable PCIe controller support on Altera
FPGA.
2015-10-23 18:27:13 +08:00
config PCIE_ALTERA_MSI
bool "Altera PCIe MSI feature"
depends on PCIE_ALTERA && PCI_MSI
select PCI_MSI_IRQ_DOMAIN
help
Say Y here if you want PCIe MSI support for the Altera FPGA.
This MSI driver supports Altera MSI to GIC controller IP.
2015-10-29 20:02:51 -05:00
config PCI_HISI
depends on OF && ARM64
2015-11-27 01:17:05 +08:00
bool "HiSilicon Hip05 and Hip06 SoCs PCIe controllers"
2015-10-29 20:02:51 -05:00
select PCIEPORTBUS
select PCIE_DW
help
2015-11-27 01:17:05 +08:00
Say Y here if you want PCIe controller support on HiSilicon
Hip05 and Hip06 SoCs
2015-10-29 20:02:51 -05:00
2015-12-18 14:38:57 +02:00
config PCIE_QCOM
bool "Qualcomm PCIe controller"
depends on ARCH_QCOM && OF
select PCIE_DW
select PCIEPORTBUS
help
Say Y here to enable PCIe controller support on Qualcomm SoCs. The
PCIe controller uses the Designware core plus Qualcomm-specific
hardware wrappers.
2015-10-29 20:02:51 -05:00
2016-03-04 14:31:47 -08:00
config PCI_HOST_THUNDER_PEM
bool "Cavium Thunder PCIe controller to off-chip devices"
depends on OF && ARM64
select PCI_HOST_COMMON
help
Say Y here if you want PCIe support for CN88XX Cavium Thunder SoCs.
2016-03-04 14:31:48 -08:00
config PCI_HOST_THUNDER_ECAM
bool "Cavium Thunder ECAM controller to on-chip devices on pass-1.x silicon"
depends on OF && ARM64
select PCI_HOST_COMMON
help
Say Y here if you want ECAM support for CN88XX-Pass-1.x Cavium Thunder SoCs.
2016-04-26 10:31:46 +02:00
config PCIE_ARMADA_8K
bool "Marvell Armada-8K PCIe controller"
depends on ARCH_MVEBU
select PCIE_DW
select PCIEPORTBUS
help
Say Y here if you want to enable PCIe controller support on
Armada-8K SoCs. The PCIe controller on Armada-8K is based on
Designware hardware and therefore the driver re-uses the
Designware core functions to implement the driver.
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 17:55:22 +02:00
endmenu