aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMagnus Damm <damm@opensource.se>2013-03-27 11:49:54 -0400
committerSimon Horman <horms+renesas@verge.net.au>2013-04-01 22:02:20 -0400
commit8f5ec0a57ef503e7609d763cadba55f12b9486ce (patch)
treefe8e6d892d7104b7788d01706ec7940d2cf5e3e8
parent55d9fab280e6e587d634d2ec2effe94eabe90e9c (diff)
ARM: shmobile: r8a7790 IRQC support
Add IRQC interrupt controller support to r8a7790 by hooking up a single IRQC instances to handle 4 external IRQ signals. The IRQC controller is tied to SPIs of the GIC. On r8a7790 the external IRQ pins routing is handled by the PFC which is excluded from this patch. Both platform devices and DT devices are added in this patch. The platform device versions are used to provide a static interrupt map configuration for board code written in C. Signed-off-by: Magnus Damm <damm@opensource.se> Signed-off-by: Simon Horman <horms+renesas@verge.net.au>
-rw-r--r--arch/arm/boot/dts/r8a7790.dtsi9
-rw-r--r--arch/arm/mach-shmobile/Kconfig1
-rw-r--r--arch/arm/mach-shmobile/setup-r8a7790.c21
3 files changed, 31 insertions, 0 deletions
diff --git a/arch/arm/boot/dts/r8a7790.dtsi b/arch/arm/boot/dts/r8a7790.dtsi
index 1c58ffb6cccf..a1e0e0c64c3c 100644
--- a/arch/arm/boot/dts/r8a7790.dtsi
+++ b/arch/arm/boot/dts/r8a7790.dtsi
@@ -51,4 +51,13 @@
51 <1 11 0xf08>, 51 <1 11 0xf08>,
52 <1 10 0xf08>; 52 <1 10 0xf08>;
53 }; 53 };
54
55 irqc0: interrupt-controller@e61c0000 {
56 compatible = "renesas,irqc";
57 #interrupt-cells = <2>;
58 interrupt-controller;
59 reg = <0xe61c0000 0x200>;
60 interrupt-parent = <&gic>;
61 interrupts = <0 0 4>, <0 1 4>, <0 2 4>, <0 3 4>;
62 };
54}; 63};
diff --git a/arch/arm/mach-shmobile/Kconfig b/arch/arm/mach-shmobile/Kconfig
index 749dfb4c63c0..ccaea6aecea0 100644
--- a/arch/arm/mach-shmobile/Kconfig
+++ b/arch/arm/mach-shmobile/Kconfig
@@ -57,6 +57,7 @@ config ARCH_R8A7790
57 select CPU_V7 57 select CPU_V7
58 select ARM_ARCH_TIMER 58 select ARM_ARCH_TIMER
59 select SH_CLK_CPG 59 select SH_CLK_CPG
60 select RENESAS_IRQC
60 61
61config ARCH_EMEV2 62config ARCH_EMEV2
62 bool "Emma Mobile EV2" 63 bool "Emma Mobile EV2"
diff --git a/arch/arm/mach-shmobile/setup-r8a7790.c b/arch/arm/mach-shmobile/setup-r8a7790.c
index 3bb5bf16000c..9b4ccd7b5031 100644
--- a/arch/arm/mach-shmobile/setup-r8a7790.c
+++ b/arch/arm/mach-shmobile/setup-r8a7790.c
@@ -23,6 +23,7 @@
23#include <linux/kernel.h> 23#include <linux/kernel.h>
24#include <linux/of_platform.h> 24#include <linux/of_platform.h>
25#include <linux/serial_sci.h> 25#include <linux/serial_sci.h>
26#include <linux/platform_data/irq-renesas-irqc.h>
26#include <mach/common.h> 27#include <mach/common.h>
27#include <mach/irqs.h> 28#include <mach/irqs.h>
28#include <mach/r8a7790.h> 29#include <mach/r8a7790.h>
@@ -74,6 +75,25 @@ static inline void r8a7790_register_scif(int idx)
74 sizeof(struct plat_sci_port)); 75 sizeof(struct plat_sci_port));
75} 76}
76 77
78static struct renesas_irqc_config irqc0_data = {
79 .irq_base = irq_pin(0), /* IRQ0 -> IRQ3 */
80};
81
82static struct resource irqc0_resources[] = {
83 DEFINE_RES_MEM(0xe61c0000, 0x200), /* IRQC Event Detector Block_0 */
84 DEFINE_RES_IRQ(gic_spi(0)), /* IRQ0 */
85 DEFINE_RES_IRQ(gic_spi(1)), /* IRQ1 */
86 DEFINE_RES_IRQ(gic_spi(2)), /* IRQ2 */
87 DEFINE_RES_IRQ(gic_spi(3)), /* IRQ3 */
88};
89
90#define r8a7790_register_irqc(idx) \
91 platform_device_register_resndata(&platform_bus, "renesas_irqc", \
92 idx, irqc##idx##_resources, \
93 ARRAY_SIZE(irqc##idx##_resources), \
94 &irqc##idx##_data, \
95 sizeof(struct renesas_irqc_config))
96
77void __init r8a7790_add_standard_devices(void) 97void __init r8a7790_add_standard_devices(void)
78{ 98{
79 r8a7790_register_scif(SCIFA0); 99 r8a7790_register_scif(SCIFA0);
@@ -84,6 +104,7 @@ void __init r8a7790_add_standard_devices(void)
84 r8a7790_register_scif(SCIFA2); 104 r8a7790_register_scif(SCIFA2);
85 r8a7790_register_scif(SCIF0); 105 r8a7790_register_scif(SCIF0);
86 r8a7790_register_scif(SCIF1); 106 r8a7790_register_scif(SCIF1);
107 r8a7790_register_irqc(0);
87} 108}
88 109
89#ifdef CONFIG_USE_OF 110#ifdef CONFIG_USE_OF