irqchip: add basic infrastructure
With the recent creation of the drivers/irqchip/ directory, it is
desirable to move irq controller drivers here. At the moment, the only
driver here is irq-bcm2835, the driver for the irq controller found in
the ARM BCM2835 SoC, present in Rasberry Pi systems. This irq
controller driver was exporting its initialization function and its
irq handling function through a header file in
<linux/irqchip/bcm2835.h>.
When proposing to also move another irq controller driver in
drivers/irqchip, Rob Herring raised the very valid point that moving
things to drivers/irqchip was good in order to remove more stuff from
arch/arm, but if it means adding gazillions of headers files in
include/linux/irqchip/, it would not be very nice.
So, upon the suggestion of Rob Herring and Arnd Bergmann, this commit
introduces a small infrastructure that defines a central
irqchip_init() function in drivers/irqchip/irqchip.c, which is meant
to be called as the ->init_irq() callback of ARM platforms. This
function calls of_irq_init() with an array of match strings and init
functions generated from a special linker section.
Note that the irq controller driver initialization function is
responsible for setting the global handle_arch_irq() variable, so that
ARM platforms no longer have to define the ->handle_irq field in their
DT_MACHINE structure.
A global header, <linux/irqchip.h> is also added to expose the single
irqchip_init() function to the reset of the kernel.
A further commit moves the BCM2835 irq controller driver to this new
small infrastructure, therefore removing the include/linux/irqchip/
directory.
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Reviewed-by: Stephen Warren <swarren@wwwdotorg.org>
Reviewed-by: Rob Herring <rob.herring@calxeda.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
[rob.herring: reword commit message to reflect use of linker sections.]
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
2012-11-20 23:00:52 +01:00
config IRQCHIP
def_bool y
depends on OF_IRQ
2012-11-20 21:21:40 -06:00
config ARM_GIC
bool
select IRQ_DOMAIN
2014-11-25 16:04:19 +08:00
select IRQ_DOMAIN_HIERARCHY
2012-11-20 21:21:40 -06:00
select MULTI_IRQ_HANDLER
2014-11-25 18:47:22 +00:00
config ARM_GIC_V2M
bool
depends on ARM_GIC
depends on PCI && PCI_MSI
select PCI_MSI_IRQ_DOMAIN
2012-11-20 21:21:40 -06:00
config GIC_NON_BANKED
bool
2014-06-30 16:01:31 +01:00
config ARM_GIC_V3
bool
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
2014-11-24 14:35:09 +00:00
select IRQ_DOMAIN_HIERARCHY
2014-06-30 16:01:31 +01:00
2014-11-24 14:35:19 +00:00
config ARM_GIC_V3_ITS
bool
select PCI_MSI_IRQ_DOMAIN
2014-06-30 16:01:31 +01:00
2013-06-26 09:18:48 +02:00
config ARM_NVIC
bool
select IRQ_DOMAIN
select GENERIC_IRQ_CHIP
2012-10-27 17:25:26 -05:00
config ARM_VIC
bool
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
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.
2014-07-10 19:14:18 +02:00
config ATMEL_AIC_IRQ
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
select SPARSE_IRQ
config ATMEL_AIC5_IRQ
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
select SPARSE_IRQ
2014-11-06 22:44:27 -08:00
config BCM7120_L2_IRQ
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
2014-05-23 17:40:53 -07:00
config BRCMSTB_L2_IRQ
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
2013-09-09 14:01:20 +02:00
config DW_APB_ICTL
bool
2014-10-22 20:59:10 +08:00
select GENERIC_IRQ_CHIP
2013-09-09 14:01:20 +02:00
select IRQ_DOMAIN
2013-04-22 15:43:50 +01:00
config IMGPDC_IRQ
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
2014-02-02 12:07:46 +04:00
config CLPS711X_IRQCHIP
bool
depends on ARCH_CLPS711X
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
select SPARSE_IRQ
default y
2014-05-26 23:31:42 +03:00
config OR1K_PIC
bool
select IRQ_DOMAIN
2014-09-15 16:15:02 -05:00
config OMAP_IRQCHIP
bool
select GENERIC_IRQ_CHIP
select IRQ_DOMAIN
2013-06-06 18:27:09 +02:00
config ORION_IRQCHIP
bool
select IRQ_DOMAIN
select MULTI_IRQ_HANDLER
2013-02-18 23:28:34 +09:00
config RENESAS_INTC_IRQPIN
bool
select IRQ_DOMAIN
2013-02-27 17:15:01 +09:00
config RENESAS_IRQC
bool
select IRQ_DOMAIN
2013-06-25 18:29:57 +02:00
config TB10X_IRQC
bool
select IRQ_DOMAIN
select GENERIC_IRQ_CHIP
2012-10-31 22:04:31 +01:00
config VERSATILE_FPGA_IRQ
bool
select IRQ_DOMAIN
config VERSATILE_FPGA_IRQ_NR
int
default 4
depends on VERSATILE_FPGA_IRQ
2013-12-01 12:04:57 +04:00
config XTENSA_MX
bool
select IRQ_DOMAIN
2013-12-03 15:57:23 +05:30
config IRQ_CROSSBAR
bool
help
2014-09-18 12:09:42 +09:00
Support for a CROSSBAR ip that precedes the main interrupt controller.
2013-12-03 15:57:23 +05:30
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.
2014-07-23 17:40:30 +03:00
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
2014-09-18 14:47:19 -07:00
config MIPS_GIC
bool
select MIPS_CM