diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/arm/etherh.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/drivers/net/arm/etherh.c b/drivers/net/arm/etherh.c index 942a2819576c..2e28c201dcc0 100644 --- a/drivers/net/arm/etherh.c +++ b/drivers/net/arm/etherh.c | |||
@@ -68,6 +68,7 @@ struct etherh_priv { | |||
68 | void __iomem *dma_base; | 68 | void __iomem *dma_base; |
69 | unsigned int id; | 69 | unsigned int id; |
70 | void __iomem *ctrl_port; | 70 | void __iomem *ctrl_port; |
71 | void __iomem *base; | ||
71 | unsigned char ctrl; | 72 | unsigned char ctrl; |
72 | u32 supported; | 73 | u32 supported; |
73 | }; | 74 | }; |
@@ -177,7 +178,7 @@ etherh_setif(struct net_device *dev) | |||
177 | switch (etherh_priv(dev)->id) { | 178 | switch (etherh_priv(dev)->id) { |
178 | case PROD_I3_ETHERLAN600: | 179 | case PROD_I3_ETHERLAN600: |
179 | case PROD_I3_ETHERLAN600A: | 180 | case PROD_I3_ETHERLAN600A: |
180 | addr = (void *)dev->base_addr + EN0_RCNTHI; | 181 | addr = etherh_priv(dev)->base + EN0_RCNTHI; |
181 | 182 | ||
182 | switch (dev->if_port) { | 183 | switch (dev->if_port) { |
183 | case IF_PORT_10BASE2: | 184 | case IF_PORT_10BASE2: |
@@ -218,7 +219,7 @@ etherh_getifstat(struct net_device *dev) | |||
218 | switch (etherh_priv(dev)->id) { | 219 | switch (etherh_priv(dev)->id) { |
219 | case PROD_I3_ETHERLAN600: | 220 | case PROD_I3_ETHERLAN600: |
220 | case PROD_I3_ETHERLAN600A: | 221 | case PROD_I3_ETHERLAN600A: |
221 | addr = (void *)dev->base_addr + EN0_RCNTHI; | 222 | addr = etherh_priv(dev)->base + EN0_RCNTHI; |
222 | switch (dev->if_port) { | 223 | switch (dev->if_port) { |
223 | case IF_PORT_10BASE2: | 224 | case IF_PORT_10BASE2: |
224 | stat = 1; | 225 | stat = 1; |
@@ -281,7 +282,7 @@ static void | |||
281 | etherh_reset(struct net_device *dev) | 282 | etherh_reset(struct net_device *dev) |
282 | { | 283 | { |
283 | struct ei_device *ei_local = netdev_priv(dev); | 284 | struct ei_device *ei_local = netdev_priv(dev); |
284 | void __iomem *addr = (void *)dev->base_addr; | 285 | void __iomem *addr = etherh_priv(dev)->base; |
285 | 286 | ||
286 | writeb(E8390_NODMA+E8390_PAGE0+E8390_STOP, addr); | 287 | writeb(E8390_NODMA+E8390_PAGE0+E8390_STOP, addr); |
287 | 288 | ||
@@ -327,7 +328,7 @@ etherh_block_output (struct net_device *dev, int count, const unsigned char *buf | |||
327 | 328 | ||
328 | ei_local->dmaing = 1; | 329 | ei_local->dmaing = 1; |
329 | 330 | ||
330 | addr = (void *)dev->base_addr; | 331 | addr = etherh_priv(dev)->base; |
331 | dma_base = etherh_priv(dev)->dma_base; | 332 | dma_base = etherh_priv(dev)->dma_base; |
332 | 333 | ||
333 | count = (count + 1) & ~1; | 334 | count = (count + 1) & ~1; |
@@ -387,7 +388,7 @@ etherh_block_input (struct net_device *dev, int count, struct sk_buff *skb, int | |||
387 | 388 | ||
388 | ei_local->dmaing = 1; | 389 | ei_local->dmaing = 1; |
389 | 390 | ||
390 | addr = (void *)dev->base_addr; | 391 | addr = etherh_priv(dev)->base; |
391 | dma_base = etherh_priv(dev)->dma_base; | 392 | dma_base = etherh_priv(dev)->dma_base; |
392 | 393 | ||
393 | buf = skb->data; | 394 | buf = skb->data; |
@@ -427,7 +428,7 @@ etherh_get_header (struct net_device *dev, struct e8390_pkt_hdr *hdr, int ring_p | |||
427 | 428 | ||
428 | ei_local->dmaing = 1; | 429 | ei_local->dmaing = 1; |
429 | 430 | ||
430 | addr = (void *)dev->base_addr; | 431 | addr = etherh_priv(dev)->base; |
431 | dma_base = etherh_priv(dev)->dma_base; | 432 | dma_base = etherh_priv(dev)->dma_base; |
432 | 433 | ||
433 | writeb (E8390_NODMA | E8390_PAGE0 | E8390_START, addr + E8390_CMD); | 434 | writeb (E8390_NODMA | E8390_PAGE0 | E8390_START, addr + E8390_CMD); |
@@ -696,7 +697,8 @@ etherh_probe(struct expansion_card *ec, const struct ecard_id *id) | |||
696 | eh->ctrl_port = eh->ioc_fast; | 697 | eh->ctrl_port = eh->ioc_fast; |
697 | } | 698 | } |
698 | 699 | ||
699 | dev->base_addr = (unsigned long)eh->memc + data->ns8390_offset; | 700 | eh->base = eh->memc + data->ns8390_offset; |
701 | dev->base_addr = (unsigned long)eh->base; | ||
700 | eh->dma_base = eh->memc + data->dataport_offset; | 702 | eh->dma_base = eh->memc + data->dataport_offset; |
701 | eh->ctrl_port += data->ctrlport_offset; | 703 | eh->ctrl_port += data->ctrlport_offset; |
702 | 704 | ||