4 * Copyright (C) 2006 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>
15 static struct resource rtc_resources
[] = {
18 .end
= 0xffe80000 + 0x58 - 1,
19 .flags
= IORESOURCE_IO
,
24 .flags
= IORESOURCE_IRQ
,
29 .flags
= IORESOURCE_IRQ
,
34 .flags
= IORESOURCE_IRQ
,
38 static struct platform_device rtc_device
= {
41 .num_resources
= ARRAY_SIZE(rtc_resources
),
42 .resource
= rtc_resources
,
45 static struct plat_sci_port sci_platform_data
[] = {
47 .mapbase
= 0xffe00000,
48 .flags
= UPF_BOOT_AUTOCONF
,
50 .irqs
= { 40, 41, 43, 42 },
52 .mapbase
= 0xffe10000,
53 .flags
= UPF_BOOT_AUTOCONF
,
55 .irqs
= { 76, 77, 79, 78 },
61 static struct platform_device sci_device
= {
65 .platform_data
= sci_platform_data
,
69 static struct platform_device
*sh7780_devices
[] __initdata
= {
74 static int __init
sh7780_devices_setup(void)
76 return platform_add_devices(sh7780_devices
,
77 ARRAY_SIZE(sh7780_devices
));
79 __initcall(sh7780_devices_setup
);
81 static struct intc2_data intc2_irq_table
[] = {
82 { TIMER_IRQ
, 0, 24, 0, INTC_TMU0_MSK
, 2 },
83 { 21, 1, 0, 0, INTC_RTC_MSK
, TIMER_PRIORITY
},
84 { 22, 1, 1, 0, INTC_RTC_MSK
, TIMER_PRIORITY
},
85 { 23, 1, 2, 0, INTC_RTC_MSK
, TIMER_PRIORITY
},
86 { SCIF0_ERI_IRQ
, 8, 24, 0, INTC_SCIF0_MSK
, SCIF0_PRIORITY
},
87 { SCIF0_RXI_IRQ
, 8, 24, 0, INTC_SCIF0_MSK
, SCIF0_PRIORITY
},
88 { SCIF0_BRI_IRQ
, 8, 24, 0, INTC_SCIF0_MSK
, SCIF0_PRIORITY
},
89 { SCIF0_TXI_IRQ
, 8, 24, 0, INTC_SCIF0_MSK
, SCIF0_PRIORITY
},
91 { SCIF1_ERI_IRQ
, 8, 16, 0, INTC_SCIF1_MSK
, SCIF1_PRIORITY
},
92 { SCIF1_RXI_IRQ
, 8, 16, 0, INTC_SCIF1_MSK
, SCIF1_PRIORITY
},
93 { SCIF1_BRI_IRQ
, 8, 16, 0, INTC_SCIF1_MSK
, SCIF1_PRIORITY
},
94 { SCIF1_TXI_IRQ
, 8, 16, 0, INTC_SCIF1_MSK
, SCIF1_PRIORITY
},
96 { PCIC0_IRQ
, 0x10, 8, 0, INTC_PCIC0_MSK
, PCIC0_PRIORITY
},
97 { PCIC1_IRQ
, 0x10, 0, 0, INTC_PCIC1_MSK
, PCIC1_PRIORITY
},
98 { PCIC2_IRQ
, 0x14, 24, 0, INTC_PCIC2_MSK
, PCIC2_PRIORITY
},
99 { PCIC3_IRQ
, 0x14, 16, 0, INTC_PCIC3_MSK
, PCIC3_PRIORITY
},
100 { PCIC4_IRQ
, 0x14, 8, 0, INTC_PCIC4_MSK
, PCIC4_PRIORITY
},
103 void __init
init_IRQ_intc2(void)
105 make_intc2_irq(intc2_irq_table
, ARRAY_SIZE(intc2_irq_table
));