xref: /linux/drivers/irqchip/Kconfig (revision a890caeb2ba40ca183969230e204ab144f258357)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
2c94fb639SRandy Dunlapmenu "IRQ chip support"
3c94fb639SRandy Dunlap
4f6e916b8SThomas Petazzoniconfig IRQCHIP
5f6e916b8SThomas Petazzoni	def_bool y
6f6e916b8SThomas Petazzoni	depends on OF_IRQ
7f6e916b8SThomas Petazzoni
881243e44SRob Herringconfig ARM_GIC
981243e44SRob Herring	bool
109a1091efSYingjoe Chen	select IRQ_DOMAIN_HIERARCHY
114f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
120c9e4982SMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
1381243e44SRob Herring
149c8edddfSJon Hunterconfig ARM_GIC_PM
159c8edddfSJon Hunter	bool
169c8edddfSJon Hunter	depends on PM
179c8edddfSJon Hunter	select ARM_GIC
189c8edddfSJon Hunter
19a27d21e0SLinus Walleijconfig ARM_GIC_MAX_NR
20a27d21e0SLinus Walleij	int
2170265523SJiangfeng Xiao	depends on ARM_GIC
22a27d21e0SLinus Walleij	default 2 if ARCH_REALVIEW
23a27d21e0SLinus Walleij	default 1
24a27d21e0SLinus Walleij
25853a33ceSSuravee Suthikulpanitconfig ARM_GIC_V2M
26853a33ceSSuravee Suthikulpanit	bool
273ee80364SArnd Bergmann	depends on PCI
283ee80364SArnd Bergmann	select ARM_GIC
293ee80364SArnd Bergmann	select PCI_MSI
30853a33ceSSuravee Suthikulpanit
3181243e44SRob Herringconfig GIC_NON_BANKED
3281243e44SRob Herring	bool
3381243e44SRob Herring
34021f6537SMarc Zyngierconfig ARM_GIC_V3
35021f6537SMarc Zyngier	bool
364f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
37443acc4fSMarc Zyngier	select IRQ_DOMAIN_HIERARCHY
38e3825ba1SMarc Zyngier	select PARTITION_PERCPU
39956ae91aSMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
40021f6537SMarc Zyngier
4119812729SMarc Zyngierconfig ARM_GIC_V3_ITS
4219812729SMarc Zyngier	bool
4329f41139SMarc Zyngier	select GENERIC_MSI_IRQ_DOMAIN
4429f41139SMarc Zyngier	default ARM_GIC_V3
4529f41139SMarc Zyngier
4629f41139SMarc Zyngierconfig ARM_GIC_V3_ITS_PCI
4729f41139SMarc Zyngier	bool
4829f41139SMarc Zyngier	depends on ARM_GIC_V3_ITS
493ee80364SArnd Bergmann	depends on PCI
503ee80364SArnd Bergmann	depends on PCI_MSI
5129f41139SMarc Zyngier	default ARM_GIC_V3_ITS
52292ec080SUwe Kleine-König
537afe031cSBogdan Purcareataconfig ARM_GIC_V3_ITS_FSL_MC
547afe031cSBogdan Purcareata	bool
557afe031cSBogdan Purcareata	depends on ARM_GIC_V3_ITS
567afe031cSBogdan Purcareata	depends on FSL_MC_BUS
577afe031cSBogdan Purcareata	default ARM_GIC_V3_ITS
587afe031cSBogdan Purcareata
5944430ec0SRob Herringconfig ARM_NVIC
6044430ec0SRob Herring	bool
612d9f59f7SStefan Agner	select IRQ_DOMAIN_HIERARCHY
6244430ec0SRob Herring	select GENERIC_IRQ_CHIP
6344430ec0SRob Herring
6444430ec0SRob Herringconfig ARM_VIC
6544430ec0SRob Herring	bool
6644430ec0SRob Herring	select IRQ_DOMAIN
674f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
6844430ec0SRob Herring
6944430ec0SRob Herringconfig ARM_VIC_NR
7044430ec0SRob Herring	int
7144430ec0SRob Herring	default 4 if ARCH_S5PV210
7244430ec0SRob Herring	default 2
7344430ec0SRob Herring	depends on ARM_VIC
7444430ec0SRob Herring	help
7544430ec0SRob Herring	  The maximum number of VICs available in the system, for
7644430ec0SRob Herring	  power management.
7744430ec0SRob Herring
78fed6d336SThomas Petazzoniconfig ARMADA_370_XP_IRQ
79fed6d336SThomas Petazzoni	bool
80fed6d336SThomas Petazzoni	select GENERIC_IRQ_CHIP
813ee80364SArnd Bergmann	select PCI_MSI if PCI
82e31793a3SMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
83fed6d336SThomas Petazzoni
84e6b78f2cSAntoine Tenartconfig ALPINE_MSI
85e6b78f2cSAntoine Tenart	bool
863ee80364SArnd Bergmann	depends on PCI
873ee80364SArnd Bergmann	select PCI_MSI
88e6b78f2cSAntoine Tenart	select GENERIC_IRQ_CHIP
89e6b78f2cSAntoine Tenart
901eb77c3bSTalel Shenharconfig AL_FIC
911eb77c3bSTalel Shenhar	bool "Amazon's Annapurna Labs Fabric Interrupt Controller"
921eb77c3bSTalel Shenhar	depends on OF || COMPILE_TEST
931eb77c3bSTalel Shenhar	select GENERIC_IRQ_CHIP
941eb77c3bSTalel Shenhar	select IRQ_DOMAIN
951eb77c3bSTalel Shenhar	help
961eb77c3bSTalel Shenhar	  Support Amazon's Annapurna Labs Fabric Interrupt Controller.
971eb77c3bSTalel Shenhar
98b1479ebbSBoris BREZILLONconfig ATMEL_AIC_IRQ
99b1479ebbSBoris BREZILLON	bool
100b1479ebbSBoris BREZILLON	select GENERIC_IRQ_CHIP
101b1479ebbSBoris BREZILLON	select IRQ_DOMAIN
1024f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
103b1479ebbSBoris BREZILLON	select SPARSE_IRQ
104b1479ebbSBoris BREZILLON
105b1479ebbSBoris BREZILLONconfig ATMEL_AIC5_IRQ
106b1479ebbSBoris BREZILLON	bool
107b1479ebbSBoris BREZILLON	select GENERIC_IRQ_CHIP
108b1479ebbSBoris BREZILLON	select IRQ_DOMAIN
1094f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
110b1479ebbSBoris BREZILLON	select SPARSE_IRQ
111b1479ebbSBoris BREZILLON
1120509cfdeSRalf Baechleconfig I8259
1130509cfdeSRalf Baechle	bool
1140509cfdeSRalf Baechle	select IRQ_DOMAIN
1150509cfdeSRalf Baechle
116c7c42ec2SSimon Arlottconfig BCM6345_L1_IRQ
117c7c42ec2SSimon Arlott	bool
118c7c42ec2SSimon Arlott	select GENERIC_IRQ_CHIP
119c7c42ec2SSimon Arlott	select IRQ_DOMAIN
120d0ed5e8eSMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
121c7c42ec2SSimon Arlott
1225f7f0317SKevin Cernekeeconfig BCM7038_L1_IRQ
1235f7f0317SKevin Cernekee	bool
1245f7f0317SKevin Cernekee	select GENERIC_IRQ_CHIP
1255f7f0317SKevin Cernekee	select IRQ_DOMAIN
126b8d9884aSMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
1275f7f0317SKevin Cernekee
128a4fcbb86SKevin Cernekeeconfig BCM7120_L2_IRQ
129a4fcbb86SKevin Cernekee	bool
130a4fcbb86SKevin Cernekee	select GENERIC_IRQ_CHIP
131a4fcbb86SKevin Cernekee	select IRQ_DOMAIN
132a4fcbb86SKevin Cernekee
1337f646e92SFlorian Fainelliconfig BRCMSTB_L2_IRQ
1347f646e92SFlorian Fainelli	bool
1357f646e92SFlorian Fainelli	select GENERIC_IRQ_CHIP
1367f646e92SFlorian Fainelli	select IRQ_DOMAIN
1377f646e92SFlorian Fainelli
1380145beedSBartosz Golaszewskiconfig DAVINCI_AINTC
1390145beedSBartosz Golaszewski	bool
1400145beedSBartosz Golaszewski	select GENERIC_IRQ_CHIP
1410145beedSBartosz Golaszewski	select IRQ_DOMAIN
1420145beedSBartosz Golaszewski
1430fc3d74cSBartosz Golaszewskiconfig DAVINCI_CP_INTC
1440fc3d74cSBartosz Golaszewski	bool
1450fc3d74cSBartosz Golaszewski	select GENERIC_IRQ_CHIP
1460fc3d74cSBartosz Golaszewski	select IRQ_DOMAIN
1470fc3d74cSBartosz Golaszewski
148350d71b9SSebastian Hesselbarthconfig DW_APB_ICTL
149350d71b9SSebastian Hesselbarth	bool
150e1588490SJisheng Zhang	select GENERIC_IRQ_CHIP
15154a38440SZhen Lei	select IRQ_DOMAIN_HIERARCHY
152350d71b9SSebastian Hesselbarth
1536ee532e2SLinus Walleijconfig FARADAY_FTINTC010
1546ee532e2SLinus Walleij	bool
1556ee532e2SLinus Walleij	select IRQ_DOMAIN
1564f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
1576ee532e2SLinus Walleij	select SPARSE_IRQ
1586ee532e2SLinus Walleij
1599a7c4abdSMaJunconfig HISILICON_IRQ_MBIGEN
1609a7c4abdSMaJun	bool
1619a7c4abdSMaJun	select ARM_GIC_V3
1629a7c4abdSMaJun	select ARM_GIC_V3_ITS
1639a7c4abdSMaJun
164b6ef9161SJames Hoganconfig IMGPDC_IRQ
165b6ef9161SJames Hogan	bool
166b6ef9161SJames Hogan	select GENERIC_IRQ_CHIP
167b6ef9161SJames Hogan	select IRQ_DOMAIN
168b6ef9161SJames Hogan
1695b978c10SLinus Walleijconfig IXP4XX_IRQ
1705b978c10SLinus Walleij	bool
1715b978c10SLinus Walleij	select IRQ_DOMAIN
1725b978c10SLinus Walleij	select GENERIC_IRQ_MULTI_HANDLER
1735b978c10SLinus Walleij	select SPARSE_IRQ
1745b978c10SLinus Walleij
175da0abe1aSRichard Fitzgeraldconfig MADERA_IRQ
176da0abe1aSRichard Fitzgerald	tristate
177da0abe1aSRichard Fitzgerald
17867e38cf2SRalf Baechleconfig IRQ_MIPS_CPU
17967e38cf2SRalf Baechle	bool
18067e38cf2SRalf Baechle	select GENERIC_IRQ_CHIP
1813838a547SPaul Burton	select GENERIC_IRQ_IPI if SYS_SUPPORTS_MULTITHREADING
18267e38cf2SRalf Baechle	select IRQ_DOMAIN
18318416e45SMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
18467e38cf2SRalf Baechle
185afc98d90SAlexander Shiyanconfig CLPS711X_IRQCHIP
186afc98d90SAlexander Shiyan	bool
187afc98d90SAlexander Shiyan	depends on ARCH_CLPS711X
188afc98d90SAlexander Shiyan	select IRQ_DOMAIN
1894f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
190afc98d90SAlexander Shiyan	select SPARSE_IRQ
191afc98d90SAlexander Shiyan	default y
192afc98d90SAlexander Shiyan
1939b54470aSStafford Horneconfig OMPIC
1949b54470aSStafford Horne	bool
1959b54470aSStafford Horne
1964db8e6d2SStefan Kristianssonconfig OR1K_PIC
1974db8e6d2SStefan Kristiansson	bool
1984db8e6d2SStefan Kristiansson	select IRQ_DOMAIN
1994db8e6d2SStefan Kristiansson
2008598066cSFelipe Balbiconfig OMAP_IRQCHIP
2018598066cSFelipe Balbi	bool
2028598066cSFelipe Balbi	select GENERIC_IRQ_CHIP
2038598066cSFelipe Balbi	select IRQ_DOMAIN
2048598066cSFelipe Balbi
2059dbd90f1SSebastian Hesselbarthconfig ORION_IRQCHIP
2069dbd90f1SSebastian Hesselbarth	bool
2079dbd90f1SSebastian Hesselbarth	select IRQ_DOMAIN
2084f7799d9SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
2099dbd90f1SSebastian Hesselbarth
210aaa8666aSCristian Birsanconfig PIC32_EVIC
211aaa8666aSCristian Birsan	bool
212aaa8666aSCristian Birsan	select GENERIC_IRQ_CHIP
213aaa8666aSCristian Birsan	select IRQ_DOMAIN
214aaa8666aSCristian Birsan
215981b58f6SRich Felkerconfig JCORE_AIC
2163602ffdeSRich Felker	bool "J-Core integrated AIC" if COMPILE_TEST
2173602ffdeSRich Felker	depends on OF
218981b58f6SRich Felker	select IRQ_DOMAIN
219981b58f6SRich Felker	help
220981b58f6SRich Felker	  Support for the J-Core integrated AIC.
221981b58f6SRich Felker
222d852e62aSManivannan Sadhasivamconfig RDA_INTC
223d852e62aSManivannan Sadhasivam	bool
224d852e62aSManivannan Sadhasivam	select IRQ_DOMAIN
225d852e62aSManivannan Sadhasivam
22644358048SMagnus Dammconfig RENESAS_INTC_IRQPIN
22702d7e041SGeert Uytterhoeven	bool "Renesas INTC External IRQ Pin Support" if COMPILE_TEST
22844358048SMagnus Damm	select IRQ_DOMAIN
22902d7e041SGeert Uytterhoeven	help
23002d7e041SGeert Uytterhoeven	  Enable support for the Renesas Interrupt Controller for external
23102d7e041SGeert Uytterhoeven	  interrupt pins, as found on SH/R-Mobile and R-Car Gen1 SoCs.
23244358048SMagnus Damm
233fbc83b7fSMagnus Dammconfig RENESAS_IRQC
23472d44c0cSLad Prabhakar	bool "Renesas R-Mobile APE6, R-Car Gen{2,3} and RZ/G{1,2} IRQC support" if COMPILE_TEST
23599c221dfSMagnus Damm	select GENERIC_IRQ_CHIP
236fbc83b7fSMagnus Damm	select IRQ_DOMAIN
23702d7e041SGeert Uytterhoeven	help
23802d7e041SGeert Uytterhoeven	  Enable support for the Renesas Interrupt Controller for external
23972d44c0cSLad Prabhakar	  devices, as found on R-Mobile APE6, R-Car Gen{2,3} and RZ/G{1,2} SoCs.
240fbc83b7fSMagnus Damm
241a644ccb8SGeert Uytterhoevenconfig RENESAS_RZA1_IRQC
24202d7e041SGeert Uytterhoeven	bool "Renesas RZ/A1 IRQC support" if COMPILE_TEST
243a644ccb8SGeert Uytterhoeven	select IRQ_DOMAIN_HIERARCHY
24402d7e041SGeert Uytterhoeven	help
24502d7e041SGeert Uytterhoeven	  Enable support for the Renesas RZ/A1 Interrupt Controller, to use up
24602d7e041SGeert Uytterhoeven	  to 8 external interrupts with configurable sense select.
247a644ccb8SGeert Uytterhoeven
24803ac990eSMichael Walleconfig SL28CPLD_INTC
24903ac990eSMichael Walle	bool "Kontron sl28cpld IRQ controller"
25003ac990eSMichael Walle	depends on MFD_SL28CPLD=y || COMPILE_TEST
25103ac990eSMichael Walle	select REGMAP_IRQ
25203ac990eSMichael Walle	help
25303ac990eSMichael Walle	  Interrupt controller driver for the board management controller
25403ac990eSMichael Walle	  found on the Kontron sl28 CPLD.
25503ac990eSMichael Walle
25607088484SLee Jonesconfig ST_IRQCHIP
25707088484SLee Jones	bool
25807088484SLee Jones	select REGMAP
25907088484SLee Jones	select MFD_SYSCON
26007088484SLee Jones	help
26107088484SLee Jones	  Enables SysCfg Controlled IRQs on STi based platforms.
26207088484SLee Jones
263b06eb017SChristian Ruppertconfig TB10X_IRQC
264b06eb017SChristian Ruppert	bool
265b06eb017SChristian Ruppert	select IRQ_DOMAIN
266b06eb017SChristian Ruppert	select GENERIC_IRQ_CHIP
267b06eb017SChristian Ruppert
268d01f8633SDamien Riegelconfig TS4800_IRQ
269d01f8633SDamien Riegel	tristate "TS-4800 IRQ controller"
270d01f8633SDamien Riegel	select IRQ_DOMAIN
2710df337cfSRichard Weinberger	depends on HAS_IOMEM
272d2b383dcSJean Delvare	depends on SOC_IMX51 || COMPILE_TEST
273d01f8633SDamien Riegel	help
274d01f8633SDamien Riegel	  Support for the TS-4800 FPGA IRQ controller
275d01f8633SDamien Riegel
2762389d501SLinus Walleijconfig VERSATILE_FPGA_IRQ
2772389d501SLinus Walleij	bool
2782389d501SLinus Walleij	select IRQ_DOMAIN
2792389d501SLinus Walleij
2802389d501SLinus Walleijconfig VERSATILE_FPGA_IRQ_NR
2812389d501SLinus Walleij       int
2822389d501SLinus Walleij       default 4
2832389d501SLinus Walleij       depends on VERSATILE_FPGA_IRQ
28426a8e96aSMax Filippov
28526a8e96aSMax Filippovconfig XTENSA_MX
28626a8e96aSMax Filippov	bool
28726a8e96aSMax Filippov	select IRQ_DOMAIN
28850091212SMarc Zyngier	select GENERIC_IRQ_EFFECTIVE_AFF_MASK
28996ca848eSSricharan R
2900547dc78SZubair Lutfullah Kakakhelconfig XILINX_INTC
2910547dc78SZubair Lutfullah Kakakhel	bool
2920547dc78SZubair Lutfullah Kakakhel	select IRQ_DOMAIN
2930547dc78SZubair Lutfullah Kakakhel
29496ca848eSSricharan Rconfig IRQ_CROSSBAR
29596ca848eSSricharan R	bool
29696ca848eSSricharan R	help
297f54619f2SMasanari Iida	  Support for a CROSSBAR ip that precedes the main interrupt controller.
29896ca848eSSricharan R	  The primary irqchip invokes the crossbar's callback which inturn allocates
29996ca848eSSricharan R	  a free irq and configures the IP. Thus the peripheral interrupts are
30096ca848eSSricharan R	  routed to one of the free irqchip interrupt lines.
30189323f8cSGrygorii Strashko
30289323f8cSGrygorii Strashkoconfig KEYSTONE_IRQ
30389323f8cSGrygorii Strashko	tristate "Keystone 2 IRQ controller IP"
30489323f8cSGrygorii Strashko	depends on ARCH_KEYSTONE
30589323f8cSGrygorii Strashko	help
30689323f8cSGrygorii Strashko		Support for Texas Instruments Keystone 2 IRQ controller IP which
30789323f8cSGrygorii Strashko		is part of the Keystone 2 IPC mechanism
3088a19b8f1SAndrew Bresticker
3098a19b8f1SAndrew Brestickerconfig MIPS_GIC
3108a19b8f1SAndrew Bresticker	bool
311bb11cff3SQais Yousef	select GENERIC_IRQ_IPI
3128a19b8f1SAndrew Bresticker	select MIPS_CM
3138a764482SYoshinori Sato
31444e08e70SPaul Burtonconfig INGENIC_IRQ
31544e08e70SPaul Burton	bool
31644e08e70SPaul Burton	depends on MACH_INGENIC
31744e08e70SPaul Burton	default y
31878c10e55SLinus Torvalds
3199536eba0SPaul Cercueilconfig INGENIC_TCU_IRQ
3209536eba0SPaul Cercueil	bool "Ingenic JZ47xx TCU interrupt controller"
3219536eba0SPaul Cercueil	default MACH_INGENIC
3229536eba0SPaul Cercueil	depends on MIPS || COMPILE_TEST
3239536eba0SPaul Cercueil	select MFD_SYSCON
3248084499bSYueHaibing	select GENERIC_IRQ_CHIP
3259536eba0SPaul Cercueil	help
3269536eba0SPaul Cercueil	  Support for interrupts in the Timer/Counter Unit (TCU) of the Ingenic
3279536eba0SPaul Cercueil	  JZ47xx SoCs.
3289536eba0SPaul Cercueil
3299536eba0SPaul Cercueil	  If unsure, say N.
3309536eba0SPaul Cercueil
3318a764482SYoshinori Satoconfig RENESAS_H8300H_INTC
3328a764482SYoshinori Sato        bool
3338a764482SYoshinori Sato	select IRQ_DOMAIN
3348a764482SYoshinori Sato
3358a764482SYoshinori Satoconfig RENESAS_H8S_INTC
33602d7e041SGeert Uytterhoeven	bool "Renesas H8S Interrupt Controller Support" if COMPILE_TEST
3378a764482SYoshinori Sato	select IRQ_DOMAIN
33802d7e041SGeert Uytterhoeven	help
33902d7e041SGeert Uytterhoeven	  Enable support for the Renesas H8/300 Interrupt Controller, as found
34002d7e041SGeert Uytterhoeven	  on Renesas H8S SoCs.
341e324c4dcSShenwei Wang
342e324c4dcSShenwei Wangconfig IMX_GPCV2
343e324c4dcSShenwei Wang	bool
344e324c4dcSShenwei Wang	select IRQ_DOMAIN
345e324c4dcSShenwei Wang	help
346e324c4dcSShenwei Wang	  Enables the wakeup IRQs for IMX platforms with GPCv2 block
3477e4ac676SOleksij Rempel
3487e4ac676SOleksij Rempelconfig IRQ_MXS
3497e4ac676SOleksij Rempel	def_bool y if MACH_ASM9260 || ARCH_MXS
3507e4ac676SOleksij Rempel	select IRQ_DOMAIN
3517e4ac676SOleksij Rempel	select STMP_DEVICE
352c27f29bbSThomas Petazzoni
35319d99164SAlexandre Belloniconfig MSCC_OCELOT_IRQ
35419d99164SAlexandre Belloni	bool
35519d99164SAlexandre Belloni	select IRQ_DOMAIN
35619d99164SAlexandre Belloni	select GENERIC_IRQ_CHIP
35719d99164SAlexandre Belloni
358a68a63cbSThomas Petazzoniconfig MVEBU_GICP
359a68a63cbSThomas Petazzoni	bool
360a68a63cbSThomas Petazzoni
361e0de91a9SThomas Petazzoniconfig MVEBU_ICU
362e0de91a9SThomas Petazzoni	bool
363e0de91a9SThomas Petazzoni
364c27f29bbSThomas Petazzoniconfig MVEBU_ODMI
365c27f29bbSThomas Petazzoni	bool
366fa23b9d1SArnd Bergmann	select GENERIC_MSI_IRQ_DOMAIN
3679e2c986cSMarc Zyngier
368a109893bSThomas Petazzoniconfig MVEBU_PIC
369a109893bSThomas Petazzoni	bool
370a109893bSThomas Petazzoni
37161ce8d8dSMiquel Raynalconfig MVEBU_SEI
37261ce8d8dSMiquel Raynal        bool
37361ce8d8dSMiquel Raynal
3740dcd9f87SRasmus Villemoesconfig LS_EXTIRQ
3750dcd9f87SRasmus Villemoes	def_bool y if SOC_LS1021A || ARCH_LAYERSCAPE
3760dcd9f87SRasmus Villemoes	select MFD_SYSCON
3770dcd9f87SRasmus Villemoes
378b8f3ebe6SMinghuan Lianconfig LS_SCFG_MSI
379b8f3ebe6SMinghuan Lian	def_bool y if SOC_LS1021A || ARCH_LAYERSCAPE
380b8f3ebe6SMinghuan Lian	depends on PCI && PCI_MSI
381b8f3ebe6SMinghuan Lian
3829e2c986cSMarc Zyngierconfig PARTITION_PERCPU
3839e2c986cSMarc Zyngier	bool
3840efacbbaSLinus Torvalds
385e0720416SAlexandre TORGUEconfig STM32_EXTI
386e0720416SAlexandre TORGUE	bool
387e0720416SAlexandre TORGUE	select IRQ_DOMAIN
3880e7d7807SLudovic Barre	select GENERIC_IRQ_CHIP
389f20cc9b0SAgustin Vega-Frias
390f20cc9b0SAgustin Vega-Friasconfig QCOM_IRQ_COMBINER
391f20cc9b0SAgustin Vega-Frias	bool "QCOM IRQ combiner support"
392f20cc9b0SAgustin Vega-Frias	depends on ARCH_QCOM && ACPI
393f20cc9b0SAgustin Vega-Frias	select IRQ_DOMAIN_HIERARCHY
394f20cc9b0SAgustin Vega-Frias	help
395f20cc9b0SAgustin Vega-Frias	  Say yes here to add support for the IRQ combiner devices embedded
396f20cc9b0SAgustin Vega-Frias	  in Qualcomm Technologies chips.
3975ed34d3aSMasahiro Yamada
3985ed34d3aSMasahiro Yamadaconfig IRQ_UNIPHIER_AIDET
3995ed34d3aSMasahiro Yamada	bool "UniPhier AIDET support" if COMPILE_TEST
4005ed34d3aSMasahiro Yamada	depends on ARCH_UNIPHIER || COMPILE_TEST
4015ed34d3aSMasahiro Yamada	default ARCH_UNIPHIER
4025ed34d3aSMasahiro Yamada	select IRQ_DOMAIN_HIERARCHY
4035ed34d3aSMasahiro Yamada	help
4045ed34d3aSMasahiro Yamada	  Support for the UniPhier AIDET (ARM Interrupt Detector).
405c94fb639SRandy Dunlap
406215f4cc0SJerome Brunetconfig MESON_IRQ_GPIO
407215f4cc0SJerome Brunet       bool "Meson GPIO Interrupt Multiplexer"
408d9ee91c1SThomas Gleixner       depends on ARCH_MESON
409215f4cc0SJerome Brunet       select IRQ_DOMAIN_HIERARCHY
410215f4cc0SJerome Brunet       help
411215f4cc0SJerome Brunet         Support Meson SoC Family GPIO Interrupt Multiplexer
412215f4cc0SJerome Brunet
4134235ff50SMiodrag Dinicconfig GOLDFISH_PIC
4144235ff50SMiodrag Dinic       bool "Goldfish programmable interrupt controller"
4154235ff50SMiodrag Dinic       depends on MIPS && (GOLDFISH || COMPILE_TEST)
4164235ff50SMiodrag Dinic       select IRQ_DOMAIN
4174235ff50SMiodrag Dinic       help
4184235ff50SMiodrag Dinic         Say yes here to enable Goldfish interrupt controller driver used
4194235ff50SMiodrag Dinic         for Goldfish based virtual platforms.
4204235ff50SMiodrag Dinic
421f55c73aeSArchana Sathyakumarconfig QCOM_PDC
422a150dac5SMarc Zyngier	bool "QCOM PDC"
423f55c73aeSArchana Sathyakumar	depends on ARCH_QCOM
424f55c73aeSArchana Sathyakumar	select IRQ_DOMAIN_HIERARCHY
425f55c73aeSArchana Sathyakumar	help
426f55c73aeSArchana Sathyakumar	  Power Domain Controller driver to manage and configure wakeup
427f55c73aeSArchana Sathyakumar	  IRQs for Qualcomm Technologies Inc (QTI) mobile chips.
428f55c73aeSArchana Sathyakumar
429d8a5f5f7SGuo Renconfig CSKY_MPINTC
430be1abc5bSGuo Ren	bool
431d8a5f5f7SGuo Ren	depends on CSKY
432d8a5f5f7SGuo Ren	help
433d8a5f5f7SGuo Ren	  Say yes here to enable C-SKY SMP interrupt controller driver used
434d8a5f5f7SGuo Ren	  for C-SKY SMP system.
435656b42deSRandy Dunlap	  In fact it's not mmio map in hardware and it uses ld/st to visit the
436d8a5f5f7SGuo Ren	  controller's register inside CPU.
437d8a5f5f7SGuo Ren
438edff1b48SGuo Renconfig CSKY_APB_INTC
439edff1b48SGuo Ren	bool "C-SKY APB Interrupt Controller"
440edff1b48SGuo Ren	depends on CSKY
441edff1b48SGuo Ren	help
442edff1b48SGuo Ren	  Say yes here to enable C-SKY APB interrupt controller driver used
443656b42deSRandy Dunlap	  by C-SKY single core SOC system. It uses mmio map apb-bus to visit
444edff1b48SGuo Ren	  the controller's register.
445edff1b48SGuo Ren
4460136afa0SLucas Stachconfig IMX_IRQSTEER
4470136afa0SLucas Stach	bool "i.MX IRQSTEER support"
4480136afa0SLucas Stach	depends on ARCH_MXC || COMPILE_TEST
4490136afa0SLucas Stach	default ARCH_MXC
4500136afa0SLucas Stach	select IRQ_DOMAIN
4510136afa0SLucas Stach	help
4520136afa0SLucas Stach	  Support for the i.MX IRQSTEER interrupt multiplexer/remapper.
4530136afa0SLucas Stach
4542fbb1396SJoakim Zhangconfig IMX_INTMUX
455*a890caebSGeert Uytterhoeven	bool "i.MX INTMUX support" if COMPILE_TEST
456*a890caebSGeert Uytterhoeven	default y if ARCH_MXC
4572fbb1396SJoakim Zhang	select IRQ_DOMAIN
4582fbb1396SJoakim Zhang	help
4592fbb1396SJoakim Zhang	  Support for the i.MX INTMUX interrupt multiplexer.
4602fbb1396SJoakim Zhang
4619e543e22SJiaxun Yangconfig LS1X_IRQ
4629e543e22SJiaxun Yang	bool "Loongson-1 Interrupt Controller"
4639e543e22SJiaxun Yang	depends on MACH_LOONGSON32
4649e543e22SJiaxun Yang	default y
4659e543e22SJiaxun Yang	select IRQ_DOMAIN
4669e543e22SJiaxun Yang	select GENERIC_IRQ_CHIP
4679e543e22SJiaxun Yang	help
4689e543e22SJiaxun Yang	  Support for the Loongson-1 platform Interrupt Controller.
4699e543e22SJiaxun Yang
470cd844b07SLokesh Vutlaconfig TI_SCI_INTR_IRQCHIP
471cd844b07SLokesh Vutla	bool
472cd844b07SLokesh Vutla	depends on TI_SCI_PROTOCOL
473cd844b07SLokesh Vutla	select IRQ_DOMAIN_HIERARCHY
474cd844b07SLokesh Vutla	help
475cd844b07SLokesh Vutla	  This enables the irqchip driver support for K3 Interrupt router
476cd844b07SLokesh Vutla	  over TI System Control Interface available on some new TI's SoCs.
477cd844b07SLokesh Vutla	  If you wish to use interrupt router irq resources managed by the
478cd844b07SLokesh Vutla	  TI System Controller, say Y here. Otherwise, say N.
479cd844b07SLokesh Vutla
4809f1463b8SLokesh Vutlaconfig TI_SCI_INTA_IRQCHIP
4819f1463b8SLokesh Vutla	bool
4829f1463b8SLokesh Vutla	depends on TI_SCI_PROTOCOL
4839f1463b8SLokesh Vutla	select IRQ_DOMAIN_HIERARCHY
484f011df61SLokesh Vutla	select TI_SCI_INTA_MSI_DOMAIN
4859f1463b8SLokesh Vutla	help
4869f1463b8SLokesh Vutla	  This enables the irqchip driver support for K3 Interrupt aggregator
4879f1463b8SLokesh Vutla	  over TI System Control Interface available on some new TI's SoCs.
4889f1463b8SLokesh Vutla	  If you wish to use interrupt aggregator irq resources managed by the
4899f1463b8SLokesh Vutla	  TI System Controller, say Y here. Otherwise, say N.
4909f1463b8SLokesh Vutla
49104e2d1e0SGrzegorz Jaszczykconfig TI_PRUSS_INTC
49204e2d1e0SGrzegorz Jaszczyk	tristate "TI PRU-ICSS Interrupt Controller"
4937e92dee6SSuman Anna	depends on ARCH_DAVINCI || SOC_AM33XX || SOC_AM43XX || SOC_DRA7XX || ARCH_KEYSTONE || ARCH_K3
49404e2d1e0SGrzegorz Jaszczyk	select IRQ_DOMAIN
49504e2d1e0SGrzegorz Jaszczyk	help
49604e2d1e0SGrzegorz Jaszczyk	  This enables support for the PRU-ICSS Local Interrupt Controller
49704e2d1e0SGrzegorz Jaszczyk	  present within a PRU-ICSS subsystem present on various TI SoCs.
49804e2d1e0SGrzegorz Jaszczyk	  The PRUSS INTC enables various interrupts to be routed to multiple
49904e2d1e0SGrzegorz Jaszczyk	  different processors within the SoC.
50004e2d1e0SGrzegorz Jaszczyk
5016b7ce892SAnup Patelconfig RISCV_INTC
5026b7ce892SAnup Patel	bool "RISC-V Local Interrupt Controller"
5036b7ce892SAnup Patel	depends on RISCV
5046b7ce892SAnup Patel	default y
5056b7ce892SAnup Patel	help
5066b7ce892SAnup Patel	   This enables support for the per-HART local interrupt controller
5076b7ce892SAnup Patel	   found in standard RISC-V systems.  The per-HART local interrupt
5086b7ce892SAnup Patel	   controller handles timer interrupts, software interrupts, and
5096b7ce892SAnup Patel	   hardware interrupts. Without a per-HART local interrupt controller,
5106b7ce892SAnup Patel	   a RISC-V system will be unable to handle any interrupts.
5116b7ce892SAnup Patel
5126b7ce892SAnup Patel	   If you don't know what to do here, say Y.
5136b7ce892SAnup Patel
5148237f8bcSChristoph Hellwigconfig SIFIVE_PLIC
5158237f8bcSChristoph Hellwig	bool "SiFive Platform-Level Interrupt Controller"
5168237f8bcSChristoph Hellwig	depends on RISCV
517466008f9SYash Shah	select IRQ_DOMAIN_HIERARCHY
5188237f8bcSChristoph Hellwig	help
5198237f8bcSChristoph Hellwig	   This enables support for the PLIC chip found in SiFive (and
5208237f8bcSChristoph Hellwig	   potentially other) RISC-V systems.  The PLIC controls devices
5218237f8bcSChristoph Hellwig	   interrupts and connects them to each core's local interrupt
5228237f8bcSChristoph Hellwig	   controller.  Aside from timer and software interrupts, all other
5238237f8bcSChristoph Hellwig	   interrupt sources are subordinate to the PLIC.
5248237f8bcSChristoph Hellwig
5258237f8bcSChristoph Hellwig	   If you don't know what to do here, say Y.
52601493855SJonathan Neuschäfer
527b74416dbSHyunki Kooconfig EXYNOS_IRQ_COMBINER
528b74416dbSHyunki Koo	bool "Samsung Exynos IRQ combiner support" if COMPILE_TEST
529b74416dbSHyunki Koo	depends on (ARCH_EXYNOS && ARM) || COMPILE_TEST
530b74416dbSHyunki Koo	help
531b74416dbSHyunki Koo	  Say yes here to add support for the IRQ combiner devices embedded
532b74416dbSHyunki Koo	  in Samsung Exynos chips.
533b74416dbSHyunki Koo
534dbb15226SJiaxun Yangconfig LOONGSON_LIOINTC
535dbb15226SJiaxun Yang	bool "Loongson Local I/O Interrupt Controller"
536dbb15226SJiaxun Yang	depends on MACH_LOONGSON64
537dbb15226SJiaxun Yang	default y
538dbb15226SJiaxun Yang	select IRQ_DOMAIN
539dbb15226SJiaxun Yang	select GENERIC_IRQ_CHIP
540dbb15226SJiaxun Yang	help
541dbb15226SJiaxun Yang	  Support for the Loongson Local I/O Interrupt Controller.
542dbb15226SJiaxun Yang
543a93f1d90SJiaxun Yangconfig LOONGSON_HTPIC
544a93f1d90SJiaxun Yang	bool "Loongson3 HyperTransport PIC Controller"
545a93f1d90SJiaxun Yang	depends on MACH_LOONGSON64
546a93f1d90SJiaxun Yang	default y
547a93f1d90SJiaxun Yang	select IRQ_DOMAIN
548a93f1d90SJiaxun Yang	select GENERIC_IRQ_CHIP
549a93f1d90SJiaxun Yang	help
550a93f1d90SJiaxun Yang	  Support for the Loongson-3 HyperTransport PIC Controller.
551a93f1d90SJiaxun Yang
552818e915fSJiaxun Yangconfig LOONGSON_HTVEC
553818e915fSJiaxun Yang	bool "Loongson3 HyperTransport Interrupt Vector Controller"
554d77aeb5dSIngo Molnar	depends on MACH_LOONGSON64
555818e915fSJiaxun Yang	default MACH_LOONGSON64
556818e915fSJiaxun Yang	select IRQ_DOMAIN_HIERARCHY
557818e915fSJiaxun Yang	help
558818e915fSJiaxun Yang	  Support for the Loongson3 HyperTransport Interrupt Vector Controller.
559818e915fSJiaxun Yang
560ef8c01ebSJiaxun Yangconfig LOONGSON_PCH_PIC
561ef8c01ebSJiaxun Yang	bool "Loongson PCH PIC Controller"
562ef8c01ebSJiaxun Yang	depends on MACH_LOONGSON64 || COMPILE_TEST
563ef8c01ebSJiaxun Yang	default MACH_LOONGSON64
564ef8c01ebSJiaxun Yang	select IRQ_DOMAIN_HIERARCHY
565ef8c01ebSJiaxun Yang	select IRQ_FASTEOI_HIERARCHY_HANDLERS
566ef8c01ebSJiaxun Yang	help
567ef8c01ebSJiaxun Yang	  Support for the Loongson PCH PIC Controller.
568ef8c01ebSJiaxun Yang
569632dcc2cSJiaxun Yangconfig LOONGSON_PCH_MSI
570a23df9a4SJiaxun Yang	bool "Loongson PCH MSI Controller"
571632dcc2cSJiaxun Yang	depends on MACH_LOONGSON64 || COMPILE_TEST
572632dcc2cSJiaxun Yang	depends on PCI
573632dcc2cSJiaxun Yang	default MACH_LOONGSON64
574632dcc2cSJiaxun Yang	select IRQ_DOMAIN_HIERARCHY
575632dcc2cSJiaxun Yang	select PCI_MSI
576632dcc2cSJiaxun Yang	help
577632dcc2cSJiaxun Yang	  Support for the Loongson PCH MSI Controller.
578632dcc2cSJiaxun Yang
579ad4c938cSMark-PK Tsaiconfig MST_IRQ
580ad4c938cSMark-PK Tsai	bool "MStar Interrupt Controller"
58161b0648dSGeert Uytterhoeven	depends on ARCH_MEDIATEK || ARCH_MSTARV7 || COMPILE_TEST
582ad4c938cSMark-PK Tsai	default ARCH_MEDIATEK
583ad4c938cSMark-PK Tsai	select IRQ_DOMAIN
584ad4c938cSMark-PK Tsai	select IRQ_DOMAIN_HIERARCHY
585ad4c938cSMark-PK Tsai	help
586ad4c938cSMark-PK Tsai	  Support MStar Interrupt Controller.
587ad4c938cSMark-PK Tsai
58801493855SJonathan Neuschäferendmenu
589