2 * Renesas MX-G (R8A03022BG) Setup
4 * Copyright (C) 2008 Paul Mundt
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
10 #include <linux/platform_device.h>
11 #include <linux/init.h>
12 #include <linux/serial.h>
13 #include <linux/serial_sci.h>
18 /* interrupt sources */
19 IRQ0
, IRQ1
, IRQ2
, IRQ3
, IRQ4
, IRQ5
, IRQ6
, IRQ7
,
20 IRQ8
, IRQ9
, IRQ10
, IRQ11
, IRQ12
, IRQ13
, IRQ14
, IRQ15
,
22 PINT0
, PINT1
, PINT2
, PINT3
, PINT4
, PINT5
, PINT6
, PINT7
,
24 SINT8
, SINT7
, SINT6
, SINT5
, SINT4
, SINT3
, SINT2
, SINT1
,
26 SCIF0_BRI
, SCIF0_ERI
, SCIF0_RXI
, SCIF0_TXI
,
27 SCIF1_BRI
, SCIF1_ERI
, SCIF1_RXI
, SCIF1_TXI
,
29 MTU2_TGI0A
, MTU2_TGI0B
, MTU2_TGI0C
, MTU2_TGI0D
,
30 MTU2_TCI0V
, MTU2_TGI0E
, MTU2_TGI0F
,
31 MTU2_TGI1A
, MTU2_TGI1B
, MTU2_TCI1V
, MTU2_TCI1U
,
32 MTU2_TGI2A
, MTU2_TGI2B
, MTU2_TCI2V
, MTU2_TCI2U
,
33 MTU2_TGI3A
, MTU2_TGI3B
, MTU2_TGI3C
, MTU2_TGI3D
, MTU2_TCI3V
,
34 MTU2_TGI4A
, MTU2_TGI4B
, MTU2_TGI4C
, MTU2_TGI4D
, MTU2_TCI4V
,
35 MTU2_TGI5U
, MTU2_TGI5V
, MTU2_TGI5W
,
37 /* interrupt groups */
39 MTU2_GROUP1
, MTU2_GROUP2
, MTU2_GROUP3
, MTU2_GROUP4
, MTU2_GROUP5
42 static struct intc_vect vectors
[] __initdata
= {
43 INTC_IRQ(IRQ0
, 64), INTC_IRQ(IRQ1
, 65),
44 INTC_IRQ(IRQ2
, 66), INTC_IRQ(IRQ3
, 67),
45 INTC_IRQ(IRQ4
, 68), INTC_IRQ(IRQ5
, 69),
46 INTC_IRQ(IRQ6
, 70), INTC_IRQ(IRQ7
, 71),
47 INTC_IRQ(IRQ8
, 72), INTC_IRQ(IRQ9
, 73),
48 INTC_IRQ(IRQ10
, 74), INTC_IRQ(IRQ11
, 75),
49 INTC_IRQ(IRQ12
, 76), INTC_IRQ(IRQ13
, 77),
50 INTC_IRQ(IRQ14
, 78), INTC_IRQ(IRQ15
, 79),
52 INTC_IRQ(PINT0
, 80), INTC_IRQ(PINT1
, 81),
53 INTC_IRQ(PINT2
, 82), INTC_IRQ(PINT3
, 83),
54 INTC_IRQ(PINT4
, 84), INTC_IRQ(PINT5
, 85),
55 INTC_IRQ(PINT6
, 86), INTC_IRQ(PINT7
, 87),
57 INTC_IRQ(SINT8
, 94), INTC_IRQ(SINT7
, 95),
58 INTC_IRQ(SINT6
, 96), INTC_IRQ(SINT5
, 97),
59 INTC_IRQ(SINT4
, 98), INTC_IRQ(SINT3
, 99),
60 INTC_IRQ(SINT2
, 100), INTC_IRQ(SINT1
, 101),
62 INTC_IRQ(SCIF0_RXI
, 220), INTC_IRQ(SCIF0_TXI
, 221),
63 INTC_IRQ(SCIF0_BRI
, 222), INTC_IRQ(SCIF0_ERI
, 223),
64 INTC_IRQ(SCIF1_RXI
, 224), INTC_IRQ(SCIF1_TXI
, 225),
65 INTC_IRQ(SCIF1_BRI
, 226), INTC_IRQ(SCIF1_ERI
, 227),
67 INTC_IRQ(MTU2_TGI0A
, 228), INTC_IRQ(MTU2_TGI0B
, 229),
68 INTC_IRQ(MTU2_TGI0C
, 230), INTC_IRQ(MTU2_TGI0D
, 231),
69 INTC_IRQ(MTU2_TCI0V
, 232), INTC_IRQ(MTU2_TGI0E
, 233),
71 INTC_IRQ(MTU2_TGI0F
, 234), INTC_IRQ(MTU2_TGI1A
, 235),
72 INTC_IRQ(MTU2_TGI1B
, 236), INTC_IRQ(MTU2_TCI1V
, 237),
73 INTC_IRQ(MTU2_TCI1U
, 238), INTC_IRQ(MTU2_TGI2A
, 239),
75 INTC_IRQ(MTU2_TGI2B
, 240), INTC_IRQ(MTU2_TCI2V
, 241),
76 INTC_IRQ(MTU2_TCI2U
, 242), INTC_IRQ(MTU2_TGI3A
, 243),
78 INTC_IRQ(MTU2_TGI3B
, 244),
79 INTC_IRQ(MTU2_TGI3C
, 245),
81 INTC_IRQ(MTU2_TGI3D
, 246), INTC_IRQ(MTU2_TCI3V
, 247),
82 INTC_IRQ(MTU2_TGI4A
, 248), INTC_IRQ(MTU2_TGI4B
, 249),
83 INTC_IRQ(MTU2_TGI4C
, 250), INTC_IRQ(MTU2_TGI4D
, 251),
85 INTC_IRQ(MTU2_TCI4V
, 252), INTC_IRQ(MTU2_TGI5U
, 253),
86 INTC_IRQ(MTU2_TGI5V
, 254), INTC_IRQ(MTU2_TGI5W
, 255),
89 static struct intc_group groups
[] __initdata
= {
90 INTC_GROUP(PINT
, PINT0
, PINT1
, PINT2
, PINT3
,
91 PINT4
, PINT5
, PINT6
, PINT7
),
92 INTC_GROUP(MTU2_GROUP1
, MTU2_TGI0A
, MTU2_TGI0B
, MTU2_TGI0C
, MTU2_TGI0D
,
93 MTU2_TCI0V
, MTU2_TGI0E
),
94 INTC_GROUP(MTU2_GROUP2
, MTU2_TGI0F
, MTU2_TGI1A
, MTU2_TGI1B
,
95 MTU2_TCI1V
, MTU2_TCI1U
, MTU2_TGI2A
),
96 INTC_GROUP(MTU2_GROUP3
, MTU2_TGI2B
, MTU2_TCI2V
, MTU2_TCI2U
,
98 INTC_GROUP(MTU2_GROUP4
, MTU2_TGI3D
, MTU2_TCI3V
, MTU2_TGI4A
,
99 MTU2_TGI4B
, MTU2_TGI4C
, MTU2_TGI4D
),
100 INTC_GROUP(MTU2_GROUP5
, MTU2_TCI4V
, MTU2_TGI5U
, MTU2_TGI5V
, MTU2_TGI5W
),
101 INTC_GROUP(SCIF0
, SCIF0_BRI
, SCIF0_ERI
, SCIF0_RXI
, SCIF0_TXI
),
102 INTC_GROUP(SCIF1
, SCIF1_BRI
, SCIF1_ERI
, SCIF1_RXI
, SCIF1_TXI
),
105 static struct intc_prio_reg prio_registers
[] __initdata
= {
106 { 0xfffd9418, 0, 16, 4, /* IPR01 */ { IRQ0
, IRQ1
, IRQ2
, IRQ3
} },
107 { 0xfffd941a, 0, 16, 4, /* IPR02 */ { IRQ4
, IRQ5
, IRQ6
, IRQ7
} },
108 { 0xfffd941c, 0, 16, 4, /* IPR03 */ { IRQ8
, IRQ9
, IRQ10
, IRQ11
} },
109 { 0xfffd941e, 0, 16, 4, /* IPR04 */ { IRQ12
, IRQ13
, IRQ14
, IRQ15
} },
110 { 0xfffd9420, 0, 16, 4, /* IPR05 */ { PINT
, 0, 0, 0 } },
111 { 0xfffd9800, 0, 16, 4, /* IPR06 */ { } },
112 { 0xfffd9802, 0, 16, 4, /* IPR07 */ { } },
113 { 0xfffd9804, 0, 16, 4, /* IPR08 */ { } },
114 { 0xfffd9806, 0, 16, 4, /* IPR09 */ { } },
115 { 0xfffd9808, 0, 16, 4, /* IPR10 */ { } },
116 { 0xfffd980a, 0, 16, 4, /* IPR11 */ { } },
117 { 0xfffd980c, 0, 16, 4, /* IPR12 */ { } },
118 { 0xfffd980e, 0, 16, 4, /* IPR13 */ { } },
119 { 0xfffd9810, 0, 16, 4, /* IPR14 */ { 0, 0, 0, SCIF0
} },
120 { 0xfffd9812, 0, 16, 4, /* IPR15 */
121 { SCIF1
, MTU2_GROUP1
, MTU2_GROUP2
, MTU2_GROUP3
} },
122 { 0xfffd9814, 0, 16, 4, /* IPR16 */
123 { MTU2_TGI3B
, MTU2_TGI3C
, MTU2_GROUP4
, MTU2_GROUP5
} },
126 static struct intc_mask_reg mask_registers
[] __initdata
= {
127 { 0xfffd9408, 0, 16, /* PINTER */
128 { 0, 0, 0, 0, 0, 0, 0, 0,
129 PINT7
, PINT6
, PINT5
, PINT4
, PINT3
, PINT2
, PINT1
, PINT0
} },
132 static DECLARE_INTC_DESC(intc_desc
, "mxg", vectors
, groups
,
133 mask_registers
, prio_registers
, NULL
);
135 static struct plat_sci_port sci_platform_data
[] = {
137 .mapbase
= 0xff804000,
138 .flags
= UPF_BOOT_AUTOCONF
,
140 .irqs
= { 223, 220, 221, 222 },
146 static struct platform_device sci_device
= {
150 .platform_data
= sci_platform_data
,
154 static struct platform_device
*mxg_devices
[] __initdata
= {
158 static int __init
mxg_devices_setup(void)
160 return platform_add_devices(mxg_devices
,
161 ARRAY_SIZE(mxg_devices
));
163 __initcall(mxg_devices_setup
);
165 void __init
plat_irq_setup(void)
167 register_intc_controller(&intc_desc
);