diff options
| author | Lennert Buytenhek <buytenh@org.rmk.(none)> | 2006-09-29 16:17:36 -0400 |
|---|---|---|
| committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2006-09-30 06:30:45 -0400 |
| commit | 730ee9f3594d8bcedb981dd184f310899fc931c6 (patch) | |
| tree | ef2fca48cf2022971bd95a3cb253294253206cfc | |
| parent | 2552fc27ff79b10b9678d92bcaef21df38bb7bb6 (diff) | |
[ARM] 3879/1: ep93xx: instantiate platform devices for ep93xx ethernet
Instantiate platform devices for the ep93xx ethernet driver in a
couple of ep93xx board support files.
Signed-off-by: Lennert Buytenhek <buytenh@wantstofly.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
| -rw-r--r-- | arch/arm/mach-ep93xx/edb9315a.c | 30 | ||||
| -rw-r--r-- | arch/arm/mach-ep93xx/gesbc9312.c | 27 | ||||
| -rw-r--r-- | arch/arm/mach-ep93xx/ts72xx.c | 30 |
3 files changed, 87 insertions, 0 deletions
diff --git a/arch/arm/mach-ep93xx/edb9315a.c b/arch/arm/mach-ep93xx/edb9315a.c index bfefdaa8f794..fa958e9d6ddd 100644 --- a/arch/arm/mach-ep93xx/edb9315a.c +++ b/arch/arm/mach-ep93xx/edb9315a.c | |||
| @@ -44,10 +44,40 @@ static struct platform_device edb9315a_flash = { | |||
| 44 | .resource = &edb9315a_flash_resource, | 44 | .resource = &edb9315a_flash_resource, |
| 45 | }; | 45 | }; |
| 46 | 46 | ||
| 47 | static struct ep93xx_eth_data edb9315a_eth_data = { | ||
| 48 | .phy_id = 1, | ||
| 49 | }; | ||
| 50 | |||
| 51 | static struct resource edb9315a_eth_resource[] = { | ||
| 52 | { | ||
| 53 | .start = EP93XX_ETHERNET_PHYS_BASE, | ||
| 54 | .end = EP93XX_ETHERNET_PHYS_BASE + 0xffff, | ||
| 55 | .flags = IORESOURCE_MEM, | ||
| 56 | }, { | ||
| 57 | .start = IRQ_EP93XX_ETHERNET, | ||
| 58 | .end = IRQ_EP93XX_ETHERNET, | ||
| 59 | .flags = IORESOURCE_IRQ, | ||
| 60 | } | ||
| 61 | }; | ||
| 62 | |||
| 63 | static struct platform_device edb9315a_eth_device = { | ||
| 64 | .name = "ep93xx-eth", | ||
| 65 | .id = -1, | ||
| 66 | .dev = { | ||
| 67 | .platform_data = &edb9315a_eth_data, | ||
| 68 | }, | ||
| 69 | .num_resources = 2, | ||
| 70 | .resource = edb9315a_eth_resource, | ||
| 71 | }; | ||
| 72 | |||
| 47 | static void __init edb9315a_init_machine(void) | 73 | static void __init edb9315a_init_machine(void) |
| 48 | { | 74 | { |
| 49 | ep93xx_init_devices(); | 75 | ep93xx_init_devices(); |
| 50 | platform_device_register(&edb9315a_flash); | 76 | platform_device_register(&edb9315a_flash); |
| 77 | |||
| 78 | memcpy(edb9315a_eth_data.dev_addr, | ||
| 79 | (void *)(EP93XX_ETHERNET_BASE + 0x50), 6); | ||
| 80 | platform_device_register(&edb9315a_eth_device); | ||
| 51 | } | 81 | } |
| 52 | 82 | ||
| 53 | MACHINE_START(EDB9315A, "Cirrus Logic EDB9315A Evaluation Board") | 83 | MACHINE_START(EDB9315A, "Cirrus Logic EDB9315A Evaluation Board") |
diff --git a/arch/arm/mach-ep93xx/gesbc9312.c b/arch/arm/mach-ep93xx/gesbc9312.c index e760fd4f3655..694590a451c1 100644 --- a/arch/arm/mach-ep93xx/gesbc9312.c +++ b/arch/arm/mach-ep93xx/gesbc9312.c | |||
| @@ -43,10 +43,37 @@ static struct platform_device gesbc9312_flash = { | |||
| 43 | .resource = &gesbc9312_flash_resource, | 43 | .resource = &gesbc9312_flash_resource, |
| 44 | }; | 44 | }; |
| 45 | 45 | ||
| 46 | static struct ep93xx_eth_data gesbc9312_eth_data = { | ||
| 47 | .phy_id = 1, | ||
| 48 | }; | ||
| 49 | |||
| 50 | static struct resource gesbc9312_eth_resource[] = { | ||
| 51 | { | ||
| 52 | .start = EP93XX_ETHERNET_PHYS_BASE, | ||
| 53 | .end = EP93XX_ETHERNET_PHYS_BASE + 0xffff, | ||
| 54 | .flags = IORESOURCE_MEM, | ||
| 55 | }, { | ||
| 56 | .start = IRQ_EP93XX_ETHERNET, | ||
| 57 | .end = IRQ_EP93XX_ETHERNET, | ||
| 58 | .flags = IORESOURCE_IRQ, | ||
| 59 | } | ||
| 60 | }; | ||
| 61 | |||
| 62 | static struct platform_device gesbc9312_eth_device = { | ||
| 63 | .name = "ep93xx-eth", | ||
| 64 | .id = -1, | ||
| 65 | .dev = { | ||
| 66 | .platform_data = &gesbc9312_eth_data, | ||
| 67 | }, | ||
| 68 | .num_resources = 2, | ||
| 69 | .resource = gesbc9312_eth_resource, | ||
| 70 | }; | ||
| 71 | |||
| 46 | static void __init gesbc9312_init_machine(void) | 72 | static void __init gesbc9312_init_machine(void) |
| 47 | { | 73 | { |
| 48 | ep93xx_init_devices(); | 74 | ep93xx_init_devices(); |
| 49 | platform_device_register(&gesbc9312_flash); | 75 | platform_device_register(&gesbc9312_flash); |
| 76 | platform_device_register(&gesbc9312_eth_device); | ||
| 50 | } | 77 | } |
| 51 | 78 | ||
| 52 | MACHINE_START(GESBC9312, "Glomation GESBC-9312-sx") | 79 | MACHINE_START(GESBC9312, "Glomation GESBC-9312-sx") |
diff --git a/arch/arm/mach-ep93xx/ts72xx.c b/arch/arm/mach-ep93xx/ts72xx.c index df315f2e9beb..3a4bf90ba832 100644 --- a/arch/arm/mach-ep93xx/ts72xx.c +++ b/arch/arm/mach-ep93xx/ts72xx.c | |||
| @@ -157,12 +157,42 @@ static struct platform_device ts72xx_rtc_device = { | |||
| 157 | .num_resources = 0, | 157 | .num_resources = 0, |
| 158 | }; | 158 | }; |
| 159 | 159 | ||
| 160 | static struct ep93xx_eth_data ts72xx_eth_data = { | ||
| 161 | .phy_id = 1, | ||
| 162 | }; | ||
| 163 | |||
| 164 | static struct resource ts72xx_eth_resource[] = { | ||
| 165 | { | ||
| 166 | .start = EP93XX_ETHERNET_PHYS_BASE, | ||
| 167 | .end = EP93XX_ETHERNET_PHYS_BASE + 0xffff, | ||
| 168 | .flags = IORESOURCE_MEM, | ||
| 169 | }, { | ||
| 170 | .start = IRQ_EP93XX_ETHERNET, | ||
| 171 | .end = IRQ_EP93XX_ETHERNET, | ||
| 172 | .flags = IORESOURCE_IRQ, | ||
| 173 | } | ||
| 174 | }; | ||
| 175 | |||
| 176 | static struct platform_device ts72xx_eth_device = { | ||
| 177 | .name = "ep93xx-eth", | ||
| 178 | .id = -1, | ||
| 179 | .dev = { | ||
| 180 | .platform_data = &ts72xx_eth_data, | ||
| 181 | }, | ||
| 182 | .num_resources = 2, | ||
| 183 | .resource = ts72xx_eth_resource, | ||
| 184 | }; | ||
| 185 | |||
| 160 | static void __init ts72xx_init_machine(void) | 186 | static void __init ts72xx_init_machine(void) |
| 161 | { | 187 | { |
| 162 | ep93xx_init_devices(); | 188 | ep93xx_init_devices(); |
| 163 | if (board_is_ts7200()) | 189 | if (board_is_ts7200()) |
| 164 | platform_device_register(&ts72xx_flash); | 190 | platform_device_register(&ts72xx_flash); |
| 165 | platform_device_register(&ts72xx_rtc_device); | 191 | platform_device_register(&ts72xx_rtc_device); |
| 192 | |||
| 193 | memcpy(ts72xx_eth_data.dev_addr, | ||
| 194 | (void *)(EP93XX_ETHERNET_BASE + 0x50), 6); | ||
| 195 | platform_device_register(&ts72xx_eth_device); | ||
| 166 | } | 196 | } |
| 167 | 197 | ||
| 168 | MACHINE_START(TS72XX, "Technologic Systems TS-72xx SBC") | 198 | MACHINE_START(TS72XX, "Technologic Systems TS-72xx SBC") |
