]> git.itanic.dy.fi Git - linux-stable/commit
net: phy: smsc: Disable Energy Detect Power-Down in interrupt mode
authorLukas Wunner <lukas@wunner.de>
Mon, 20 Jun 2022 11:04:50 +0000 (13:04 +0200)
committerJakub Kicinski <kuba@kernel.org>
Wed, 22 Jun 2022 04:59:47 +0000 (21:59 -0700)
commit2642cc6c3bbe0900ba15bab078fd15ad8baccbc5
treeca3f4fd5cf97b67653da8c31872fe9114211c47d
parent69135c572d1f84261a6de2a1268513a7e71753e2
net: phy: smsc: Disable Energy Detect Power-Down in interrupt mode

Simon reports that if two LAN9514 USB adapters are directly connected
without an intermediate switch, the link fails to come up and link LEDs
remain dark.  The issue was introduced by commit 1ce8b37241ed ("usbnet:
smsc95xx: Forward PHY interrupts to PHY driver to avoid polling").

The PHY suffers from a known erratum wherein link detection becomes
unreliable if Energy Detect Power-Down is used.  In poll mode, the
driver works around the erratum by briefly disabling EDPD for 640 msec
to detect a neighbor, then re-enabling it to save power.

In interrupt mode, no interrupt is signaled if EDPD is used by both link
partners, so it must not be enabled at all.

We'll recoup the power savings by enabling SUSPEND1 mode on affected
LAN95xx chips in a forthcoming commit.

Fixes: 1ce8b37241ed ("usbnet: smsc95xx: Forward PHY interrupts to PHY driver to avoid polling")
Reported-by: Simon Han <z.han@kunbus.com>
Signed-off-by: Lukas Wunner <lukas@wunner.de>
Link: https://lore.kernel.org/r/439a3f3168c2f9d44b5fd9bb8d2b551711316be6.1655714438.git.lukas@wunner.de
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/phy/smsc.c