blob: 5e0a39396bb019d596de0baefd3e571dd340a0f0 [file] [log] [blame]
Tom Riniaf273822016-10-26 17:15:37 -04001menuconfig PCI
2 bool "PCI support"
Bin Meng6bf89de2017-07-30 06:23:09 -07003 default y if PPC
Tom Riniaf273822016-10-26 17:15:37 -04004 help
5 Enable support for PCI (Peripheral Interconnect Bus), a type of bus
6 used on some devices to allow the CPU to communicate with its
7 peripherals.
8
9if PCI
Simon Glassff3e0772015-03-05 12:25:25 -070010
11config DM_PCI
Marcel Ziswilere090fdb2016-12-19 15:38:05 +010012 bool "Enable driver model for PCI"
Simon Glassff3e0772015-03-05 12:25:25 -070013 depends on DM
14 help
15 Use driver model for PCI. Driver model is the new method for
16 orgnising devices in U-Boot. For PCI, driver model keeps track of
17 available PCI devices, allows scanning of PCI buses and provides
18 device configuration support.
19
Simon Glass3ba5f742015-11-26 19:51:30 -070020config DM_PCI_COMPAT
21 bool "Enable compatible functions for PCI"
22 depends on DM_PCI
23 help
24 Enable compatibility functions for PCI so that old code can be used
25 with CONFIG_DM_PCI enabled. This should be used as an interim
26 measure when porting a board to use driver model for PCI. Once the
27 board is fully supported, this option should be disabled.
28
Wilson Dinge51f2b12018-03-26 15:57:29 +080029config PCI_AARDVARK
30 bool "Enable Aardvark PCIe driver"
31 default n
32 depends on DM_PCI
33 depends on ARMADA_3700
34 help
35 Say Y here if you want to enable PCIe controller support on
36 Armada37x0 SoCs. The PCIe controller on Armada37x0 is based on
37 Aardvark hardware.
38
Bin Mengc4762152016-10-16 23:35:18 -070039config PCI_PNP
40 bool "Enable Plug & Play support for PCI"
41 depends on PCI || DM_PCI
42 default y
43 help
44 Enable PCI memory and I/O space resource allocation and assignment.
45
Tuomas Tynkkynen3675cb02017-09-19 23:18:06 +030046config PCIE_ECAM_GENERIC
47 bool "Generic ECAM-based PCI host controller support"
48 default n
49 depends on DM_PCI
50 help
51 Say Y here if you want to enable support for generic ECAM-based
52 PCIe host controllers, such as the one emulated by QEMU.
53
liu haoe3aafef2019-10-31 07:51:08 +000054config PCI_PHYTIUM
55 bool "Phytium PCIe support"
56 depends on DM_PCI
57 help
58 Say Y here if you want to enable PCIe controller support on
59 Phytium SoCs.
60
Shadi Ammouri182ba1a2016-10-27 13:29:41 +020061config PCIE_DW_MVEBU
62 bool "Enable Armada-8K PCIe driver (DesignWare core)"
Shadi Ammouri182ba1a2016-10-27 13:29:41 +020063 depends on DM_PCI
64 depends on ARMADA_8K
65 help
66 Say Y here if you want to enable PCIe controller support on
67 Armada-8K SoCs. The PCIe controller on Armada-8K is based on
68 DesignWare hardware.
69
Hou Zhiqiangb89e3d92019-04-24 22:33:02 +080070config PCIE_FSL
71 bool "FSL PowerPC PCIe support"
72 depends on DM_PCI
73 help
74 Say Y here if you want to enable PCIe controller support on FSL
75 PowerPC MPC85xx, MPC86xx, B series, P series and T series SoCs.
76 This driver does not support SRIO_PCIE_BOOT feature.
77
Heiko Schocherb61cbbd2019-10-14 11:29:39 +020078config PCI_MPC85XX
79 bool "MPC85XX PowerPC PCI support"
80 depends on DM_PCI
81 help
82 Say Y here if you want to enable PCI controller support on FSL
83 PowerPC MPC85xx SoC.
84
Marek Vasut5f14f7d2018-01-18 14:35:35 +010085config PCI_RCAR_GEN2
86 bool "Renesas RCar Gen2 PCIe driver"
87 depends on DM_PCI
88 depends on RCAR_32
89 help
90 Say Y here if you want to enable PCIe controller support on
91 Renesas RCar Gen2 SoCs. The PCIe controller on RCar Gen2 is
92 also used to access EHCI USB controller on the SoC.
93
Marek Vasut776abed2018-10-16 12:49:19 +020094config PCI_RCAR_GEN3
95 bool "Renesas RCar Gen3 PCIe driver"
96 depends on DM_PCI
97 depends on RCAR_GEN3
98 help
99 Say Y here if you want to enable PCIe controller support on
100 Renesas RCar Gen3 SoCs.
101
Simon Glass537849a2015-03-05 12:25:27 -0700102config PCI_SANDBOX
103 bool "Sandbox PCI support"
104 depends on SANDBOX && DM_PCI
105 help
106 Support PCI on sandbox, as an emulated bus. This permits testing of
107 PCI feature such as bus scanning, device configuration and device
108 access. The available (emulated) devices are defined statically in
109 the device tree but the normal PCI scan technique is used to find
110 then.
111
Simon Glassfde7e182015-11-19 20:26:55 -0700112config PCI_TEGRA
113 bool "Tegra PCI support"
Trevor Woerner18138ab2020-05-06 08:02:41 -0400114 depends on ARCH_TEGRA
Stephen Warrenbbc5b362016-08-05 16:10:34 -0600115 depends on (TEGRA186 && POWER_DOMAIN) || (!TEGRA186)
Simon Glassfde7e182015-11-19 20:26:55 -0700116 help
117 Enable support for the PCIe controller found on some generations of
118 Tegra. Tegra20 has 2 root ports with a total of 4 lanes, Tegra30 has
119 3 root ports with a total of 6 lanes and Tegra124 has 2 root ports
120 with a total of 5 lanes. Some boards require this for Ethernet
121 support to work (e.g. beaver, jetson-tk1).
122
Paul Burtona29e45a2016-09-08 07:47:31 +0100123config PCI_XILINX
124 bool "Xilinx AXI Bridge for PCI Express"
125 depends on DM_PCI
126 help
127 Enable support for the Xilinx AXI bridge for PCI express, an IP block
128 which can be used on some generations of Xilinx FPGAs.
129
Minghuan Lian80afc632016-12-13 14:54:17 +0800130config PCIE_LAYERSCAPE
Hou Zhiqianged188aa2020-07-09 23:31:42 +0800131 bool
132 default n
133
134config PCIE_LAYERSCAPE_RC
135 bool "Layerscape PCIe Root Complex mode support"
Minghuan Lian80afc632016-12-13 14:54:17 +0800136 depends on DM_PCI
Hou Zhiqianged188aa2020-07-09 23:31:42 +0800137 select PCIE_LAYERSCAPE
Minghuan Lian80afc632016-12-13 14:54:17 +0800138 help
Hou Zhiqianged188aa2020-07-09 23:31:42 +0800139 Enable Layerscape PCIe Root Complex mode driver support. The Layerscape
140 SoC may have one or several PCIe controllers. Each controller can be
141 configured to Root Complex mode by clearing the corresponding bit of
142 RCW[HOST_AGT_PEX].
143
144config PCIE_LAYERSCAPE_EP
145 bool "Layerscape PCIe Endpoint mode support"
146 depends on DM_PCI
147 select PCIE_LAYERSCAPE
148 select PCI_ENDPOINT
149 help
150 Enable Layerscape PCIe Endpoint mode driver support. The Layerscape
151 SoC may have one or several PCIe controllers. Each controller can be
152 configured to Endpoint mode by setting the corresponding bit of
153 RCW[HOST_AGT_PEX].
Minghuan Lian80afc632016-12-13 14:54:17 +0800154
Hou Zhiqiang07ce19f2019-04-08 10:15:46 +0000155config PCIE_LAYERSCAPE_GEN4
156 bool "Layerscape Gen4 PCIe support"
157 depends on DM_PCI
158 help
159 Support PCIe Gen4 on NXP Layerscape SoCs, which may have one or
160 several PCIe controllers. The PCIe controller can work in RC or
161 EP mode according to RCW[HOST_AGT_PEX] setting.
162
Pankaj Bansalba7c9662019-11-30 13:14:00 +0000163config FSL_PCIE_COMPAT
164 string "PCIe compatible of Kernel DT"
Hou Zhiqianged188aa2020-07-09 23:31:42 +0800165 depends on PCIE_LAYERSCAPE_RC || PCIE_LAYERSCAPE_GEN4
Pankaj Bansalba7c9662019-11-30 13:14:00 +0000166 default "fsl,ls1012a-pcie" if ARCH_LS1012A
167 default "fsl,ls1028a-pcie" if ARCH_LS1028A
168 default "fsl,ls1043a-pcie" if ARCH_LS1043A
169 default "fsl,ls1046a-pcie" if ARCH_LS1046A
170 default "fsl,ls2080a-pcie" if ARCH_LS2080A
171 default "fsl,ls1088a-pcie" if ARCH_LS1088A
172 default "fsl,lx2160a-pcie" if ARCH_LX2160A
173 default "fsl,ls1021a-pcie" if ARCH_LS1021A
174 help
175 This compatible is used to find pci controller node in Kernel DT
176 to complete fixup.
177
Pankaj Bansal63618e72019-11-30 13:14:10 +0000178config FSL_PCIE_EP_COMPAT
179 string "PCIe EP compatible of Kernel DT"
Hou Zhiqianged188aa2020-07-09 23:31:42 +0800180 depends on PCIE_LAYERSCAPE_RC || PCIE_LAYERSCAPE_GEN4
Pankaj Bansal63618e72019-11-30 13:14:10 +0000181 default "fsl,lx2160a-pcie-ep" if ARCH_LX2160A
182 default "fsl,ls-pcie-ep"
183 help
184 This compatible is used to find pci controller ep node in Kernel DT
185 to complete fixup.
186
Ley Foon Tan7c458622018-04-20 21:55:45 +0800187config PCIE_INTEL_FPGA
188 bool "Intel FPGA PCIe support"
189 depends on DM_PCI
190 help
191 Say Y here if you want to enable PCIe controller support on Intel
192 FPGA, example Stratix 10.
193
Srinath Mannam48487042020-05-12 13:29:50 +0530194config PCIE_IPROC
195 bool "Iproc PCIe support"
196 depends on DM_PCI
197 help
198 Broadcom iProc PCIe controller driver.
199 Say Y here if you want to enable Broadcom iProc PCIe controller,
200
Stefan Roese94f453e2019-01-25 11:52:43 +0100201config PCI_MVEBU
202 bool "Enable Armada XP/38x PCIe driver"
203 depends on ARCH_MVEBU
204 select DM_PCI
205 select MISC
206 help
207 Say Y here if you want to enable PCIe controller support on
208 Armada XP/38x SoCs.
209
Sekhar Nori03c396b2019-08-01 19:12:57 +0530210config PCI_KEYSTONE
211 bool "TI Keystone PCIe controller"
212 depends on DM_PCI
213 help
214 Say Y here if you want to enable PCI controller support on AM654 SoC.
215
Ryder Lee42d37452019-08-22 12:26:49 +0200216config PCIE_MEDIATEK
217 bool "MediaTek PCIe Gen2 controller"
218 depends on DM_PCI
219 depends on ARCH_MEDIATEK
220 help
221 Say Y here if you want to enable Gen2 PCIe controller,
222 which could be found on MT7623 SoC family.
223
Jagan Teki99d59062020-05-09 22:26:21 +0530224config PCIE_ROCKCHIP
225 bool "Enable Rockchip PCIe driver"
226 select DM_PCI
Jagan Tekice920e02020-07-09 23:41:02 +0530227 select PHY_ROCKCHIP_PCIE
Jagan Teki99d59062020-05-09 22:26:21 +0530228 default y if ROCKCHIP_RK3399
229 help
230 Say Y here if you want to enable PCIe controller support on
231 Rockchip SoCs.
232
Sylwester Nawrocki7b1c3f62020-05-25 13:39:58 +0200233config PCI_BRCMSTB
234 bool "Broadcom STB PCIe controller"
235 depends on DM_PCI
236 depends on ARCH_BCM283X
237 help
238 Say Y here if you want to enable support for PCIe controller
239 on Broadcom set-top-box (STB) SoCs.
240 This driver currently supports only BCM2711 SoC and RC mode
241 of the controller.
Tom Riniaf273822016-10-26 17:15:37 -0400242endif