xref: /openbmc/linux/arch/sh/kernel/cpu/sh3/setup-sh7710.c (revision 9465a54fa4a9da628091c372baa84120f8304587)
1e5723e0eSPaul Mundt /*
2e5723e0eSPaul Mundt  * SH7710 Setup
3e5723e0eSPaul Mundt  *
4e5723e0eSPaul Mundt  *  Copyright (C) 2006  Paul Mundt
5*9465a54fSNobuhiro Iwamatsu  *  Copyright (C) 2007  Nobuhiro Iwamatsu
6e5723e0eSPaul Mundt  *
7e5723e0eSPaul Mundt  * This file is subject to the terms and conditions of the GNU General Public
8e5723e0eSPaul Mundt  * License.  See the file "COPYING" in the main directory of this archive
9e5723e0eSPaul Mundt  * for more details.
10e5723e0eSPaul Mundt  */
11e5723e0eSPaul Mundt #include <linux/platform_device.h>
12e5723e0eSPaul Mundt #include <linux/init.h>
13e5723e0eSPaul Mundt #include <linux/serial.h>
14e5723e0eSPaul Mundt #include <asm/sci.h>
15e5723e0eSPaul Mundt 
16e5723e0eSPaul Mundt static struct plat_sci_port sci_platform_data[] = {
17e5723e0eSPaul Mundt 	{
18e5723e0eSPaul Mundt 		.mapbase	= 0xa4400000,
19e5723e0eSPaul Mundt 		.flags		= UPF_BOOT_AUTOCONF,
20e5723e0eSPaul Mundt 		.type		= PORT_SCIF,
21e5723e0eSPaul Mundt 		.irqs		= { 52, 53, 55, 54 },
22e5723e0eSPaul Mundt 	}, {
23*9465a54fSNobuhiro Iwamatsu 		.mapbase	= 0xa4420000,
24*9465a54fSNobuhiro Iwamatsu 		.flags		= UPF_BOOT_AUTOCONF,
25*9465a54fSNobuhiro Iwamatsu 		.type		= PORT_SCIF,
26*9465a54fSNobuhiro Iwamatsu 		.irqs           = { 56, 57, 59, 58 },
27*9465a54fSNobuhiro Iwamatsu 	}, {
28*9465a54fSNobuhiro Iwamatsu 
29e5723e0eSPaul Mundt 		.flags = 0,
30e5723e0eSPaul Mundt 	}
31e5723e0eSPaul Mundt };
32e5723e0eSPaul Mundt 
33e5723e0eSPaul Mundt static struct platform_device sci_device = {
34e5723e0eSPaul Mundt 	.name		= "sh-sci",
35e5723e0eSPaul Mundt 	.id		= -1,
36e5723e0eSPaul Mundt 	.dev		= {
37e5723e0eSPaul Mundt 		.platform_data	= sci_platform_data,
38e5723e0eSPaul Mundt 	},
39e5723e0eSPaul Mundt };
40e5723e0eSPaul Mundt 
41e5723e0eSPaul Mundt static struct platform_device *sh7710_devices[] __initdata = {
42e5723e0eSPaul Mundt 	&sci_device,
43e5723e0eSPaul Mundt };
44e5723e0eSPaul Mundt 
45e5723e0eSPaul Mundt static int __init sh7710_devices_setup(void)
46e5723e0eSPaul Mundt {
47e5723e0eSPaul Mundt 	return platform_add_devices(sh7710_devices,
48e5723e0eSPaul Mundt 				    ARRAY_SIZE(sh7710_devices));
49e5723e0eSPaul Mundt }
50e5723e0eSPaul Mundt __initcall(sh7710_devices_setup);
51*9465a54fSNobuhiro Iwamatsu 
52*9465a54fSNobuhiro Iwamatsu static struct ipr_data sh7710_ipr_map[] = {
53*9465a54fSNobuhiro Iwamatsu 	/* IRQ, IPR-idx, shift, priority */
54*9465a54fSNobuhiro Iwamatsu 	{ 16, 0, 12, 2 }, /* TMU0 TUNI*/
55*9465a54fSNobuhiro Iwamatsu 	{ 17, 0,  8, 2 }, /* TMU1 TUNI */
56*9465a54fSNobuhiro Iwamatsu 	{ 18, 0,  4, 2 }, /* TMU2 TUNI */
57*9465a54fSNobuhiro Iwamatsu 	{ 27, 1, 12, 2 }, /* WDT ITI */
58*9465a54fSNobuhiro Iwamatsu 	{ 20, 0,  0, 2 }, /* RTC ATI (alarm) */
59*9465a54fSNobuhiro Iwamatsu 	{ 21, 0,  0, 2 }, /* RTC PRI (period) */
60*9465a54fSNobuhiro Iwamatsu 	{ 22, 0,  0, 2 }, /* RTC CUI (carry) */
61*9465a54fSNobuhiro Iwamatsu 	{ 48, 4, 12, 7 }, /* DMAC DMTE0 */
62*9465a54fSNobuhiro Iwamatsu 	{ 49, 4, 12, 7 }, /* DMAC DMTE1 */
63*9465a54fSNobuhiro Iwamatsu 	{ 50, 4, 12, 7 }, /* DMAC DMTE2 */
64*9465a54fSNobuhiro Iwamatsu 	{ 51, 4, 12, 7 }, /* DMAC DMTE3 */
65*9465a54fSNobuhiro Iwamatsu 	{ 52, 4,  8, 3 }, /* SCIF0 ERI */
66*9465a54fSNobuhiro Iwamatsu 	{ 53, 4,  8, 3 }, /* SCIF0 RXI */
67*9465a54fSNobuhiro Iwamatsu 	{ 54, 4,  8, 3 }, /* SCIF0 BRI */
68*9465a54fSNobuhiro Iwamatsu 	{ 55, 4,  8, 3 }, /* SCIF0 TXI */
69*9465a54fSNobuhiro Iwamatsu 	{ 56, 4,  4, 3 }, /* SCIF1 ERI */
70*9465a54fSNobuhiro Iwamatsu 	{ 57, 4,  4, 3 }, /* SCIF1 RXI */
71*9465a54fSNobuhiro Iwamatsu 	{ 58, 4,  4, 3 }, /* SCIF1 BRI */
72*9465a54fSNobuhiro Iwamatsu 	{ 59, 4,  4, 3 }, /* SCIF1 TXI */
73*9465a54fSNobuhiro Iwamatsu 	{ 76, 5,  8, 7 }, /* DMAC DMTE4 */
74*9465a54fSNobuhiro Iwamatsu 	{ 77, 5,  8, 7 }, /* DMAC DMTE5 */
75*9465a54fSNobuhiro Iwamatsu 	{ 80, 6, 12, 5 }, /* EDMAC EINT0 */
76*9465a54fSNobuhiro Iwamatsu 	{ 81, 6,  8, 5 }, /* EDMAC EINT1 */
77*9465a54fSNobuhiro Iwamatsu 	{ 82, 6,  4, 5 }, /* EDMAC EINT2 */
78*9465a54fSNobuhiro Iwamatsu };
79*9465a54fSNobuhiro Iwamatsu 
80*9465a54fSNobuhiro Iwamatsu static unsigned long ipr_offsets[] = {
81*9465a54fSNobuhiro Iwamatsu 	0xA414FEE2	/* 0: IPRA */
82*9465a54fSNobuhiro Iwamatsu ,	0xA414FEE4	/* 1: IPRB */
83*9465a54fSNobuhiro Iwamatsu ,	0xA4140016	/* 2: IPRC */
84*9465a54fSNobuhiro Iwamatsu ,	0xA4140018	/* 3: IPRD */
85*9465a54fSNobuhiro Iwamatsu ,	0xA414001A	/* 4: IPRE */
86*9465a54fSNobuhiro Iwamatsu ,	0xA4080000	/* 5: IPRF */
87*9465a54fSNobuhiro Iwamatsu ,	0xA4080002	/* 6: IPRG */
88*9465a54fSNobuhiro Iwamatsu ,	0xA4080004	/* 7: IPRH */
89*9465a54fSNobuhiro Iwamatsu ,	0xA4080006	/* 8: IPRI */
90*9465a54fSNobuhiro Iwamatsu };
91*9465a54fSNobuhiro Iwamatsu 
92*9465a54fSNobuhiro Iwamatsu /* given the IPR index return the address of the IPR register */
93*9465a54fSNobuhiro Iwamatsu unsigned int map_ipridx_to_addr(int idx)
94*9465a54fSNobuhiro Iwamatsu {
95*9465a54fSNobuhiro Iwamatsu 	if (idx >= ARRAY_SIZE(ipr_offsets))
96*9465a54fSNobuhiro Iwamatsu 		return 0;
97*9465a54fSNobuhiro Iwamatsu 	return ipr_offsets[idx];
98*9465a54fSNobuhiro Iwamatsu }
99*9465a54fSNobuhiro Iwamatsu 
100*9465a54fSNobuhiro Iwamatsu void __init init_IRQ_ipr()
101*9465a54fSNobuhiro Iwamatsu {
102*9465a54fSNobuhiro Iwamatsu 	make_ipr_irq(sh7710_ipr_map, ARRAY_SIZE(sh7710_ipr_map));
103*9465a54fSNobuhiro Iwamatsu }
104