Kconfig 10.4 KB
Newer Older
1
# SPDX-License-Identifier: GPL-2.0-only
R
Randy Dunlap 已提交
2 3
menu "IRQ chip support"

4 5 6 7
config IRQCHIP
	def_bool y
	depends on OF_IRQ

8 9
config ARM_GIC
	bool
10
	select IRQ_DOMAIN_HIERARCHY
11
	select GENERIC_IRQ_MULTI_HANDLER
12
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
13

14 15 16 17 18
config ARM_GIC_PM
	bool
	depends on PM
	select ARM_GIC

19 20
config ARM_GIC_MAX_NR
	int
21
	depends on ARM_GIC
22 23 24
	default 2 if ARCH_REALVIEW
	default 1

25 26
config ARM_GIC_V2M
	bool
27 28 29
	depends on PCI
	select ARM_GIC
	select PCI_MSI
30

31 32 33
config GIC_NON_BANKED
	bool

34 35
config ARM_GIC_V3
	bool
36
	select GENERIC_IRQ_MULTI_HANDLER
37
	select IRQ_DOMAIN_HIERARCHY
38
	select PARTITION_PERCPU
39
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
40

41 42
config ARM_GIC_V3_ITS
	bool
43 44 45 46 47 48
	select GENERIC_MSI_IRQ_DOMAIN
	default ARM_GIC_V3

config ARM_GIC_V3_ITS_PCI
	bool
	depends on ARM_GIC_V3_ITS
49 50
	depends on PCI
	depends on PCI_MSI
51
	default ARM_GIC_V3_ITS
52

53 54 55 56 57 58
config ARM_GIC_V3_ITS_FSL_MC
	bool
	depends on ARM_GIC_V3_ITS
	depends on FSL_MC_BUS
	default ARM_GIC_V3_ITS

59 60
config ARM_NVIC
	bool
61
	select IRQ_DOMAIN_HIERARCHY
62 63
	select GENERIC_IRQ_CHIP

64 65 66
config ARM_VIC
	bool
	select IRQ_DOMAIN
67
	select GENERIC_IRQ_MULTI_HANDLER
68 69 70 71 72 73 74 75 76 77

config ARM_VIC_NR
	int
	default 4 if ARCH_S5PV210
	default 2
	depends on ARM_VIC
	help
	  The maximum number of VICs available in the system, for
	  power management.

78 79 80
config ARMADA_370_XP_IRQ
	bool
	select GENERIC_IRQ_CHIP
81
	select PCI_MSI if PCI
82
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
83

84 85
config ALPINE_MSI
	bool
86 87
	depends on PCI
	select PCI_MSI
88 89
	select GENERIC_IRQ_CHIP

90 91 92 93 94 95 96 97
config AL_FIC
	bool "Amazon's Annapurna Labs Fabric Interrupt Controller"
	depends on OF || COMPILE_TEST
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN
	help
	  Support Amazon's Annapurna Labs Fabric Interrupt Controller.

98 99 100 101
config ATMEL_AIC_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN
102
	select GENERIC_IRQ_MULTI_HANDLER
103 104 105 106 107 108
	select SPARSE_IRQ

config ATMEL_AIC5_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN
109
	select GENERIC_IRQ_MULTI_HANDLER
110 111
	select SPARSE_IRQ

112 113 114 115
config I8259
	bool
	select IRQ_DOMAIN

116 117 118 119
config BCM6345_L1_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN
120
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
121

122 123 124 125
config BCM7038_L1_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN
126
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
127

128 129 130 131 132
config BCM7120_L2_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

133 134 135 136 137
config BRCMSTB_L2_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

138 139 140 141 142
config DAVINCI_AINTC
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

143 144 145 146 147
config DAVINCI_CP_INTC
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

148 149
config DW_APB_ICTL
	bool
150
	select GENERIC_IRQ_CHIP
151 152
	select IRQ_DOMAIN

153 154 155
config FARADAY_FTINTC010
	bool
	select IRQ_DOMAIN
156
	select GENERIC_IRQ_MULTI_HANDLER
157 158
	select SPARSE_IRQ

159 160 161 162 163
config HISILICON_IRQ_MBIGEN
	bool
	select ARM_GIC_V3
	select ARM_GIC_V3_ITS

164 165 166 167 168
config IMGPDC_IRQ
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

L
Linus Walleij 已提交
169 170 171 172 173 174
config IXP4XX_IRQ
	bool
	select IRQ_DOMAIN
	select GENERIC_IRQ_MULTI_HANDLER
	select SPARSE_IRQ

175 176 177
config MADERA_IRQ
	tristate

178 179 180
config IRQ_MIPS_CPU
	bool
	select GENERIC_IRQ_CHIP
181
	select GENERIC_IRQ_IPI if SYS_SUPPORTS_MULTITHREADING
182
	select IRQ_DOMAIN
183
	select IRQ_DOMAIN_HIERARCHY if GENERIC_IRQ_IPI
184
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
185

186 187 188 189
config CLPS711X_IRQCHIP
	bool
	depends on ARCH_CLPS711X
	select IRQ_DOMAIN
190
	select GENERIC_IRQ_MULTI_HANDLER
191 192 193
	select SPARSE_IRQ
	default y

194 195 196
config OMPIC
	bool

197 198 199 200
config OR1K_PIC
	bool
	select IRQ_DOMAIN

201 202 203 204 205
config OMAP_IRQCHIP
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

206 207 208
config ORION_IRQCHIP
	bool
	select IRQ_DOMAIN
209
	select GENERIC_IRQ_MULTI_HANDLER
210

211 212 213 214 215
config PIC32_EVIC
	bool
	select GENERIC_IRQ_CHIP
	select IRQ_DOMAIN

216
config JCORE_AIC
217 218
	bool "J-Core integrated AIC" if COMPILE_TEST
	depends on OF
219 220 221 222
	select IRQ_DOMAIN
	help
	  Support for the J-Core integrated AIC.

223 224 225 226
config RDA_INTC
	bool
	select IRQ_DOMAIN

227
config RENESAS_INTC_IRQPIN
228
	bool "Renesas INTC External IRQ Pin Support" if COMPILE_TEST
229
	select IRQ_DOMAIN
230 231 232
	help
	  Enable support for the Renesas Interrupt Controller for external
	  interrupt pins, as found on SH/R-Mobile and R-Car Gen1 SoCs.
233

M
Magnus Damm 已提交
234
config RENESAS_IRQC
235
	bool "Renesas R-Mobile APE6 and R-Car IRQC support" if COMPILE_TEST
236
	select GENERIC_IRQ_CHIP
M
Magnus Damm 已提交
237
	select IRQ_DOMAIN
238 239 240
	help
	  Enable support for the Renesas Interrupt Controller for external
	  devices, as found on R-Mobile APE6, R-Car Gen2, and R-Car Gen3 SoCs.
M
Magnus Damm 已提交
241

242
config RENESAS_RZA1_IRQC
243
	bool "Renesas RZ/A1 IRQC support" if COMPILE_TEST
244
	select IRQ_DOMAIN_HIERARCHY
245 246 247
	help
	  Enable support for the Renesas RZ/A1 Interrupt Controller, to use up
	  to 8 external interrupts with configurable sense select.
248

249 250 251 252 253 254 255
config ST_IRQCHIP
	bool
	select REGMAP
	select MFD_SYSCON
	help
	  Enables SysCfg Controlled IRQs on STi based platforms.

256 257 258 259 260
config TANGO_IRQ
	bool
	select IRQ_DOMAIN
	select GENERIC_IRQ_CHIP

261 262 263 264 265
config TB10X_IRQC
	bool
	select IRQ_DOMAIN
	select GENERIC_IRQ_CHIP

266 267 268
config TS4800_IRQ
	tristate "TS-4800 IRQ controller"
	select IRQ_DOMAIN
269
	depends on HAS_IOMEM
270
	depends on SOC_IMX51 || COMPILE_TEST
271 272 273
	help
	  Support for the TS-4800 FPGA IRQ controller

274 275 276 277 278 279 280 281
config VERSATILE_FPGA_IRQ
	bool
	select IRQ_DOMAIN

config VERSATILE_FPGA_IRQ_NR
       int
       default 4
       depends on VERSATILE_FPGA_IRQ
M
Max Filippov 已提交
282 283 284 285

config XTENSA_MX
	bool
	select IRQ_DOMAIN
286
	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
287

288 289 290 291
config XILINX_INTC
	bool
	select IRQ_DOMAIN

292 293 294
config IRQ_CROSSBAR
	bool
	help
M
Masanari Iida 已提交
295
	  Support for a CROSSBAR ip that precedes the main interrupt controller.
296 297 298
	  The primary irqchip invokes the crossbar's callback which inturn allocates
	  a free irq and configures the IP. Thus the peripheral interrupts are
	  routed to one of the free irqchip interrupt lines.
299 300 301 302 303 304 305

config KEYSTONE_IRQ
	tristate "Keystone 2 IRQ controller IP"
	depends on ARCH_KEYSTONE
	help
		Support for Texas Instruments Keystone 2 IRQ controller IP which
		is part of the Keystone 2 IPC mechanism
306 307 308

config MIPS_GIC
	bool
309
	select GENERIC_IRQ_IPI
310
	select IRQ_DOMAIN_HIERARCHY
311
	select MIPS_CM
Y
Yoshinori Sato 已提交
312

313 314 315 316
config INGENIC_IRQ
	bool
	depends on MACH_INGENIC
	default y
317

318 319 320 321 322 323 324 325 326 327 328
config INGENIC_TCU_IRQ
	bool "Ingenic JZ47xx TCU interrupt controller"
	default MACH_INGENIC
	depends on MIPS || COMPILE_TEST
	select MFD_SYSCON
	help
	  Support for interrupts in the Timer/Counter Unit (TCU) of the Ingenic
	  JZ47xx SoCs.

	  If unsure, say N.

Y
Yoshinori Sato 已提交
329 330 331 332 333
config RENESAS_H8300H_INTC
        bool
	select IRQ_DOMAIN

config RENESAS_H8S_INTC
334
	bool "Renesas H8S Interrupt Controller Support" if COMPILE_TEST
335
	select IRQ_DOMAIN
336 337 338
	help
	  Enable support for the Renesas H8/300 Interrupt Controller, as found
	  on Renesas H8S SoCs.
339 340 341 342 343 344

config IMX_GPCV2
	bool
	select IRQ_DOMAIN
	help
	  Enables the wakeup IRQs for IMX platforms with GPCv2 block
345 346 347 348 349

config IRQ_MXS
	def_bool y if MACH_ASM9260 || ARCH_MXS
	select IRQ_DOMAIN
	select STMP_DEVICE
350

351 352 353 354 355
config MSCC_OCELOT_IRQ
	bool
	select IRQ_DOMAIN
	select GENERIC_IRQ_CHIP

356 357 358
config MVEBU_GICP
	bool

359 360 361
config MVEBU_ICU
	bool

362 363
config MVEBU_ODMI
	bool
364
	select GENERIC_MSI_IRQ_DOMAIN
365

366 367 368
config MVEBU_PIC
	bool

369 370 371
config MVEBU_SEI
        bool

372 373 374 375
config LS_SCFG_MSI
	def_bool y if SOC_LS1021A || ARCH_LAYERSCAPE
	depends on PCI && PCI_MSI

376 377
config PARTITION_PERCPU
	bool
378

379 380
config EZNPS_GIC
	bool "NPS400 Global Interrupt Manager (GIM)"
381
	depends on ARC || (COMPILE_TEST && !64BIT)
382 383 384
	select IRQ_DOMAIN
	help
	  Support the EZchip NPS400 global interrupt controller
385 386 387 388

config STM32_EXTI
	bool
	select IRQ_DOMAIN
389
	select GENERIC_IRQ_CHIP
390 391 392 393 394 395 396 397

config QCOM_IRQ_COMBINER
	bool "QCOM IRQ combiner support"
	depends on ARCH_QCOM && ACPI
	select IRQ_DOMAIN_HIERARCHY
	help
	  Say yes here to add support for the IRQ combiner devices embedded
	  in Qualcomm Technologies chips.
398 399 400 401 402 403 404 405

config IRQ_UNIPHIER_AIDET
	bool "UniPhier AIDET support" if COMPILE_TEST
	depends on ARCH_UNIPHIER || COMPILE_TEST
	default ARCH_UNIPHIER
	select IRQ_DOMAIN_HIERARCHY
	help
	  Support for the UniPhier AIDET (ARM Interrupt Detector).
R
Randy Dunlap 已提交
406

407 408
config MESON_IRQ_GPIO
       bool "Meson GPIO Interrupt Multiplexer"
409
       depends on ARCH_MESON
410 411 412 413
       select IRQ_DOMAIN_HIERARCHY
       help
         Support Meson SoC Family GPIO Interrupt Multiplexer

414 415 416 417 418 419 420 421
config GOLDFISH_PIC
       bool "Goldfish programmable interrupt controller"
       depends on MIPS && (GOLDFISH || COMPILE_TEST)
       select IRQ_DOMAIN
       help
         Say yes here to enable Goldfish interrupt controller driver used
         for Goldfish based virtual platforms.

422 423 424 425 426 427 428 429
config QCOM_PDC
	bool "QCOM PDC"
	depends on ARCH_QCOM
	select IRQ_DOMAIN_HIERARCHY
	help
	  Power Domain Controller driver to manage and configure wakeup
	  IRQs for Qualcomm Technologies Inc (QTI) mobile chips.

430 431 432 433 434 435 436 437 438
config CSKY_MPINTC
	bool "C-SKY Multi Processor Interrupt Controller"
	depends on CSKY
	help
	  Say yes here to enable C-SKY SMP interrupt controller driver used
	  for C-SKY SMP system.
	  In fact it's not mmio map in hw and it use ld/st to visit the
	  controller's register inside CPU.

439 440 441 442 443 444 445 446
config CSKY_APB_INTC
	bool "C-SKY APB Interrupt Controller"
	depends on CSKY
	help
	  Say yes here to enable C-SKY APB interrupt controller driver used
	  by C-SKY single core SOC system. It use mmio map apb-bus to visit
	  the controller's register.

447 448 449 450 451 452 453 454
config IMX_IRQSTEER
	bool "i.MX IRQSTEER support"
	depends on ARCH_MXC || COMPILE_TEST
	default ARCH_MXC
	select IRQ_DOMAIN
	help
	  Support for the i.MX IRQSTEER interrupt multiplexer/remapper.

455 456 457 458 459 460 461 462 463
config LS1X_IRQ
	bool "Loongson-1 Interrupt Controller"
	depends on MACH_LOONGSON32
	default y
	select IRQ_DOMAIN
	select GENERIC_IRQ_CHIP
	help
	  Support for the Loongson-1 platform Interrupt Controller.

464 465 466 467 468 469 470 471 472 473
config TI_SCI_INTR_IRQCHIP
	bool
	depends on TI_SCI_PROTOCOL
	select IRQ_DOMAIN_HIERARCHY
	help
	  This enables the irqchip driver support for K3 Interrupt router
	  over TI System Control Interface available on some new TI's SoCs.
	  If you wish to use interrupt router irq resources managed by the
	  TI System Controller, say Y here. Otherwise, say N.

474 475 476 477
config TI_SCI_INTA_IRQCHIP
	bool
	depends on TI_SCI_PROTOCOL
	select IRQ_DOMAIN_HIERARCHY
478
	select TI_SCI_INTA_MSI_DOMAIN
479 480 481 482 483 484
	help
	  This enables the irqchip driver support for K3 Interrupt aggregator
	  over TI System Control Interface available on some new TI's SoCs.
	  If you wish to use interrupt aggregator irq resources managed by the
	  TI System Controller, say Y here. Otherwise, say N.

R
Randy Dunlap 已提交
485
endmenu
486 487 488 489 490 491 492 493 494 495 496 497

config SIFIVE_PLIC
	bool "SiFive Platform-Level Interrupt Controller"
	depends on RISCV
	help
	   This enables support for the PLIC chip found in SiFive (and
	   potentially other) RISC-V systems.  The PLIC controls devices
	   interrupts and connects them to each core's local interrupt
	   controller.  Aside from timer and software interrupts, all other
	   interrupt sources are subordinate to the PLIC.

	   If you don't know what to do here, say Y.