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