ipq40xx: fix ar40xx driver
authorNick Hainke <vincent@systemli.org>
Mon, 18 Apr 2022 13:04:25 +0000 (15:04 +0200)
committerDavid Bauer <mail@david-bauer.net>
Sat, 30 Apr 2022 14:31:32 +0000 (16:31 +0200)
commite9431a8335658fd8bcb1c01b3c7e59bf0401196d
treeaf09dc6c3f82d0ebe21eba17826434560537612a
parentdd58c12f0f404580785789c144d8548d1a945fe1
ipq40xx: fix ar40xx driver

This commit is completely based on the work of adron-s:
https://github.com/openwrt/openwrt/pull/4721#issuecomment-1101108651

The commit fixes the data corruption on TX packets. Packets are
transmitted, but their contents are replaced with zeros. This error is
caused by the lack of guard (50 ms) intervals between calibration phases.
This error is treated by adding mdelay(50) to the calibration function
code. In the original qca-ssda code [0], these mdelays were existing, but
in the ar41xx.c they are gone.

Tested on:
- Fritz!Box 4040
- Fritz!Box 7530
- Mikrotik SXTsq 5AC
- ZyXEL NBG6617

- [0] https://git.codelinaro.org/clo/qsdk/oss/lklm/qca-ssdk/-/blob/NHSS.QSDK.11.4/src/init/ssdk_init.c#L2072

Suggested-by: Serhii Serhieiev <adron@mstnt.com>
Reviewed-by: Robert Marko <robimarko@gmail.com>
Signed-off-by: Nick Hainke <vincent@systemli.org>
(cherry picked from commit ab7e53e5cce703c7a62efbe1d41fb94c2228a178)
[Deleted 5.10 from commit title]
Signed-off-by: Nick Hainke <vincent@systemli.org>
target/linux/ipq40xx/files/drivers/net/phy/ar40xx.c