18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * arch/sh/boards/renesas/edosk7705/setup.c 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2000 Kazumoto Kojima 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * Hitachi SolutionEngine Support. 88c2ecf20Sopenharmony_ci * 98c2ecf20Sopenharmony_ci * Modified for edosk7705 development 108c2ecf20Sopenharmony_ci * board by S. Dunn, 2003. 118c2ecf20Sopenharmony_ci */ 128c2ecf20Sopenharmony_ci#include <linux/init.h> 138c2ecf20Sopenharmony_ci#include <linux/irq.h> 148c2ecf20Sopenharmony_ci#include <linux/platform_device.h> 158c2ecf20Sopenharmony_ci#include <linux/interrupt.h> 168c2ecf20Sopenharmony_ci#include <linux/smc91x.h> 178c2ecf20Sopenharmony_ci#include <linux/sh_intc.h> 188c2ecf20Sopenharmony_ci#include <asm/machvec.h> 198c2ecf20Sopenharmony_ci#include <linux/sizes.h> 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ci#define SMC_IOBASE 0xA2000000 228c2ecf20Sopenharmony_ci#define SMC_IO_OFFSET 0x300 238c2ecf20Sopenharmony_ci#define SMC_IOADDR (SMC_IOBASE + SMC_IO_OFFSET) 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci#define ETHERNET_IRQ evt2irq(0x320) 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_cistatic void __init sh_edosk7705_init_irq(void) 288c2ecf20Sopenharmony_ci{ 298c2ecf20Sopenharmony_ci make_imask_irq(ETHERNET_IRQ); 308c2ecf20Sopenharmony_ci} 318c2ecf20Sopenharmony_ci 328c2ecf20Sopenharmony_ci/* eth initialization functions */ 338c2ecf20Sopenharmony_cistatic struct smc91x_platdata smc91x_info = { 348c2ecf20Sopenharmony_ci .flags = SMC91X_USE_16BIT | SMC91X_IO_SHIFT_1 | IORESOURCE_IRQ_LOWLEVEL, 358c2ecf20Sopenharmony_ci}; 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_cistatic struct resource smc91x_res[] = { 388c2ecf20Sopenharmony_ci [0] = { 398c2ecf20Sopenharmony_ci .start = SMC_IOADDR, 408c2ecf20Sopenharmony_ci .end = SMC_IOADDR + SZ_32 - 1, 418c2ecf20Sopenharmony_ci .flags = IORESOURCE_MEM, 428c2ecf20Sopenharmony_ci }, 438c2ecf20Sopenharmony_ci [1] = { 448c2ecf20Sopenharmony_ci .start = ETHERNET_IRQ, 458c2ecf20Sopenharmony_ci .end = ETHERNET_IRQ, 468c2ecf20Sopenharmony_ci .flags = IORESOURCE_IRQ , 478c2ecf20Sopenharmony_ci } 488c2ecf20Sopenharmony_ci}; 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_cistatic struct platform_device smc91x_dev = { 518c2ecf20Sopenharmony_ci .name = "smc91x", 528c2ecf20Sopenharmony_ci .id = -1, 538c2ecf20Sopenharmony_ci .num_resources = ARRAY_SIZE(smc91x_res), 548c2ecf20Sopenharmony_ci .resource = smc91x_res, 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_ci .dev = { 578c2ecf20Sopenharmony_ci .platform_data = &smc91x_info, 588c2ecf20Sopenharmony_ci }, 598c2ecf20Sopenharmony_ci}; 608c2ecf20Sopenharmony_ci 618c2ecf20Sopenharmony_ci/* platform init code */ 628c2ecf20Sopenharmony_cistatic struct platform_device *edosk7705_devices[] __initdata = { 638c2ecf20Sopenharmony_ci &smc91x_dev, 648c2ecf20Sopenharmony_ci}; 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_cistatic int __init init_edosk7705_devices(void) 678c2ecf20Sopenharmony_ci{ 688c2ecf20Sopenharmony_ci return platform_add_devices(edosk7705_devices, 698c2ecf20Sopenharmony_ci ARRAY_SIZE(edosk7705_devices)); 708c2ecf20Sopenharmony_ci} 718c2ecf20Sopenharmony_cidevice_initcall(init_edosk7705_devices); 728c2ecf20Sopenharmony_ci 738c2ecf20Sopenharmony_ci/* 748c2ecf20Sopenharmony_ci * The Machine Vector 758c2ecf20Sopenharmony_ci */ 768c2ecf20Sopenharmony_cistatic struct sh_machine_vector mv_edosk7705 __initmv = { 778c2ecf20Sopenharmony_ci .mv_name = "EDOSK7705", 788c2ecf20Sopenharmony_ci .mv_init_irq = sh_edosk7705_init_irq, 798c2ecf20Sopenharmony_ci}; 80