162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * linux/arch/sh/boards/se/7721/setup.c
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2008 Renesas Solutions Corp.
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * Hitachi UL SolutionEngine 7721 Support.
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci#include <linux/init.h>
1062306a36Sopenharmony_ci#include <linux/platform_device.h>
1162306a36Sopenharmony_ci#include <mach-se/mach/se7721.h>
1262306a36Sopenharmony_ci#include <mach-se/mach/mrshpc.h>
1362306a36Sopenharmony_ci#include <asm/machvec.h>
1462306a36Sopenharmony_ci#include <asm/io.h>
1562306a36Sopenharmony_ci#include <asm/heartbeat.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_cistatic unsigned char heartbeat_bit_pos[] = { 8, 9, 10, 11, 12, 13, 14, 15 };
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_cistatic struct heartbeat_data heartbeat_data = {
2062306a36Sopenharmony_ci	.bit_pos	= heartbeat_bit_pos,
2162306a36Sopenharmony_ci	.nr_bits	= ARRAY_SIZE(heartbeat_bit_pos),
2262306a36Sopenharmony_ci};
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_cistatic struct resource heartbeat_resource = {
2562306a36Sopenharmony_ci	.start	= PA_LED,
2662306a36Sopenharmony_ci	.end	= PA_LED,
2762306a36Sopenharmony_ci	.flags	= IORESOURCE_MEM | IORESOURCE_MEM_16BIT,
2862306a36Sopenharmony_ci};
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_cistatic struct platform_device heartbeat_device = {
3162306a36Sopenharmony_ci	.name		= "heartbeat",
3262306a36Sopenharmony_ci	.id		= -1,
3362306a36Sopenharmony_ci	.dev	= {
3462306a36Sopenharmony_ci		.platform_data	= &heartbeat_data,
3562306a36Sopenharmony_ci	},
3662306a36Sopenharmony_ci	.num_resources	= 1,
3762306a36Sopenharmony_ci	.resource	= &heartbeat_resource,
3862306a36Sopenharmony_ci};
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_cistatic struct resource cf_ide_resources[] = {
4162306a36Sopenharmony_ci	[0] = {
4262306a36Sopenharmony_ci		.start	= PA_MRSHPC_IO + 0x1f0,
4362306a36Sopenharmony_ci		.end	= PA_MRSHPC_IO + 0x1f0 + 8 ,
4462306a36Sopenharmony_ci		.flags	= IORESOURCE_IO,
4562306a36Sopenharmony_ci	},
4662306a36Sopenharmony_ci	[1] = {
4762306a36Sopenharmony_ci		.start	= PA_MRSHPC_IO + 0x1f0 + 0x206,
4862306a36Sopenharmony_ci		.end	= PA_MRSHPC_IO + 0x1f0 + 8 + 0x206 + 8,
4962306a36Sopenharmony_ci		.flags	= IORESOURCE_IO,
5062306a36Sopenharmony_ci	},
5162306a36Sopenharmony_ci	[2] = {
5262306a36Sopenharmony_ci		.start  = MRSHPC_IRQ0,
5362306a36Sopenharmony_ci		.flags  = IORESOURCE_IRQ,
5462306a36Sopenharmony_ci	},
5562306a36Sopenharmony_ci};
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_cistatic struct platform_device cf_ide_device = {
5862306a36Sopenharmony_ci	.name		= "pata_platform",
5962306a36Sopenharmony_ci	.id		= -1,
6062306a36Sopenharmony_ci	.num_resources	= ARRAY_SIZE(cf_ide_resources),
6162306a36Sopenharmony_ci	.resource	= cf_ide_resources,
6262306a36Sopenharmony_ci};
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_cistatic struct platform_device *se7721_devices[] __initdata = {
6562306a36Sopenharmony_ci	&cf_ide_device,
6662306a36Sopenharmony_ci	&heartbeat_device
6762306a36Sopenharmony_ci};
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_cistatic int __init se7721_devices_setup(void)
7062306a36Sopenharmony_ci{
7162306a36Sopenharmony_ci	mrshpc_setup_windows();
7262306a36Sopenharmony_ci	return platform_add_devices(se7721_devices, ARRAY_SIZE(se7721_devices));
7362306a36Sopenharmony_ci}
7462306a36Sopenharmony_cidevice_initcall(se7721_devices_setup);
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_cistatic void __init se7721_setup(char **cmdline_p)
7762306a36Sopenharmony_ci{
7862306a36Sopenharmony_ci	/* for USB */
7962306a36Sopenharmony_ci	__raw_writew(0x0000, 0xA405010C);	/* PGCR */
8062306a36Sopenharmony_ci	__raw_writew(0x0000, 0xA405010E);	/* PHCR */
8162306a36Sopenharmony_ci	__raw_writew(0x00AA, 0xA4050118);	/* PPCR */
8262306a36Sopenharmony_ci	__raw_writew(0x0000, 0xA4050124);	/* PSELA */
8362306a36Sopenharmony_ci}
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ci/*
8662306a36Sopenharmony_ci * The Machine Vector
8762306a36Sopenharmony_ci */
8862306a36Sopenharmony_cistruct sh_machine_vector mv_se7721 __initmv = {
8962306a36Sopenharmony_ci	.mv_name		= "Solution Engine 7721",
9062306a36Sopenharmony_ci	.mv_setup		= se7721_setup,
9162306a36Sopenharmony_ci	.mv_init_irq		= init_se7721_IRQ,
9262306a36Sopenharmony_ci};
93