setup-sh7619.c 2.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
/*
 * SH7619 Setup
 *
 *  Copyright (C) 2006  Yoshinori Sato
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file "COPYING" in the main directory of this archive
 * for more details.
 */
#include <linux/platform_device.h>
#include <linux/init.h>
#include <linux/serial.h>
#include <asm/sci.h>

static struct plat_sci_port sci_platform_data[] = {
	{
		.mapbase	= 0xf8400000,
		.flags		= UPF_BOOT_AUTOCONF,
		.type		= PORT_SCIF,
		.irqs		=  { 88, 89, 91, 90},
	}, {
		.mapbase	= 0xf8410000,
		.flags		= UPF_BOOT_AUTOCONF,
		.type		= PORT_SCIF,
		.irqs		=  { 92, 93, 95, 94},
	}, {
		.mapbase	= 0xf8420000,
		.flags		= UPF_BOOT_AUTOCONF,
		.type		= PORT_SCIF,
		.irqs		=  { 96, 97, 99, 98},
	}, {
		.flags = 0,
	}
};

static struct platform_device sci_device = {
	.name		= "sh-sci",
	.id		= -1,
	.dev		= {
		.platform_data	= sci_platform_data,
	},
};

static struct platform_device *sh7619_devices[] __initdata = {
	&sci_device,
};

static int __init sh7619_devices_setup(void)
{
	return platform_add_devices(sh7619_devices,
				    ARRAY_SIZE(sh7619_devices));
}
__initcall(sh7619_devices_setup);
54

M
Magnus Damm 已提交
55
static struct ipr_data ipr_irq_table[] = {
56 57 58 59 60 61 62 63 64 65 66 67 68
	{ 86, 0,  4, 2 },	/* CMI0 */
	{ 88, 1, 12, 3 },	/* SCIF0_ERI */
	{ 89, 1, 12, 3 },	/* SCIF0_RXI */
	{ 90, 1, 12, 3 },	/* SCIF0_BRI */
	{ 91, 1, 12, 3 },	/* SCIF0_TXI */
	{ 92, 1,  8, 3 },	/* SCIF1_ERI */
	{ 93, 1,  8, 3 },	/* SCIF1_RXI */
	{ 94, 1,  8, 3 },	/* SCIF1_BRI */
	{ 95, 1,  8, 3 },	/* SCIF1_TXI */
	{ 96, 1,  4, 3 },	/* SCIF2_ERI */
	{ 97, 1,  4, 3 },	/* SCIF2_RXI */
	{ 98, 1,  4, 3 },	/* SCIF2_BRI */
	{ 99, 1,  4, 3 },	/* SCIF2_TXI */
69 70
};

M
Magnus Damm 已提交
71
static unsigned long ipr_offsets[] = {
72 73 74 75 76 77 78
	0xf8080000,	/* IPRC */
	0xf8080002,	/* IPRD */
	0xf8080004,	/* IPRE */
	0xf8080006,	/* IPRF */
	0xf8080008,	/* IPRG */
};

M
Magnus Damm 已提交
79 80 81 82 83 84 85 86 87 88 89
static struct ipr_desc ipr_irq_desc = {
	.ipr_offsets	= ipr_offsets,
	.nr_offsets	= ARRAY_SIZE(ipr_offsets),

	.ipr_data	= ipr_irq_table,
	.nr_irqs	= ARRAY_SIZE(ipr_irq_table),

	.chip = {
		.name	= "IPR-sh7619",
	},
};
90

91
void __init plat_irq_setup(void)
92
{
M
Magnus Damm 已提交
93
	register_ipr_controller(&ipr_irq_desc);
94
}