summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTekkamanV <tekkamanv@starfivetech.com>2020-12-21 20:15:39 +0300
committerTekkaman Ninja <tekkamanninja@163.com>2021-09-29 09:51:22 +0300
commit7b587f7703891d55c4f36876997402964126422e (patch)
treebd6324bcf6a0a27933ab2480635217510c94d887
parent51478b7ab8bdd2ec908f5e1280eaeb0fc37f8dac (diff)
downloadu-boot-7b587f7703891d55c4f36876997402964126422e.tar.xz
starfive: Modify designware driver for JH7100
This patch is using internal RAM to improve performance (avoid flushing L2 cache): Modify designware driver by: 1, Modify gtxclk configuration by phydev->speed 2, Add Preseted mem support for mac descrtables and buffs 3, disable DMA memory range check when building for JH7100 The original patch is from 'Bo Li <bo.li@starfivetech.com>':
-rw-r--r--drivers/net/Kconfig24
-rw-r--r--drivers/net/designware.c71
2 files changed, 82 insertions, 13 deletions
diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig
index d4dc72046c..9b2766d824 100644
--- a/drivers/net/Kconfig
+++ b/drivers/net/Kconfig
@@ -287,6 +287,30 @@ config ETH_DESIGNWARE
100Mbit and 1 Gbit operation. You must enable CONFIG_PHYLIB to
provide the PHY (physical media interface).
+config ETH_DESIGNWARE_PRESETED_BUFF
+ bool "Preseted mem for Synopsys Designware Ethernet MAC"
+ default y if TARGET_STARFIVE_JH7100
+
+if ETH_DESIGNWARE_PRESETED_BUFF
+
+config ETH_DESIGNWARE_PRESETED_TX_MAC_DES_BASE
+ hex "Preseted mem for preseted_tx_mac_descrtable"
+ default 0x18001000
+
+config ETH_DESIGNWARE_PRESETED_RX_MAC_DES_BASE
+ hex "Preseted mem for preseted_rx_mac_descrtable"
+ default 0x18002000
+
+config ETH_DESIGNWARE_PRESETED_TXBUFF_BASE
+ hex "Preseted mem for preseted_txbuffs"
+ default 0x18010000
+
+config ETH_DESIGNWARE_PRESETED_RXBUFF_BASE
+ hex "Preseted mem for preseted_rxbuffs"
+ default 0x18018000
+
+endif #ETH_DESIGNWARE_PRESETED_BUFF
+
config ETH_DESIGNWARE_MESON8B
bool "Amlogic Meson8b and later glue driver for Synopsys Designware Ethernet MAC"
depends on DM_ETH
diff --git a/drivers/net/designware.c b/drivers/net/designware.c
index 5aaac603a0..559288aacc 100644
--- a/drivers/net/designware.c
+++ b/drivers/net/designware.c
@@ -32,6 +32,30 @@
#include <power/regulator.h>
#include "designware.h"
+#if CONFIG_IS_ENABLED(TARGET_STARFIVE_JH7100)
+#include <asm/arch/io.h>
+#include <asm/arch/clkgen_ctrl_macro.h>
+#endif
+
+#if CONFIG_IS_ENABLED(ETH_DESIGNWARE_PRESETED_BUFF)
+#define TX_MAC_DES preseted_tx_mac_descrtable
+#define RX_MAC_DES preseted_rx_mac_descrtable
+#define TX_BUFF preseted_txbuffs
+#define RX_BUFF preseted_rxbuffs
+struct dmamacdescr *preseted_tx_mac_descrtable =
+ (struct dmamacdescr *)CONFIG_ETH_DESIGNWARE_PRESETED_TX_MAC_DES_BASE;
+struct dmamacdescr *preseted_rx_mac_descrtable =
+ (struct dmamacdescr *)CONFIG_ETH_DESIGNWARE_PRESETED_RX_MAC_DES_BASE;
+char *preseted_txbuffs = (char *)CONFIG_ETH_DESIGNWARE_PRESETED_TXBUFF_BASE;
+char *preseted_rxbuffs = (char *)CONFIG_ETH_DESIGNWARE_PRESETED_RXBUFF_BASE;
+#else
+#define TX_MAC_DES priv->tx_mac_descrtable
+#define RX_MAC_DES priv->rx_mac_descrtable
+#define TX_BUFF priv->txbuffs
+#define RX_BUFF priv->rxbuffs
+#endif
+
+
static int dw_mdio_read(struct mii_dev *bus, int addr, int devad, int reg)
{
#ifdef CONFIG_DM_ETH
@@ -232,8 +256,8 @@ static int dw_dm_mdio_init(const char *name, void *priv)
static void tx_descs_init(struct dw_eth_dev *priv)
{
struct eth_dma_regs *dma_p = priv->dma_regs_p;
- struct dmamacdescr *desc_table_p = &priv->tx_mac_descrtable[0];
- char *txbuffs = &priv->txbuffs[0];
+ struct dmamacdescr *desc_table_p = &TX_MAC_DES[0];
+ char *txbuffs = &TX_BUFF[0];
struct dmamacdescr *desc_p;
u32 idx;
@@ -261,9 +285,9 @@ static void tx_descs_init(struct dw_eth_dev *priv)
desc_p->dmamac_next = (ulong)&desc_table_p[0];
/* Flush all Tx buffer descriptors at once */
- flush_dcache_range((ulong)priv->tx_mac_descrtable,
- (ulong)priv->tx_mac_descrtable +
- sizeof(priv->tx_mac_descrtable));
+ flush_dcache_range((ulong)TX_MAC_DES,
+ (ulong)TX_MAC_DES +
+ sizeof(struct dmamacdescr) * CONFIG_TX_DESCR_NUM);
writel((ulong)&desc_table_p[0], &dma_p->txdesclistaddr);
priv->tx_currdescnum = 0;
@@ -272,8 +296,8 @@ static void tx_descs_init(struct dw_eth_dev *priv)
static void rx_descs_init(struct dw_eth_dev *priv)
{
struct eth_dma_regs *dma_p = priv->dma_regs_p;
- struct dmamacdescr *desc_table_p = &priv->rx_mac_descrtable[0];
- char *rxbuffs = &priv->rxbuffs[0];
+ struct dmamacdescr *desc_table_p = &RX_MAC_DES[0];
+ char *rxbuffs = &RX_BUFF[0];
struct dmamacdescr *desc_p;
u32 idx;
@@ -301,9 +325,9 @@ static void rx_descs_init(struct dw_eth_dev *priv)
desc_p->dmamac_next = (ulong)&desc_table_p[0];
/* Flush all Rx buffer descriptors at once */
- flush_dcache_range((ulong)priv->rx_mac_descrtable,
- (ulong)priv->rx_mac_descrtable +
- sizeof(priv->rx_mac_descrtable));
+ flush_dcache_range((ulong)RX_MAC_DES,
+ (ulong)RX_MAC_DES +
+ sizeof(struct dmamacdescr) * CONFIG_RX_DESCR_NUM);
writel((ulong)&desc_table_p[0], &dma_p->rxdesclistaddr);
priv->rx_currdescnum = 0;
@@ -345,6 +369,25 @@ static int dw_adjust_link(struct dw_eth_dev *priv, struct eth_mac_regs *mac_p,
if (phydev->duplex)
conf |= FULLDPLXMODE;
+#if CONFIG_IS_ENABLED(TARGET_STARFIVE_JH7100)
+ switch (phydev->speed) {
+ case 1000:
+ _DIVIDE_CLOCK_clk_gmac_gtxclk_(4);
+ break;
+
+ case 100:
+ _DIVIDE_CLOCK_clk_gmac_gtxclk_(20);
+ break;
+
+ case 10:
+ _DIVIDE_CLOCK_clk_gmac_gtxclk_(200);
+ break;
+
+ default:
+ break;
+ }
+#endif
+
writel(conf, &mac_p->conf);
printf("Speed: %d, %s duplex%s\n", phydev->speed,
@@ -451,7 +494,7 @@ static int _dw_eth_send(struct dw_eth_dev *priv, void *packet, int length)
{
struct eth_dma_regs *dma_p = priv->dma_regs_p;
u32 desc_num = priv->tx_currdescnum;
- struct dmamacdescr *desc_p = &priv->tx_mac_descrtable[desc_num];
+ struct dmamacdescr *desc_p = &TX_MAC_DES[desc_num];
ulong desc_start = (ulong)desc_p;
ulong desc_end = desc_start +
roundup(sizeof(*desc_p), ARCH_DMA_MINALIGN);
@@ -517,7 +560,7 @@ static int _dw_eth_send(struct dw_eth_dev *priv, void *packet, int length)
static int _dw_eth_recv(struct dw_eth_dev *priv, uchar **packetp)
{
u32 status, desc_num = priv->rx_currdescnum;
- struct dmamacdescr *desc_p = &priv->rx_mac_descrtable[desc_num];
+ struct dmamacdescr *desc_p = &RX_MAC_DES[desc_num];
int length = -EAGAIN;
ulong desc_start = (ulong)desc_p;
ulong desc_end = desc_start +
@@ -548,7 +591,7 @@ static int _dw_eth_recv(struct dw_eth_dev *priv, uchar **packetp)
static int _dw_free_pkt(struct dw_eth_dev *priv)
{
u32 desc_num = priv->rx_currdescnum;
- struct dmamacdescr *desc_p = &priv->rx_mac_descrtable[desc_num];
+ struct dmamacdescr *desc_p = &RX_MAC_DES[desc_num];
ulong desc_start = (ulong)desc_p;
ulong desc_end = desc_start +
roundup(sizeof(*desc_p), ARCH_DMA_MINALIGN);
@@ -667,10 +710,12 @@ int designware_initialize(ulong base_addr, u32 interface)
return -ENOMEM;
}
+#if !CONFIG_IS_ENABLED(TARGET_STARFIVE_JH7100)
if ((phys_addr_t)priv + sizeof(*priv) > (1ULL << 32)) {
printf("designware: buffers are outside DMA memory\n");
return -EINVAL;
}
+#endif
memset(dev, 0, sizeof(struct eth_device));
memset(priv, 0, sizeof(struct dw_eth_dev));