summaryrefslogtreecommitdiff
path: root/drivers/net/designware.c
diff options
context:
space:
mode:
authorSonic Zhang <sonic.zhang@analog.com>2015-01-29 13:37:31 +0800
committerTom Rini <trini@konsulko.com>2015-03-05 11:17:53 -0500
commit2ddaf13bd28d9d9450831e84e30d617d2f49f1bd (patch)
treecfa3b345ceffe65c5859f5c32cd4c7e422383a28 /drivers/net/designware.c
parenta32ab4d910b86c83a6dee557eed68298b7e9b361 (diff)
net: configure DWMAC DMA by default AXI burst length
Board can define its own AXI burst length to improve DWMAC DMA performance. v2-changes: - Avoid write burst len register when the Macro is not defined. v3-changes: - Add axi_bus register member to struct eth_dma_regs. Signed-off-by: Sonic Zhang <sonic.zhang@analog.com> Acked-by: Joe Hershberger <joe.hershberger@ni.com>
Diffstat (limited to 'drivers/net/designware.c')
-rw-r--r--drivers/net/designware.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/net/designware.c b/drivers/net/designware.c
index c03e935e2f..7469e59d49 100644
--- a/drivers/net/designware.c
+++ b/drivers/net/designware.c
@@ -258,6 +258,10 @@ static int dw_eth_init(struct eth_device *dev, bd_t *bis)
writel(readl(&dma_p->opmode) | RXSTART | TXSTART, &dma_p->opmode);
+#ifdef CONFIG_DW_AXI_BURST_LEN
+ writel((CONFIG_DW_AXI_BURST_LEN & 0x1FF >> 1), &dma_p->axibus);
+#endif
+
/* Start up the PHY */
if (phy_startup(priv->phydev)) {
printf("Could not initialize PHY %s\n",