1 --- a/arch/arm/mach-gemini/common.h
2 +++ b/arch/arm/mach-gemini/common.h
4 #include <linux/reboot.h>
7 +struct gemini_gmac_platform_data;
9 extern void gemini_map_io(void);
10 extern void gemini_init_irq(void);
11 @@ -28,6 +29,7 @@ extern int platform_register_pflash(unsi
12 struct mtd_partition *parts,
13 unsigned int nr_parts);
14 extern int platform_register_watchdog(void);
15 +extern int platform_register_ethernet(struct gemini_gmac_platform_data *pdata);
17 extern void gemini_restart(enum reboot_mode mode, const char *cmd);
19 --- a/arch/arm/mach-gemini/devices.c
20 +++ b/arch/arm/mach-gemini/devices.c
22 #include <mach/irqs.h>
23 #include <mach/hardware.h>
24 #include <mach/global_reg.h>
25 +#include <mach/gmac.h>
27 static struct plat_serial8250_port serial_platform_data[] = {
29 @@ -133,3 +134,56 @@ int __init platform_register_watchdog(vo
31 return platform_device_register(&wdt_device);
34 +static struct resource gmac_resources[] = {
36 + .start = GEMINI_TOE_BASE,
37 + .end = GEMINI_TOE_BASE + 0xffff,
38 + .flags = IORESOURCE_MEM,
43 + .flags = IORESOURCE_IRQ,
48 + .flags = IORESOURCE_IRQ,
52 +static u64 gmac_dmamask = 0xffffffffUL;
54 +static struct platform_device ethernet_device = {
55 + .name = "gmac-gemini",
58 + .dma_mask = &gmac_dmamask,
59 + .coherent_dma_mask = 0xffffffff,
61 + .num_resources = ARRAY_SIZE(gmac_resources),
62 + .resource = gmac_resources,
65 +int platform_register_ethernet(struct gemini_gmac_platform_data *pdata)
69 + reg = readl((void __iomem*)(IO_ADDRESS(GEMINI_GLOBAL_BASE) +
72 + reg &= ~(GMAC_GMII | GMAC_1_ENABLE);
74 + if (pdata->bus_id[1])
75 + reg |= GMAC_1_ENABLE;
76 + else if (pdata->interface[0] == PHY_INTERFACE_MODE_GMII)
79 + writel(reg, (void __iomem*)(IO_ADDRESS(GEMINI_GLOBAL_BASE) +
82 + ethernet_device.dev.platform_data = pdata;
84 + return platform_device_register(ðernet_device);