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));