From 100078e1754797ef883f502810917027fcd858b1 Mon Sep 17 00:00:00 2001 From: Kuninori Morimoto Date: Thu, 10 Nov 2011 18:47:36 -0800 Subject: [PATCH] --- yaml --- r: 283626 b: refs/heads/master c: 8900df7add8a4c197f0f9d7e8dc0d41847ba5eeb h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/arch/arm/mach-shmobile/board-bonito.c | 33 +++++++++++++++++++++ 2 files changed, 34 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 1987d8feaee9..5cb8a5fdb13c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 6bf2805dac7cd6c70e678e0f4852c67000c7fc21 +refs/heads/master: 8900df7add8a4c197f0f9d7e8dc0d41847ba5eeb diff --git a/trunk/arch/arm/mach-shmobile/board-bonito.c b/trunk/arch/arm/mach-shmobile/board-bonito.c index fe749e354626..4d2201622323 100644 --- a/trunk/arch/arm/mach-shmobile/board-bonito.c +++ b/trunk/arch/arm/mach-shmobile/board-bonito.c @@ -95,6 +95,7 @@ #define FPGA_IRQ_BASE (512) #define FPGA_IRQ0 (FPGA_IRQ_BASE) #define FPGA_IRQ1 (FPGA_IRQ_BASE + 16) +#define FPGA_ETH_IRQ (FPGA_IRQ0 + 15) static u16 bonito_fpga_read(u32 offset) { return __raw_readw(0xf0003000 + offset); @@ -277,6 +278,37 @@ static struct platform_device lcdc0_device = { }, }; +/* + * SMSC 9221 + */ +static struct resource smsc_resources[] = { + [0] = { + .start = 0x18010000, + .end = 0x18011000 - 1, + .flags = IORESOURCE_MEM, + }, + [1] = { + .start = FPGA_ETH_IRQ, + .flags = IORESOURCE_IRQ, + }, +}; + +static struct smsc911x_platform_config smsc_platdata = { + .flags = SMSC911X_USE_16BIT, + .phy_interface = PHY_INTERFACE_MODE_MII, + .irq_polarity = SMSC911X_IRQ_POLARITY_ACTIVE_LOW, + .irq_type = SMSC911X_IRQ_TYPE_PUSH_PULL, +}; + +static struct platform_device smsc_device = { + .name = "smsc911x", + .dev = { + .platform_data = &smsc_platdata, + }, + .resource = smsc_resources, + .num_resources = ARRAY_SIZE(smsc_resources), +}; + /* * core board devices */ @@ -288,6 +320,7 @@ static struct platform_device *bonito_core_devices[] __initdata = { */ static struct platform_device *bonito_base_devices[] __initdata = { &lcdc0_device, + &smsc_device, }; /*