Re: [PATCH 3/3] net: hisilicon: Add Fast Ethernet MAC driver

From: Arnd Bergmann
Date: Mon Jun 13 2016 - 06:33:36 EST


On Monday, June 13, 2016 2:07:56 PM CEST Dongpo Li wrote:

> +- reset-names: should contain the reset signal name "mac_reset"(required)
> + and "phy_reset"(optional).

Maybe just name the resets 'mac' and 'phy'? The '_reset' part is
implied by the property.

I gave the driver a brief review and basically everything looks
great, very nice work!

There are two small things that I noticed:

> +
> + do {
> + hisi_femac_xmit_reclaim(dev);
> + num = hisi_femac_rx(dev, task);
> + work_done += num;
> + task -= num;
> + if ((work_done >= budget) || (num == 0))
> + break;
> +
> + ints = readl(priv->glb_base + GLB_IRQ_STAT);
> + writel(ints & DEF_INT_MASK,
> + priv->glb_base + GLB_IRQ_RAW);
> + } while (ints & DEF_INT_MASK);
> +
> + if (work_done < budget) {
> + napi_complete(napi);
> + hisi_femac_irq_enable(priv, DEF_INT_MASK);
> + }

You tx function uses BQL to optimize the queue length, and that
is great. You also check xmit reclaim for rx interrupts, so
as long as you have both rx and tx traffic, this should work
great.

However, I notice that you only have a 'tx fifo empty'
interrupt triggering the napi poll, so I guess on a tx-only
workload you will always end up pushing packets into the
queue until BQL throttles tx, and then get the interrupt
after all packets have been sent, which will cause BQL to
make the queue longer up to the maximum queue size, and that
negates the effect of BQL.

Is there any way you can get a tx interrupt earlier than
this in order to get a more balanced queue, or is it ok
to just rely on rx packets to come in occasionally, and
just use the tx fifo empty interrupt as a fallback?

> + priv->phy_mode = of_get_phy_mode(node);
> + if (priv->phy_mode < 0) {
> + dev_err(dev, "not find phy-mode\n");
> + ret = -EINVAL;
> + goto out_disable_clk;
> + }
> +
> + priv->phy_node = of_parse_phandle(node, "phy-handle", 0);
> + if (!priv->phy_node) {
> + dev_err(dev, "not find phy-handle\n");
> + ret = -EINVAL;
> + goto out_disable_clk;
> + }
> +
> + priv->phy = of_phy_connect(ndev, priv->phy_node,
> + hisi_femac_adjust_link, 0, priv->phy_mode);
> + if (!(priv->phy) || IS_ERR(priv->phy)) {
> + dev_err(dev, "connect to PHY failed!\n");
> + ret = -ENODEV;
> + goto out_phy_node;
> + }

I wonder if we could generalize this set of three calls, I
get the impression that we duplicate this across several
drivers that shouldn't need to bother with the specific
phy-handle and phy-mode properties.

Arnd