| // SPDX-License-Identifier: GPL-2.0 |
| /* |
| * arch/sh/boards/renesas/edosk7705/setup.c |
| * |
| * Copyright (C) 2000 Kazumoto Kojima |
| * |
| * Hitachi SolutionEngine Support. |
| * |
| * Modified for edosk7705 development |
| * board by S. Dunn, 2003. |
| */ |
| #include <linux/init.h> |
| #include <linux/irq.h> |
| #include <linux/platform_device.h> |
| #include <linux/interrupt.h> |
| #include <linux/smc91x.h> |
| #include <linux/sh_intc.h> |
| #include <asm/machvec.h> |
| #include <linux/sizes.h> |
| |
| #define SMC_IOBASE 0xA2000000 |
| #define SMC_IO_OFFSET 0x300 |
| #define SMC_IOADDR (SMC_IOBASE + SMC_IO_OFFSET) |
| |
| #define ETHERNET_IRQ evt2irq(0x320) |
| |
| static void __init sh_edosk7705_init_irq(void) |
| { |
| make_imask_irq(ETHERNET_IRQ); |
| } |
| |
| /* eth initialization functions */ |
| static struct smc91x_platdata smc91x_info = { |
| .flags = SMC91X_USE_16BIT | SMC91X_IO_SHIFT_1 | IORESOURCE_IRQ_LOWLEVEL, |
| }; |
| |
| static struct resource smc91x_res[] = { |
| [0] = { |
| .start = SMC_IOADDR, |
| .end = SMC_IOADDR + SZ_32 - 1, |
| .flags = IORESOURCE_MEM, |
| }, |
| [1] = { |
| .start = ETHERNET_IRQ, |
| .end = ETHERNET_IRQ, |
| .flags = IORESOURCE_IRQ , |
| } |
| }; |
| |
| static struct platform_device smc91x_dev = { |
| .name = "smc91x", |
| .id = -1, |
| .num_resources = ARRAY_SIZE(smc91x_res), |
| .resource = smc91x_res, |
| |
| .dev = { |
| .platform_data = &smc91x_info, |
| }, |
| }; |
| |
| /* platform init code */ |
| static struct platform_device *edosk7705_devices[] __initdata = { |
| &smc91x_dev, |
| }; |
| |
| static int __init init_edosk7705_devices(void) |
| { |
| return platform_add_devices(edosk7705_devices, |
| ARRAY_SIZE(edosk7705_devices)); |
| } |
| device_initcall(init_edosk7705_devices); |
| |
| /* |
| * The Machine Vector |
| */ |
| static struct sh_machine_vector mv_edosk7705 __initmv = { |
| .mv_name = "EDOSK7705", |
| .mv_init_irq = sh_edosk7705_init_irq, |
| }; |