hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
# SPDX-License-Identifier: GPL-2.0
 
menu "DesignWare PCI Core Support"
   depends on PCI
 
config PCIE_DW
   bool
 
config PCIE_DW_HOST
   bool
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW
 
config PCIE_DW_EP
   bool
   depends on PCI_ENDPOINT
   select PCIE_DW
 
config PCI_DRA7XX
   bool
 
config PCI_DRA7XX_HOST
   bool "TI DRA7xx PCIe controller Host Mode"
   depends on SOC_DRA7XX || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   depends on OF && HAS_IOMEM && TI_PIPE3
   select PCIE_DW_HOST
   select PCI_DRA7XX
   default y if SOC_DRA7XX
   help
     Enables support for the PCIe controller in the DRA7xx SoC to work in
     host mode. There are two instances of PCIe controller in DRA7xx.
     This controller can work either as EP or RC. In order to enable
     host-specific features PCI_DRA7XX_HOST must be selected and in order
     to enable device-specific features PCI_DRA7XX_EP must be selected.
     This uses the DesignWare core.
 
config PCI_DRA7XX_EP
   bool "TI DRA7xx PCIe controller Endpoint Mode"
   depends on SOC_DRA7XX || COMPILE_TEST
   depends on PCI_ENDPOINT
   depends on OF && HAS_IOMEM && TI_PIPE3
   select PCIE_DW_EP
   select PCI_DRA7XX
   help
     Enables support for the PCIe controller in the DRA7xx SoC to work in
     endpoint mode. There are two instances of PCIe controller in DRA7xx.
     This controller can work either as EP or RC. In order to enable
     host-specific features PCI_DRA7XX_HOST must be selected and in order
     to enable device-specific features PCI_DRA7XX_EP must be selected.
     This uses the DesignWare core.
 
config PCIE_DW_PLAT
   bool
 
config PCIE_DW_PLAT_HOST
   bool "Platform bus based DesignWare PCIe Controller - Host mode"
   depends on PCI && PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   select PCIE_DW_PLAT
   help
     Enables support for the PCIe controller in the Designware IP to
     work in host mode. There are two instances of PCIe controller in
     Designware IP.
     This controller can work either as EP or RC. In order to enable
     host-specific features PCIE_DW_PLAT_HOST must be selected and in
     order to enable device-specific features PCI_DW_PLAT_EP must be
     selected.
 
config PCIE_DW_PLAT_EP
   bool "Platform bus based DesignWare PCIe Controller - Endpoint mode"
   depends on PCI && PCI_MSI_IRQ_DOMAIN
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   select PCIE_DW_PLAT
   help
     Enables support for the PCIe controller in the Designware IP to
     work in endpoint mode. There are two instances of PCIe controller
     in Designware IP.
     This controller can work either as EP or RC. In order to enable
     host-specific features PCIE_DW_PLAT_HOST must be selected and in
     order to enable device-specific features PCI_DW_PLAT_EP must be
     selected.
 
config PCIE_DW_ROCKCHIP
   tristate "Rockchip DesignWare PCIe controller"
   select PCIE_DW
   select PCIE_DW_HOST
   depends on ARCH_ROCKCHIP
   depends on OF
   help
     Enables support for the DW PCIe controller in the Rockchip SoC.
 
config PCIE_RK_THREADED_INIT
   bool "Threaded initialize Rockchip DW based PCIe controller"
   depends on PCIE_DW_ROCKCHIP
   default y
   help
     Enables threaded initialize Rockchip DW based PCIe controller.
 
config PCIE_DW_DMATEST
   bool "DesignWare PCIe DMA test"
   depends on PCIE_DW_ROCKCHIP
   depends on !ROCKCHIP_PCIE_DMA_OBJ
   help
     Enables support for the DW PCIe controller DMA test.
 
config PCIE_DW_ROCKCHIP_EP
   bool "Rockchip DesignWare PCIe EP controller"
   select PCIE_DW
   depends on ARCH_ROCKCHIP
   depends on OF
   help
     Enables support for the DW PCIe controller in the Rockchip SoC.
 
config PCI_EXYNOS
   bool "Samsung Exynos PCIe controller"
   depends on SOC_EXYNOS5440 || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
 
config PCI_IMX6
   bool "Freescale i.MX6/7/8 PCIe controller"
   depends on ARCH_MXC || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
 
config PCIE_SPEAR13XX
   bool "STMicroelectronics SPEAr PCIe controller"
   depends on ARCH_SPEAR13XX || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here if you want PCIe support on SPEAr13XX SoCs.
 
config PCI_KEYSTONE
   bool
 
config PCI_KEYSTONE_HOST
   bool "PCI Keystone Host Mode"
   depends on ARCH_KEYSTONE || ARCH_K3 || ((ARM || ARM64) && COMPILE_TEST)
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   select PCI_KEYSTONE
   help
     Enables support for the PCIe controller in the Keystone SoC to
     work in host mode. The PCI controller on Keystone is based on
     DesignWare hardware and therefore the driver re-uses the
     DesignWare core functions to implement the driver.
 
config PCI_KEYSTONE_EP
   bool "PCI Keystone Endpoint Mode"
   depends on ARCH_KEYSTONE || ARCH_K3 || ((ARM || ARM64) && COMPILE_TEST)
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   select PCI_KEYSTONE
   help
     Enables support for the PCIe controller in the Keystone SoC to
     work in endpoint mode. The PCI controller on Keystone is based
     on DesignWare hardware and therefore the driver re-uses the
     DesignWare core functions to implement the driver.
 
config PCI_LAYERSCAPE
   bool "Freescale Layerscape PCIe controller - Host mode"
   depends on OF && (ARM || ARCH_LAYERSCAPE || COMPILE_TEST)
   depends on PCI_MSI_IRQ_DOMAIN
   select MFD_SYSCON
   select PCIE_DW_HOST
   help
     Say Y here if you want to enable PCIe controller support on Layerscape
     SoCs to work in Host mode.
     This controller can work either as EP or RC. The RCW[HOST_AGT_PEX]
     determines which PCIe controller works in EP mode and which PCIe
     controller works in RC mode.
 
config PCI_LAYERSCAPE_EP
   bool "Freescale Layerscape PCIe controller - Endpoint mode"
   depends on OF && (ARM || ARCH_LAYERSCAPE || COMPILE_TEST)
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   help
     Say Y here if you want to enable PCIe controller support on Layerscape
     SoCs to work in Endpoint mode.
     This controller can work either as EP or RC. The RCW[HOST_AGT_PEX]
     determines which PCIe controller works in EP mode and which PCIe
     controller works in RC mode.
 
config PCI_HISI
   depends on OF && (ARM64 || COMPILE_TEST)
   bool "HiSilicon Hip05 and Hip06 SoCs PCIe controllers"
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   select PCI_HOST_COMMON
   help
     Say Y here if you want PCIe controller support on HiSilicon
     Hip05 and Hip06 SoCs
 
config PCIE_QCOM
   bool "Qualcomm PCIe controller"
   depends on OF && (ARCH_QCOM || COMPILE_TEST)
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here to enable PCIe controller support on Qualcomm SoCs. The
     PCIe controller uses the DesignWare core plus Qualcomm-specific
     hardware wrappers.
 
config PCIE_ARMADA_8K
   bool "Marvell Armada-8K PCIe controller"
   depends on ARCH_MVEBU || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   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.
 
config PCIE_ARTPEC6
   bool
 
config PCIE_ARTPEC6_HOST
   bool "Axis ARTPEC-6 PCIe controller Host Mode"
   depends on MACH_ARTPEC6 || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   select PCIE_ARTPEC6
   help
     Enables support for the PCIe controller in the ARTPEC-6 SoC to work in
     host mode. This uses the DesignWare core.
 
config PCIE_ARTPEC6_EP
   bool "Axis ARTPEC-6 PCIe controller Endpoint Mode"
   depends on MACH_ARTPEC6 || COMPILE_TEST
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   select PCIE_ARTPEC6
   help
     Enables support for the PCIe controller in the ARTPEC-6 SoC to work in
     endpoint mode. This uses the DesignWare core.
 
config PCIE_INTEL_GW
   bool "Intel Gateway PCIe host controller support"
   depends on OF && (X86 || COMPILE_TEST)
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say 'Y' here to enable PCIe Host controller support on Intel
     Gateway SoCs.
     The PCIe controller uses the DesignWare core plus Intel-specific
     hardware wrappers.
 
config PCIE_KIRIN
   depends on OF && (ARM64 || COMPILE_TEST)
   bool "HiSilicon Kirin series SoCs PCIe controllers"
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here if you want PCIe controller support
     on HiSilicon Kirin series SoCs.
 
config PCIE_HISI_STB
   bool "HiSilicon STB SoCs PCIe controllers"
   depends on ARCH_HISI || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here if you want PCIe controller support on HiSilicon STB SoCs
 
config PCI_MESON
   tristate "MESON PCIe controller"
   depends on PCI_MSI_IRQ_DOMAIN
   default m if ARCH_MESON
   select PCIE_DW_HOST
   help
     Say Y here if you want to enable PCI controller support on Amlogic
     SoCs. The PCI controller on Amlogic is based on DesignWare hardware
     and therefore the driver re-uses the DesignWare core functions to
     implement the driver.
 
config PCIE_TEGRA194
   tristate
 
config PCIE_TEGRA194_HOST
   tristate "NVIDIA Tegra194 (and later) PCIe controller - Host Mode"
   depends on ARCH_TEGRA_194_SOC || COMPILE_TEST
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   select PHY_TEGRA194_P2U
   select PCIE_TEGRA194
   help
     Enables support for the PCIe controller in the NVIDIA Tegra194 SoC to
     work in host mode. There are two instances of PCIe controllers in
     Tegra194. This controller can work either as EP or RC. In order to
     enable host-specific features PCIE_TEGRA194_HOST must be selected and
     in order to enable device-specific features PCIE_TEGRA194_EP must be
     selected. This uses the DesignWare core.
 
config PCIE_TEGRA194_EP
   tristate "NVIDIA Tegra194 (and later) PCIe controller - Endpoint Mode"
   depends on ARCH_TEGRA_194_SOC || COMPILE_TEST
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   select PHY_TEGRA194_P2U
   select PCIE_TEGRA194
   help
     Enables support for the PCIe controller in the NVIDIA Tegra194 SoC to
     work in host mode. There are two instances of PCIe controllers in
     Tegra194. This controller can work either as EP or RC. In order to
     enable host-specific features PCIE_TEGRA194_HOST must be selected and
     in order to enable device-specific features PCIE_TEGRA194_EP must be
     selected. This uses the DesignWare core.
 
config PCIE_UNIPHIER
   bool "Socionext UniPhier PCIe host controllers"
   depends on ARCH_UNIPHIER || COMPILE_TEST
   depends on OF && HAS_IOMEM
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here if you want PCIe host controller support on UniPhier SoCs.
     This driver supports LD20 and PXs3 SoCs.
 
config PCIE_UNIPHIER_EP
   bool "Socionext UniPhier PCIe endpoint controllers"
   depends on ARCH_UNIPHIER || COMPILE_TEST
   depends on OF && HAS_IOMEM
   depends on PCI_ENDPOINT
   select PCIE_DW_EP
   help
     Say Y here if you want PCIe endpoint controller support on
     UniPhier SoCs. This driver supports Pro5 SoC.
 
config PCIE_AL
   bool "Amazon Annapurna Labs PCIe controller"
   depends on OF && (ARM64 || COMPILE_TEST)
   depends on PCI_MSI_IRQ_DOMAIN
   select PCIE_DW_HOST
   help
     Say Y here to enable support of the Amazon's Annapurna Labs PCIe
     controller IP on Amazon SoCs. The PCIe controller uses the DesignWare
     core plus Annapurna Labs proprietary hardware wrappers. This is
     required only for DT-based platforms. ACPI platforms with the
     Annapurna Labs PCIe controller don't need to enable this.
 
endmenu