mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-18 10:54:37 +00:00
net: Add support for ADI SC5xx SoCs with DWC QoS ethernet
The ADI SC598 includes a Designware QoS 5.20a IP block. This commit adds support for using the existing ethernet QoS driver with the SC598 SoC. Co-developed-by: Ian Roberts <ian.roberts@timesys.com> Signed-off-by: Ian Roberts <ian.roberts@timesys.com> Co-developed-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com> Signed-off-by: Nathan Barrett-Morrison <nathan.morrison@timesys.com> Signed-off-by: Vasileios Bimpikas <vasileios.bimpikas@analog.com> Signed-off-by: Utsav Agarwal <utsav.agarwal@analog.com> Signed-off-by: Arturs Artamonovs <arturs.artamonovs@analog.com> Signed-off-by: Oliver Gaskell <Oliver.Gaskell@analog.com> Signed-off-by: Greg Malysa <malysagreg@gmail.com>
This commit is contained in:
parent
7f99650bb8
commit
df831ebf61
6 changed files with 120 additions and 0 deletions
|
@ -635,6 +635,7 @@ F: drivers/clk/adi/
|
|||
F: drivers/gpio/adp5588_gpio.c
|
||||
F: drivers/gpio/gpio-adi-adsp.c
|
||||
F: drivers/i2c/adi_i2c.c
|
||||
F: drivers/net/dwc_eth_qos_adi.c
|
||||
F: drivers/pinctrl/pinctrl-adi-adsp.c
|
||||
F: drivers/serial/serial_adi_uart4.c
|
||||
F: drivers/timer/adi_sc5xx_timer.c
|
||||
|
|
|
@ -237,6 +237,13 @@ config DWC_ETH_QOS
|
|||
Of Service) IP block. The IP supports many options for bus type,
|
||||
clocking/reset structure, and feature list.
|
||||
|
||||
config DWC_ETH_QOS_ADI
|
||||
bool "Synopsys DWC Ethernet QOS device support for ADI SC59x-64 parts"
|
||||
depends on DWC_ETH_QOS
|
||||
help
|
||||
The Synopsis Designware Ethernet QoS IP block with the specific
|
||||
configuration used in the ADI ADSP-SC59X 64 bit SoCs
|
||||
|
||||
config DWC_ETH_QOS_IMX
|
||||
bool "Synopsys DWC Ethernet QOS device support for IMX"
|
||||
depends on DWC_ETH_QOS
|
||||
|
|
|
@ -19,6 +19,7 @@ obj-$(CONFIG_DM_ETH_PHY) += eth-phy-uclass.o
|
|||
obj-$(CONFIG_DRIVER_DM9000) += dm9000x.o
|
||||
obj-$(CONFIG_DSA_SANDBOX) += dsa_sandbox.o
|
||||
obj-$(CONFIG_DWC_ETH_QOS) += dwc_eth_qos.o
|
||||
obj-$(CONFIG_DWC_ETH_QOS_ADI) += dwc_eth_qos_adi.o
|
||||
obj-$(CONFIG_DWC_ETH_QOS_IMX) += dwc_eth_qos_imx.o
|
||||
obj-$(CONFIG_DWC_ETH_QOS_INTEL) += dwc_eth_qos_intel.o
|
||||
obj-$(CONFIG_DWC_ETH_QOS_ROCKCHIP) += dwc_eth_qos_rockchip.o
|
||||
|
|
|
@ -1631,6 +1631,12 @@ static const struct udevice_id eqos_ids[] = {
|
|||
.compatible = "starfive,jh7110-dwmac",
|
||||
.data = (ulong)&eqos_jh7110_config
|
||||
},
|
||||
#endif
|
||||
#if IS_ENABLED(CONFIG_DWC_ETH_QOS_ADI)
|
||||
{
|
||||
.compatible = "adi,sc59x-dwmac-eqos",
|
||||
.data = (ulong)&eqos_adi_config
|
||||
},
|
||||
#endif
|
||||
{ }
|
||||
};
|
||||
|
|
|
@ -87,6 +87,7 @@ struct eqos_mac_regs {
|
|||
#define EQOS_MAC_MDIO_ADDRESS_CR_MASK GENMASK(11, 8)
|
||||
#define EQOS_MAC_MDIO_ADDRESS_CR_100_150 1
|
||||
#define EQOS_MAC_MDIO_ADDRESS_CR_20_35 2
|
||||
#define EQOS_MAC_MDIO_ADDRESS_CR_150_250 4
|
||||
#define EQOS_MAC_MDIO_ADDRESS_CR_250_300 5
|
||||
#define EQOS_MAC_MDIO_ADDRESS_SKAP BIT(4)
|
||||
#define EQOS_MAC_MDIO_ADDRESS_GOC_MASK GENMASK(3, 2)
|
||||
|
@ -301,3 +302,4 @@ extern struct eqos_config eqos_qcom_config;
|
|||
extern struct eqos_config eqos_stm32mp13_config;
|
||||
extern struct eqos_config eqos_stm32mp15_config;
|
||||
extern struct eqos_config eqos_jh7110_config;
|
||||
extern struct eqos_config eqos_adi_config;
|
||||
|
|
103
drivers/net/dwc_eth_qos_adi.c
Normal file
103
drivers/net/dwc_eth_qos_adi.c
Normal file
|
@ -0,0 +1,103 @@
|
|||
// SPDX-License-Identifier: GPL-2.0
|
||||
/**
|
||||
* (C) Copyright 2024 - Analog Devices, Inc.
|
||||
*
|
||||
* Written and/or maintained by Timesys Corporation
|
||||
*
|
||||
* Author: Greg Malysa <greg.malysa@timesys.com>
|
||||
* Additional Contact: Nathan Barrett-Morrison <nathan.morrison@timesys.com>
|
||||
*/
|
||||
|
||||
#include <clk.h>
|
||||
#include <dm.h>
|
||||
#include <net.h>
|
||||
#include <phy.h>
|
||||
#include <reset.h>
|
||||
#include <linux/io.h>
|
||||
|
||||
#include <asm/arch-adi/sc5xx/sc5xx.h>
|
||||
|
||||
#include "dwc_eth_qos.h"
|
||||
|
||||
static int eqos_start_resets_adi(struct udevice *dev)
|
||||
{
|
||||
struct eqos_priv *eqos = dev_get_priv(dev);
|
||||
|
||||
/*
|
||||
* Settings need to latch with the DMA reset below. Currently only
|
||||
* rgmii is supported but other phy interfaces may be supported in
|
||||
* the future
|
||||
*/
|
||||
sc5xx_enable_rgmii();
|
||||
setbits_32(&eqos->dma_regs->mode, EQOS_DMA_MODE_SWR);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int eqos_probe_resources_adi(struct udevice *dev)
|
||||
{
|
||||
struct eqos_priv *eqos = dev_get_priv(dev);
|
||||
phy_interface_t interface;
|
||||
int ret;
|
||||
|
||||
ret = eqos_get_base_addr_dt(dev);
|
||||
if (ret) {
|
||||
pr_err("eqos_get_base_addr_dt failed: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
|
||||
interface = eqos->config->interface(dev);
|
||||
if (interface == PHY_INTERFACE_MODE_NA) {
|
||||
pr_err("Invalid PHY interface\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* rgmii tx clock rate is set to 125 MHz regardless of phy mode, and
|
||||
* by default the internal clock is always connected to 125 MHz. According
|
||||
* to the HRM it is invalid for this clock to have any other speed, so
|
||||
* the hardware won't work anyway if this is wrong.
|
||||
*/
|
||||
static ulong eqos_get_tick_clk_rate_adi(struct udevice *dev)
|
||||
{
|
||||
return 125 * 1000000;
|
||||
}
|
||||
|
||||
static int eqos_get_enetaddr_adi(struct udevice *dev)
|
||||
{
|
||||
struct eth_pdata *pdata = dev_get_plat(dev);
|
||||
|
||||
return eth_env_get_enetaddr("ethaddr", pdata->enetaddr);
|
||||
}
|
||||
|
||||
static struct eqos_ops eqos_adi_ops = {
|
||||
.eqos_inval_desc = eqos_inval_desc_generic,
|
||||
.eqos_flush_desc = eqos_flush_desc_generic,
|
||||
.eqos_inval_buffer = eqos_inval_buffer_generic,
|
||||
.eqos_flush_buffer = eqos_flush_buffer_generic,
|
||||
.eqos_probe_resources = eqos_probe_resources_adi,
|
||||
.eqos_remove_resources = eqos_null_ops,
|
||||
.eqos_start_resets = eqos_start_resets_adi,
|
||||
.eqos_stop_resets = eqos_null_ops,
|
||||
.eqos_start_clks = eqos_null_ops,
|
||||
.eqos_stop_clks = eqos_null_ops,
|
||||
.eqos_calibrate_pads = eqos_null_ops,
|
||||
.eqos_disable_calibration = eqos_null_ops,
|
||||
.eqos_set_tx_clk_speed = eqos_null_ops,
|
||||
.eqos_get_enetaddr = eqos_get_enetaddr_adi,
|
||||
.eqos_get_tick_clk_rate = eqos_get_tick_clk_rate_adi,
|
||||
};
|
||||
|
||||
struct eqos_config __maybe_unused eqos_adi_config = {
|
||||
.reg_access_always_ok = true,
|
||||
.mdio_wait = 20,
|
||||
.swr_wait = 50,
|
||||
.config_mac = EQOS_MAC_RXQ_CTRL0_RXQ0EN_ENABLED_DCB,
|
||||
.config_mac_mdio = EQOS_MAC_MDIO_ADDRESS_CR_150_250,
|
||||
.axi_bus_width = EQOS_AXI_WIDTH_32,
|
||||
.interface = dev_read_phy_mode,
|
||||
.ops = &eqos_adi_ops,
|
||||
};
|
Loading…
Add table
Reference in a new issue