162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * linux/arch/sh/boards/se/7780/setup.c 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2006,2007 Nobuhiro Iwamatsu 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Hitachi UL SolutionEngine 7780 Support. 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci#include <linux/init.h> 1062306a36Sopenharmony_ci#include <linux/platform_device.h> 1162306a36Sopenharmony_ci#include <asm/machvec.h> 1262306a36Sopenharmony_ci#include <mach-se/mach/se7780.h> 1362306a36Sopenharmony_ci#include <asm/io.h> 1462306a36Sopenharmony_ci#include <asm/heartbeat.h> 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci/* Heartbeat */ 1762306a36Sopenharmony_cistatic struct resource heartbeat_resource = { 1862306a36Sopenharmony_ci .start = PA_LED, 1962306a36Sopenharmony_ci .end = PA_LED, 2062306a36Sopenharmony_ci .flags = IORESOURCE_MEM | IORESOURCE_MEM_16BIT, 2162306a36Sopenharmony_ci}; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_cistatic struct platform_device heartbeat_device = { 2462306a36Sopenharmony_ci .name = "heartbeat", 2562306a36Sopenharmony_ci .id = -1, 2662306a36Sopenharmony_ci .num_resources = 1, 2762306a36Sopenharmony_ci .resource = &heartbeat_resource, 2862306a36Sopenharmony_ci}; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci/* SMC91x */ 3162306a36Sopenharmony_cistatic struct resource smc91x_eth_resources[] = { 3262306a36Sopenharmony_ci [0] = { 3362306a36Sopenharmony_ci .name = "smc91x-regs" , 3462306a36Sopenharmony_ci .start = PA_LAN + 0x300, 3562306a36Sopenharmony_ci .end = PA_LAN + 0x300 + 0x10 , 3662306a36Sopenharmony_ci .flags = IORESOURCE_MEM, 3762306a36Sopenharmony_ci }, 3862306a36Sopenharmony_ci [1] = { 3962306a36Sopenharmony_ci .start = SMC_IRQ, 4062306a36Sopenharmony_ci .end = SMC_IRQ, 4162306a36Sopenharmony_ci .flags = IORESOURCE_IRQ, 4262306a36Sopenharmony_ci }, 4362306a36Sopenharmony_ci}; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistatic struct platform_device smc91x_eth_device = { 4662306a36Sopenharmony_ci .name = "smc91x", 4762306a36Sopenharmony_ci .id = 0, 4862306a36Sopenharmony_ci .dev = { 4962306a36Sopenharmony_ci .dma_mask = NULL, /* don't use dma */ 5062306a36Sopenharmony_ci .coherent_dma_mask = 0xffffffff, 5162306a36Sopenharmony_ci }, 5262306a36Sopenharmony_ci .num_resources = ARRAY_SIZE(smc91x_eth_resources), 5362306a36Sopenharmony_ci .resource = smc91x_eth_resources, 5462306a36Sopenharmony_ci}; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_cistatic struct platform_device *se7780_devices[] __initdata = { 5762306a36Sopenharmony_ci &heartbeat_device, 5862306a36Sopenharmony_ci &smc91x_eth_device, 5962306a36Sopenharmony_ci}; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_cistatic int __init se7780_devices_setup(void) 6262306a36Sopenharmony_ci{ 6362306a36Sopenharmony_ci return platform_add_devices(se7780_devices, 6462306a36Sopenharmony_ci ARRAY_SIZE(se7780_devices)); 6562306a36Sopenharmony_ci} 6662306a36Sopenharmony_cidevice_initcall(se7780_devices_setup); 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci#define GPIO_PHCR 0xFFEA000E 6962306a36Sopenharmony_ci#define GPIO_PMSELR 0xFFEA0080 7062306a36Sopenharmony_ci#define GPIO_PECR 0xFFEA0008 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_cistatic void __init se7780_setup(char **cmdline_p) 7362306a36Sopenharmony_ci{ 7462306a36Sopenharmony_ci /* "SH-Linux" on LED Display */ 7562306a36Sopenharmony_ci __raw_writew( 'S' , PA_LED_DISP + (DISP_SEL0_ADDR << 1) ); 7662306a36Sopenharmony_ci __raw_writew( 'H' , PA_LED_DISP + (DISP_SEL1_ADDR << 1) ); 7762306a36Sopenharmony_ci __raw_writew( '-' , PA_LED_DISP + (DISP_SEL2_ADDR << 1) ); 7862306a36Sopenharmony_ci __raw_writew( 'L' , PA_LED_DISP + (DISP_SEL3_ADDR << 1) ); 7962306a36Sopenharmony_ci __raw_writew( 'i' , PA_LED_DISP + (DISP_SEL4_ADDR << 1) ); 8062306a36Sopenharmony_ci __raw_writew( 'n' , PA_LED_DISP + (DISP_SEL5_ADDR << 1) ); 8162306a36Sopenharmony_ci __raw_writew( 'u' , PA_LED_DISP + (DISP_SEL6_ADDR << 1) ); 8262306a36Sopenharmony_ci __raw_writew( 'x' , PA_LED_DISP + (DISP_SEL7_ADDR << 1) ); 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci printk(KERN_INFO "Hitachi UL Solutions Engine 7780SE03 support.\n"); 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_ci /* 8762306a36Sopenharmony_ci * PCI REQ/GNT setting 8862306a36Sopenharmony_ci * REQ0/GNT0 -> USB 8962306a36Sopenharmony_ci * REQ1/GNT1 -> PC Card 9062306a36Sopenharmony_ci * REQ2/GNT2 -> Serial ATA 9162306a36Sopenharmony_ci * REQ3/GNT3 -> PCI slot 9262306a36Sopenharmony_ci */ 9362306a36Sopenharmony_ci __raw_writew(0x0213, FPGA_REQSEL); 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci /* GPIO setting */ 9662306a36Sopenharmony_ci __raw_writew(0x0000, GPIO_PECR); 9762306a36Sopenharmony_ci __raw_writew(__raw_readw(GPIO_PHCR)&0xfff3, GPIO_PHCR); 9862306a36Sopenharmony_ci __raw_writew(0x0c00, GPIO_PMSELR); 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_ci /* iVDR Power ON */ 10162306a36Sopenharmony_ci __raw_writew(0x0001, FPGA_IVDRPW); 10262306a36Sopenharmony_ci} 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci/* 10562306a36Sopenharmony_ci * The Machine Vector 10662306a36Sopenharmony_ci */ 10762306a36Sopenharmony_cistatic struct sh_machine_vector mv_se7780 __initmv = { 10862306a36Sopenharmony_ci .mv_name = "Solution Engine 7780" , 10962306a36Sopenharmony_ci .mv_setup = se7780_setup , 11062306a36Sopenharmony_ci .mv_init_irq = init_se7780_IRQ, 11162306a36Sopenharmony_ci}; 112