diff options
Diffstat (limited to 'arch/powerpc/platforms')
-rw-r--r-- | arch/powerpc/platforms/chrp/pegasos_eth.c | 72 |
1 files changed, 17 insertions, 55 deletions
diff --git a/arch/powerpc/platforms/chrp/pegasos_eth.c b/arch/powerpc/platforms/chrp/pegasos_eth.c index 130ff72d99dd..039fc8e82199 100644 --- a/arch/powerpc/platforms/chrp/pegasos_eth.c +++ b/arch/powerpc/platforms/chrp/pegasos_eth.c | |||
@@ -21,8 +21,8 @@ | |||
21 | #define PEGASOS2_SRAM_BASE (0xf2000000) | 21 | #define PEGASOS2_SRAM_BASE (0xf2000000) |
22 | #define PEGASOS2_SRAM_SIZE (256*1024) | 22 | #define PEGASOS2_SRAM_SIZE (256*1024) |
23 | 23 | ||
24 | #define PEGASOS2_SRAM_BASE_ETH0 (PEGASOS2_SRAM_BASE) | 24 | #define PEGASOS2_SRAM_BASE_ETH_PORT0 (PEGASOS2_SRAM_BASE) |
25 | #define PEGASOS2_SRAM_BASE_ETH1 (PEGASOS2_SRAM_BASE_ETH0 + (PEGASOS2_SRAM_SIZE / 2) ) | 25 | #define PEGASOS2_SRAM_BASE_ETH_PORT1 (PEGASOS2_SRAM_BASE_ETH_PORT0 + (PEGASOS2_SRAM_SIZE / 2) ) |
26 | 26 | ||
27 | 27 | ||
28 | #define PEGASOS2_SRAM_RXRING_SIZE (PEGASOS2_SRAM_SIZE/4) | 28 | #define PEGASOS2_SRAM_RXRING_SIZE (PEGASOS2_SRAM_SIZE/4) |
@@ -47,75 +47,42 @@ static struct platform_device mv643xx_eth_shared_device = { | |||
47 | .resource = mv643xx_eth_shared_resources, | 47 | .resource = mv643xx_eth_shared_resources, |
48 | }; | 48 | }; |
49 | 49 | ||
50 | static struct resource mv643xx_eth0_resources[] = { | 50 | static struct resource mv643xx_eth_port1_resources[] = { |
51 | [0] = { | 51 | [0] = { |
52 | .name = "eth0 irq", | 52 | .name = "eth port1 irq", |
53 | .start = 9, | 53 | .start = 9, |
54 | .end = 9, | 54 | .end = 9, |
55 | .flags = IORESOURCE_IRQ, | 55 | .flags = IORESOURCE_IRQ, |
56 | }, | 56 | }, |
57 | }; | 57 | }; |
58 | 58 | ||
59 | 59 | static struct mv643xx_eth_platform_data eth_port1_pd = { | |
60 | static struct mv643xx_eth_platform_data eth0_pd = { | ||
61 | .shared = &mv643xx_eth_shared_device, | ||
62 | .port_number = 0, | ||
63 | |||
64 | .tx_sram_addr = PEGASOS2_SRAM_BASE_ETH0, | ||
65 | .tx_sram_size = PEGASOS2_SRAM_TXRING_SIZE, | ||
66 | .tx_queue_size = PEGASOS2_SRAM_TXRING_SIZE/16, | ||
67 | |||
68 | .rx_sram_addr = PEGASOS2_SRAM_BASE_ETH0 + PEGASOS2_SRAM_TXRING_SIZE, | ||
69 | .rx_sram_size = PEGASOS2_SRAM_RXRING_SIZE, | ||
70 | .rx_queue_size = PEGASOS2_SRAM_RXRING_SIZE/16, | ||
71 | }; | ||
72 | |||
73 | static struct platform_device eth0_device = { | ||
74 | .name = MV643XX_ETH_NAME, | ||
75 | .id = 0, | ||
76 | .num_resources = ARRAY_SIZE(mv643xx_eth0_resources), | ||
77 | .resource = mv643xx_eth0_resources, | ||
78 | .dev = { | ||
79 | .platform_data = ð0_pd, | ||
80 | }, | ||
81 | }; | ||
82 | |||
83 | static struct resource mv643xx_eth1_resources[] = { | ||
84 | [0] = { | ||
85 | .name = "eth1 irq", | ||
86 | .start = 9, | ||
87 | .end = 9, | ||
88 | .flags = IORESOURCE_IRQ, | ||
89 | }, | ||
90 | }; | ||
91 | |||
92 | static struct mv643xx_eth_platform_data eth1_pd = { | ||
93 | .shared = &mv643xx_eth_shared_device, | 60 | .shared = &mv643xx_eth_shared_device, |
94 | .port_number = 1, | 61 | .port_number = 1, |
62 | .phy_addr = MV643XX_ETH_PHY_ADDR(7), | ||
95 | 63 | ||
96 | .tx_sram_addr = PEGASOS2_SRAM_BASE_ETH1, | 64 | .tx_sram_addr = PEGASOS2_SRAM_BASE_ETH_PORT1, |
97 | .tx_sram_size = PEGASOS2_SRAM_TXRING_SIZE, | 65 | .tx_sram_size = PEGASOS2_SRAM_TXRING_SIZE, |
98 | .tx_queue_size = PEGASOS2_SRAM_TXRING_SIZE/16, | 66 | .tx_queue_size = PEGASOS2_SRAM_TXRING_SIZE/16, |
99 | 67 | ||
100 | .rx_sram_addr = PEGASOS2_SRAM_BASE_ETH1 + PEGASOS2_SRAM_TXRING_SIZE, | 68 | .rx_sram_addr = PEGASOS2_SRAM_BASE_ETH_PORT1 + PEGASOS2_SRAM_TXRING_SIZE, |
101 | .rx_sram_size = PEGASOS2_SRAM_RXRING_SIZE, | 69 | .rx_sram_size = PEGASOS2_SRAM_RXRING_SIZE, |
102 | .rx_queue_size = PEGASOS2_SRAM_RXRING_SIZE/16, | 70 | .rx_queue_size = PEGASOS2_SRAM_RXRING_SIZE/16, |
103 | }; | 71 | }; |
104 | 72 | ||
105 | static struct platform_device eth1_device = { | 73 | static struct platform_device eth_port1_device = { |
106 | .name = MV643XX_ETH_NAME, | 74 | .name = MV643XX_ETH_NAME, |
107 | .id = 1, | 75 | .id = 1, |
108 | .num_resources = ARRAY_SIZE(mv643xx_eth1_resources), | 76 | .num_resources = ARRAY_SIZE(mv643xx_eth_port1_resources), |
109 | .resource = mv643xx_eth1_resources, | 77 | .resource = mv643xx_eth_port1_resources, |
110 | .dev = { | 78 | .dev = { |
111 | .platform_data = ð1_pd, | 79 | .platform_data = ð_port1_pd, |
112 | }, | 80 | }, |
113 | }; | 81 | }; |
114 | 82 | ||
115 | static struct platform_device *mv643xx_eth_pd_devs[] __initdata = { | 83 | static struct platform_device *mv643xx_eth_pd_devs[] __initdata = { |
116 | &mv643xx_eth_shared_device, | 84 | &mv643xx_eth_shared_device, |
117 | ð0_device, | 85 | ð_port1_device, |
118 | ð1_device, | ||
119 | }; | 86 | }; |
120 | 87 | ||
121 | /***********/ | 88 | /***********/ |
@@ -191,15 +158,10 @@ static int __init mv643xx_eth_add_pds(void) | |||
191 | 158 | ||
192 | if ( Enable_SRAM() < 0) | 159 | if ( Enable_SRAM() < 0) |
193 | { | 160 | { |
194 | eth0_pd.tx_sram_addr = 0; | 161 | eth_port1_pd.tx_sram_addr = 0; |
195 | eth0_pd.tx_sram_size = 0; | 162 | eth_port1_pd.tx_sram_size = 0; |
196 | eth0_pd.rx_sram_addr = 0; | 163 | eth_port1_pd.rx_sram_addr = 0; |
197 | eth0_pd.rx_sram_size = 0; | 164 | eth_port1_pd.rx_sram_size = 0; |
198 | |||
199 | eth1_pd.tx_sram_addr = 0; | ||
200 | eth1_pd.tx_sram_size = 0; | ||
201 | eth1_pd.rx_sram_addr = 0; | ||
202 | eth1_pd.rx_sram_size = 0; | ||
203 | 165 | ||
204 | #ifdef BE_VERBOSE | 166 | #ifdef BE_VERBOSE |
205 | printk("Pegasos II/Marvell MV64361: Can't enable the " | 167 | printk("Pegasos II/Marvell MV64361: Can't enable the " |