162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * arch/sh/boards/renesas/edosk7705/setup.c 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2000 Kazumoto Kojima 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Hitachi SolutionEngine Support. 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * Modified for edosk7705 development 1062306a36Sopenharmony_ci * board by S. Dunn, 2003. 1162306a36Sopenharmony_ci */ 1262306a36Sopenharmony_ci#include <linux/init.h> 1362306a36Sopenharmony_ci#include <linux/irq.h> 1462306a36Sopenharmony_ci#include <linux/platform_device.h> 1562306a36Sopenharmony_ci#include <linux/interrupt.h> 1662306a36Sopenharmony_ci#include <linux/smc91x.h> 1762306a36Sopenharmony_ci#include <linux/sh_intc.h> 1862306a36Sopenharmony_ci#include <asm/machvec.h> 1962306a36Sopenharmony_ci#include <linux/sizes.h> 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci#define SMC_IOBASE 0xA2000000 2262306a36Sopenharmony_ci#define SMC_IO_OFFSET 0x300 2362306a36Sopenharmony_ci#define SMC_IOADDR (SMC_IOBASE + SMC_IO_OFFSET) 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci#define ETHERNET_IRQ evt2irq(0x320) 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_cistatic void __init sh_edosk7705_init_irq(void) 2862306a36Sopenharmony_ci{ 2962306a36Sopenharmony_ci make_imask_irq(ETHERNET_IRQ); 3062306a36Sopenharmony_ci} 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ci/* eth initialization functions */ 3362306a36Sopenharmony_cistatic struct smc91x_platdata smc91x_info = { 3462306a36Sopenharmony_ci .flags = SMC91X_USE_16BIT | SMC91X_IO_SHIFT_1 | IORESOURCE_IRQ_LOWLEVEL, 3562306a36Sopenharmony_ci}; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistatic struct resource smc91x_res[] = { 3862306a36Sopenharmony_ci [0] = { 3962306a36Sopenharmony_ci .start = SMC_IOADDR, 4062306a36Sopenharmony_ci .end = SMC_IOADDR + SZ_32 - 1, 4162306a36Sopenharmony_ci .flags = IORESOURCE_MEM, 4262306a36Sopenharmony_ci }, 4362306a36Sopenharmony_ci [1] = { 4462306a36Sopenharmony_ci .start = ETHERNET_IRQ, 4562306a36Sopenharmony_ci .end = ETHERNET_IRQ, 4662306a36Sopenharmony_ci .flags = IORESOURCE_IRQ , 4762306a36Sopenharmony_ci } 4862306a36Sopenharmony_ci}; 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_cistatic struct platform_device smc91x_dev = { 5162306a36Sopenharmony_ci .name = "smc91x", 5262306a36Sopenharmony_ci .id = -1, 5362306a36Sopenharmony_ci .num_resources = ARRAY_SIZE(smc91x_res), 5462306a36Sopenharmony_ci .resource = smc91x_res, 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci .dev = { 5762306a36Sopenharmony_ci .platform_data = &smc91x_info, 5862306a36Sopenharmony_ci }, 5962306a36Sopenharmony_ci}; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci/* platform init code */ 6262306a36Sopenharmony_cistatic struct platform_device *edosk7705_devices[] __initdata = { 6362306a36Sopenharmony_ci &smc91x_dev, 6462306a36Sopenharmony_ci}; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_cistatic int __init init_edosk7705_devices(void) 6762306a36Sopenharmony_ci{ 6862306a36Sopenharmony_ci return platform_add_devices(edosk7705_devices, 6962306a36Sopenharmony_ci ARRAY_SIZE(edosk7705_devices)); 7062306a36Sopenharmony_ci} 7162306a36Sopenharmony_cidevice_initcall(init_edosk7705_devices); 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ci/* 7462306a36Sopenharmony_ci * The Machine Vector 7562306a36Sopenharmony_ci */ 7662306a36Sopenharmony_cistatic struct sh_machine_vector mv_edosk7705 __initmv = { 7762306a36Sopenharmony_ci .mv_name = "EDOSK7705", 7862306a36Sopenharmony_ci .mv_init_irq = sh_edosk7705_init_irq, 7962306a36Sopenharmony_ci}; 80