diff options
author | Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> | 2011-11-10 21:46:35 -0500 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2011-11-11 02:55:37 -0500 |
commit | 215d6cc9230c2a42a643c4cd296680040eeb1f49 (patch) | |
tree | 16ff1a3f9e975048c5aa30c146bfc5cbc4f04d0c /arch/arm/mach-shmobile/setup-r8a7740.c | |
parent | 6831f3a9184a1c5400e4fa2f2d3172b6dfb2c805 (diff) |
ARM: mach-shmobile: r8a7740: add INTC support
R8A7740 GIC can not get external IRQx interrupt directly
without GIC - INTC demux support.
Current AG5 is using GIC - INTCS demux with
special irq relocation. but GIC - INTCA demux
is still not supported and it needs irq number re-mapping.
OTOH, normal INTC support as before is very enough for R8A7740,
because it is not SMP CPU.
This patch adds INTCA/INTCS support instead of GIC.
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/arm/mach-shmobile/setup-r8a7740.c')
-rw-r--r-- | arch/arm/mach-shmobile/setup-r8a7740.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/arch/arm/mach-shmobile/setup-r8a7740.c b/arch/arm/mach-shmobile/setup-r8a7740.c index e16860f04934..986dca6b3fad 100644 --- a/arch/arm/mach-shmobile/setup-r8a7740.c +++ b/arch/arm/mach-shmobile/setup-r8a7740.c | |||
@@ -35,7 +35,7 @@ static struct plat_sci_port scif0_platform_data = { | |||
35 | .scscr = SCSCR_RE | SCSCR_TE, | 35 | .scscr = SCSCR_RE | SCSCR_TE, |
36 | .scbrr_algo_id = SCBRR_ALGO_4, | 36 | .scbrr_algo_id = SCBRR_ALGO_4, |
37 | .type = PORT_SCIFA, | 37 | .type = PORT_SCIFA, |
38 | .irqs = SCIx_IRQ_MUXED(gic_spi(100)), | 38 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0c00)), |
39 | }; | 39 | }; |
40 | 40 | ||
41 | static struct platform_device scif0_device = { | 41 | static struct platform_device scif0_device = { |
@@ -53,7 +53,7 @@ static struct plat_sci_port scif1_platform_data = { | |||
53 | .scscr = SCSCR_RE | SCSCR_TE, | 53 | .scscr = SCSCR_RE | SCSCR_TE, |
54 | .scbrr_algo_id = SCBRR_ALGO_4, | 54 | .scbrr_algo_id = SCBRR_ALGO_4, |
55 | .type = PORT_SCIFA, | 55 | .type = PORT_SCIFA, |
56 | .irqs = SCIx_IRQ_MUXED(gic_spi(101)), | 56 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0c20)), |
57 | }; | 57 | }; |
58 | 58 | ||
59 | static struct platform_device scif1_device = { | 59 | static struct platform_device scif1_device = { |
@@ -71,7 +71,7 @@ static struct plat_sci_port scif2_platform_data = { | |||
71 | .scscr = SCSCR_RE | SCSCR_TE, | 71 | .scscr = SCSCR_RE | SCSCR_TE, |
72 | .scbrr_algo_id = SCBRR_ALGO_4, | 72 | .scbrr_algo_id = SCBRR_ALGO_4, |
73 | .type = PORT_SCIFA, | 73 | .type = PORT_SCIFA, |
74 | .irqs = SCIx_IRQ_MUXED(gic_spi(102)), | 74 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0c40)), |
75 | }; | 75 | }; |
76 | 76 | ||
77 | static struct platform_device scif2_device = { | 77 | static struct platform_device scif2_device = { |
@@ -89,7 +89,7 @@ static struct plat_sci_port scif3_platform_data = { | |||
89 | .scscr = SCSCR_RE | SCSCR_TE, | 89 | .scscr = SCSCR_RE | SCSCR_TE, |
90 | .scbrr_algo_id = SCBRR_ALGO_4, | 90 | .scbrr_algo_id = SCBRR_ALGO_4, |
91 | .type = PORT_SCIFA, | 91 | .type = PORT_SCIFA, |
92 | .irqs = SCIx_IRQ_MUXED(gic_spi(103)), | 92 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0c60)), |
93 | }; | 93 | }; |
94 | 94 | ||
95 | static struct platform_device scif3_device = { | 95 | static struct platform_device scif3_device = { |
@@ -107,7 +107,7 @@ static struct plat_sci_port scif4_platform_data = { | |||
107 | .scscr = SCSCR_RE | SCSCR_TE, | 107 | .scscr = SCSCR_RE | SCSCR_TE, |
108 | .scbrr_algo_id = SCBRR_ALGO_4, | 108 | .scbrr_algo_id = SCBRR_ALGO_4, |
109 | .type = PORT_SCIFA, | 109 | .type = PORT_SCIFA, |
110 | .irqs = SCIx_IRQ_MUXED(gic_spi(104)), | 110 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0d20)), |
111 | }; | 111 | }; |
112 | 112 | ||
113 | static struct platform_device scif4_device = { | 113 | static struct platform_device scif4_device = { |
@@ -125,7 +125,7 @@ static struct plat_sci_port scif5_platform_data = { | |||
125 | .scscr = SCSCR_RE | SCSCR_TE, | 125 | .scscr = SCSCR_RE | SCSCR_TE, |
126 | .scbrr_algo_id = SCBRR_ALGO_4, | 126 | .scbrr_algo_id = SCBRR_ALGO_4, |
127 | .type = PORT_SCIFA, | 127 | .type = PORT_SCIFA, |
128 | .irqs = SCIx_IRQ_MUXED(gic_spi(105)), | 128 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0d40)), |
129 | }; | 129 | }; |
130 | 130 | ||
131 | static struct platform_device scif5_device = { | 131 | static struct platform_device scif5_device = { |
@@ -143,7 +143,7 @@ static struct plat_sci_port scif6_platform_data = { | |||
143 | .scscr = SCSCR_RE | SCSCR_TE, | 143 | .scscr = SCSCR_RE | SCSCR_TE, |
144 | .scbrr_algo_id = SCBRR_ALGO_4, | 144 | .scbrr_algo_id = SCBRR_ALGO_4, |
145 | .type = PORT_SCIFA, | 145 | .type = PORT_SCIFA, |
146 | .irqs = SCIx_IRQ_MUXED(gic_spi(106)), | 146 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x04c0)), |
147 | }; | 147 | }; |
148 | 148 | ||
149 | static struct platform_device scif6_device = { | 149 | static struct platform_device scif6_device = { |
@@ -161,7 +161,7 @@ static struct plat_sci_port scif7_platform_data = { | |||
161 | .scscr = SCSCR_RE | SCSCR_TE, | 161 | .scscr = SCSCR_RE | SCSCR_TE, |
162 | .scbrr_algo_id = SCBRR_ALGO_4, | 162 | .scbrr_algo_id = SCBRR_ALGO_4, |
163 | .type = PORT_SCIFA, | 163 | .type = PORT_SCIFA, |
164 | .irqs = SCIx_IRQ_MUXED(gic_spi(107)), | 164 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x04e0)), |
165 | }; | 165 | }; |
166 | 166 | ||
167 | static struct platform_device scif7_device = { | 167 | static struct platform_device scif7_device = { |
@@ -179,7 +179,7 @@ static struct plat_sci_port scifb_platform_data = { | |||
179 | .scscr = SCSCR_RE | SCSCR_TE, | 179 | .scscr = SCSCR_RE | SCSCR_TE, |
180 | .scbrr_algo_id = SCBRR_ALGO_4, | 180 | .scbrr_algo_id = SCBRR_ALGO_4, |
181 | .type = PORT_SCIFB, | 181 | .type = PORT_SCIFB, |
182 | .irqs = SCIx_IRQ_MUXED(gic_spi(108)), | 182 | .irqs = SCIx_IRQ_MUXED(evt2irq(0x0d60)), |
183 | }; | 183 | }; |
184 | 184 | ||
185 | static struct platform_device scifb_device = { | 185 | static struct platform_device scifb_device = { |
@@ -207,7 +207,7 @@ static struct resource cmt10_resources[] = { | |||
207 | .flags = IORESOURCE_MEM, | 207 | .flags = IORESOURCE_MEM, |
208 | }, | 208 | }, |
209 | [1] = { | 209 | [1] = { |
210 | .start = gic_spi(58), | 210 | .start = evt2irq(0x0b00), |
211 | .flags = IORESOURCE_IRQ, | 211 | .flags = IORESOURCE_IRQ, |
212 | }, | 212 | }, |
213 | }; | 213 | }; |
@@ -244,8 +244,8 @@ static struct resource i2c0_resources[] = { | |||
244 | .flags = IORESOURCE_MEM, | 244 | .flags = IORESOURCE_MEM, |
245 | }, | 245 | }, |
246 | [1] = { | 246 | [1] = { |
247 | .start = gic_spi(201), | 247 | .start = intcs_evt2irq(0xe00), |
248 | .end = gic_spi(204), | 248 | .end = intcs_evt2irq(0xe60), |
249 | .flags = IORESOURCE_IRQ, | 249 | .flags = IORESOURCE_IRQ, |
250 | }, | 250 | }, |
251 | }; | 251 | }; |
@@ -258,8 +258,8 @@ static struct resource i2c1_resources[] = { | |||
258 | .flags = IORESOURCE_MEM, | 258 | .flags = IORESOURCE_MEM, |
259 | }, | 259 | }, |
260 | [1] = { | 260 | [1] = { |
261 | .start = gic_spi(70), | 261 | .start = evt2irq(0x780), /* IIC1_ALI1 */ |
262 | .end = gic_spi(73), | 262 | .end = evt2irq(0x7e0), /* IIC1_DTEI1 */ |
263 | .flags = IORESOURCE_IRQ, | 263 | .flags = IORESOURCE_IRQ, |
264 | }, | 264 | }, |
265 | }; | 265 | }; |