diff options
Diffstat (limited to 'arch/arm/mach-ep93xx')
-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") |