[RESEND PATCH v2 3/5] net: dwc_eth_qos: Adapt probe() for PCI devices
Philip Oberfichtner
pro at denx.de
Fri Jul 12 15:16:03 CEST 2024
Hi Marek,
Thank you for the review!
On Sun, Jun 30, 2024 at 07:33:33AM +0200, Marek Vasut wrote:
> On 6/24/24 10:34 AM, Philip Oberfichtner wrote:
> > PCI devices do not necessarily use a device tree. In that case, the
> > driver currently fails to find eqos->config and eqos->regs.
> >
> > This commit factors out the respective functionality. Device tree usage
> > remains default, but board specific implementations will be possible as
> > well.
> >
> > Signed-off-by: Philip Oberfichtner <pro at denx.de>
> > ---
> > drivers/net/dwc_eth_qos.c | 28 +++++++++++++++++++++++++---
> > drivers/net/dwc_eth_qos.h | 3 +++
> > drivers/net/dwc_eth_qos_imx.c | 1 +
> > drivers/net/dwc_eth_qos_qcom.c | 1 +
> > drivers/net/dwc_eth_qos_rockchip.c | 1 +
> > drivers/net/dwc_eth_qos_starfive.c | 1 +
> > drivers/net/dwc_eth_qos_stm32.c | 1 +
> > 7 files changed, 33 insertions(+), 3 deletions(-)
> >
> > diff --git a/drivers/net/dwc_eth_qos.c b/drivers/net/dwc_eth_qos.c
> > index b87634f1f5..34e29301cc 100644
> > --- a/drivers/net/dwc_eth_qos.c
> > +++ b/drivers/net/dwc_eth_qos.c
> > @@ -1376,6 +1376,21 @@ static int eqos_remove_resources_tegra186(struct udevice *dev)
> > return 0;
> > }
> > +/*
> > + * Get driver data based on the device tree. Boards not using a device tree can
> > + * overwrite this function.
> > + */
> > +__weak void *eqos_get_driver_data(struct udevice *dev)
> > +{
> > + return (void *)dev_get_driver_data(dev);
> > +}
> > +
> > +/* Function to get base address, useable for all boards having a device tree. */
> > +fdt_addr_t eqos_get_base_addr_dt(struct udevice *dev)
> > +{
> > + return dev_read_addr(dev);
> > +}
> > +
> > static int eqos_probe(struct udevice *dev)
> > {
> > struct eqos_priv *eqos = dev_get_priv(dev);
> > @@ -1384,13 +1399,19 @@ static int eqos_probe(struct udevice *dev)
> > debug("%s(dev=%p):\n", __func__, dev);
> > eqos->dev = dev;
> > - eqos->config = (void *)dev_get_driver_data(dev);
> > - eqos->regs = dev_read_addr(dev);
> > + eqos->config = eqos_get_driver_data(dev);
> > + if (!eqos->config) {
> > + pr_err("Failed to get driver data.\n");
> > + return -ENODEV;
> > + }
> > +
> > + eqos->regs = eqos->config->ops->eqos_get_base_addr(dev);
> > if (eqos->regs == FDT_ADDR_T_NONE) {
> > - pr_err("dev_read_addr() failed\n");
> > + pr_err("Failed to get device address.\n");
> > return -ENODEV;
> > }
> > +
> > eqos->mac_regs = (void *)(eqos->regs + EQOS_MAC_REGS_BASE);
> > eqos->mtl_regs = (void *)(eqos->regs + EQOS_MTL_REGS_BASE);
> > eqos->dma_regs = (void *)(eqos->regs + EQOS_DMA_REGS_BASE);
>
> Could you factor out the entirety of:
>
> eqos->regs = dev_read_addr(dev);
> if (eqos->regs == FDT_ADDR_T_NONE) {
> pr_err("dev_read_addr() failed\n");
> return -ENODEV;
> }
> eqos->mac_regs = (void *)(eqos->regs + EQOS_MAC_REGS_BASE);
> eqos->mtl_regs = (void *)(eqos->regs + EQOS_MTL_REGS_BASE);
> eqos->dma_regs = (void *)(eqos->regs + EQOS_DMA_REGS_BASE);
> eqos->tegra186_regs = (void *)(eqos->regs +
> EQOS_TEGRA186_REGS_BASE);
>
> into some common function, like eqos_get_base_addr_dt() , and call it from
> .eqos_probe_resources callback instead ? That way you wouldn't have to add
> new callback specifically for register address.
Good point. I'll include it in V3.
Best regards,
Philip
--
=====================================================================
DENX Software Engineering GmbH, Managing Director: Erika Unter
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-22 Fax: +49-8142-66989-80 Email: pro at denx.de
=====================================================================
More information about the U-Boot
mailing list