]> www.infradead.org Git - users/hch/dma-mapping.git/commit
net: stmmac: dwmac-tegra: Fix link bring-up sequence
authorParitosh Dixit <paritoshd@nvidia.com>
Thu, 10 Oct 2024 14:29:08 +0000 (10:29 -0400)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 15 Oct 2024 10:35:17 +0000 (12:35 +0200)
commit1cff6ff302f5703a627f9ee1d99131161ea2683e
tree675922702d2ee09856c67d3fce662ee92ee62e98
parentb62f4c186c70aa235fef2da68d07325d85ca3ade
net: stmmac: dwmac-tegra: Fix link bring-up sequence

The Tegra MGBE driver sometimes fails to initialize, reporting the
following error, and as a result, it is unable to acquire an IP
address with DHCP:

 tegra-mgbe 6800000.ethernet: timeout waiting for link to become ready

As per the recommendation from the Tegra hardware design team, fix this
issue by:
- clearing the PHY_RDY bit before setting the CDR_RESET bit and then
setting PHY_RDY bit before clearing CDR_RESET bit. This ensures valid
data is present at UPHY RX inputs before starting the CDR lock.
- adding the required delays when bringing up the UPHY lane. Note we
need to use delays here because there is no alternative, such as
polling, for these cases. Using the usleep_range() instead of ndelay()
as sleeping is preferred over busy wait loop.

Without this change we would see link failures on boot sometimes as
often as 1 in 5 boots. With this fix we have not observed any failures
in over 1000 boots.

Fixes: d8ca113724e7 ("net: stmmac: tegra: Add MGBE support")
Signed-off-by: Paritosh Dixit <paritoshd@nvidia.com>
Link: https://patch.msgid.link/20241010142908.602712-1-paritoshd@nvidia.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/ethernet/stmicro/stmmac/dwmac-tegra.c