diff options
author | John Linn <john.linn@xilinx.com> | 2010-04-08 03:08:02 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-04-13 04:33:44 -0400 |
commit | e44171f115de3dedf34064646206deb91549865f (patch) | |
tree | 94e7be7a6f9bbc6341a6915a12744ed451dcb75f /drivers/net/ll_temac.h | |
parent | 33646d7ff5f47225cbbf3a06597ded649bf34e8d (diff) |
Add non-Virtex5 support for LL TEMAC driver
This patch adds support for using the LL TEMAC Ethernet driver on
non-Virtex 5 platforms by adding support for accessing the Soft DMA
registers as if they were memory mapped instead of solely through the
DCR's (available on the Virtex 5).
The patch also updates the driver so that it runs on the MicroBlaze.
The changes were tested on the PowerPC 440, PowerPC 405, and the
MicroBlaze platforms.
Signed-off-by: John Tyner <jtyner@cs.ucr.edu>
Signed-off-by: John Linn <john.linn@xilinx.com>
Acked-by: Grant Likely <grant.likely@secretlab.ca>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ll_temac.h')
-rw-r--r-- | drivers/net/ll_temac.h | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/drivers/net/ll_temac.h b/drivers/net/ll_temac.h index 1af66a1e691..c03358434ac 100644 --- a/drivers/net/ll_temac.h +++ b/drivers/net/ll_temac.h | |||
@@ -5,8 +5,11 @@ | |||
5 | #include <linux/netdevice.h> | 5 | #include <linux/netdevice.h> |
6 | #include <linux/of.h> | 6 | #include <linux/of.h> |
7 | #include <linux/spinlock.h> | 7 | #include <linux/spinlock.h> |
8 | |||
9 | #ifdef CONFIG_PPC_DCR | ||
8 | #include <asm/dcr.h> | 10 | #include <asm/dcr.h> |
9 | #include <asm/dcr-regs.h> | 11 | #include <asm/dcr-regs.h> |
12 | #endif | ||
10 | 13 | ||
11 | /* packet size info */ | 14 | /* packet size info */ |
12 | #define XTE_HDR_SIZE 14 /* size of Ethernet header */ | 15 | #define XTE_HDR_SIZE 14 /* size of Ethernet header */ |
@@ -290,9 +293,6 @@ This option defaults to enabled (set) */ | |||
290 | 293 | ||
291 | #define TX_CONTROL_CALC_CSUM_MASK 1 | 294 | #define TX_CONTROL_CALC_CSUM_MASK 1 |
292 | 295 | ||
293 | #define XTE_ALIGN 32 | ||
294 | #define BUFFER_ALIGN(adr) ((XTE_ALIGN - ((u32) adr)) % XTE_ALIGN) | ||
295 | |||
296 | #define MULTICAST_CAM_TABLE_NUM 4 | 296 | #define MULTICAST_CAM_TABLE_NUM 4 |
297 | 297 | ||
298 | /* TX/RX CURDESC_PTR points to first descriptor */ | 298 | /* TX/RX CURDESC_PTR points to first descriptor */ |
@@ -335,9 +335,15 @@ struct temac_local { | |||
335 | struct mii_bus *mii_bus; /* MII bus reference */ | 335 | struct mii_bus *mii_bus; /* MII bus reference */ |
336 | int mdio_irqs[PHY_MAX_ADDR]; /* IRQs table for MDIO bus */ | 336 | int mdio_irqs[PHY_MAX_ADDR]; /* IRQs table for MDIO bus */ |
337 | 337 | ||
338 | /* IO registers and IRQs */ | 338 | /* IO registers, dma functions and IRQs */ |
339 | void __iomem *regs; | 339 | void __iomem *regs; |
340 | void __iomem *sdma_regs; | ||
341 | #ifdef CONFIG_PPC_DCR | ||
340 | dcr_host_t sdma_dcrs; | 342 | dcr_host_t sdma_dcrs; |
343 | #endif | ||
344 | u32 (*dma_in)(struct temac_local *, int); | ||
345 | void (*dma_out)(struct temac_local *, int, u32); | ||
346 | |||
341 | int tx_irq; | 347 | int tx_irq; |
342 | int rx_irq; | 348 | int rx_irq; |
343 | int emac_num; | 349 | int emac_num; |