diff options
| author | Robert Marko <[email protected]> | 2023-11-14 14:08:43 +0000 |
|---|---|---|
| committer | David S. Miller <[email protected]> | 2023-11-16 22:10:29 +0000 |
| commit | e93984ebc1c82bd34f7a1b3391efaceee0a8ae96 (patch) | |
| tree | ad8ffb518a926ae259a1111231352161571adc9a /tools/testing/selftests/tc-testing/plugin-lib/nsPlugin.py | |
| parent | net: phy: aquantia: move MMD_VEND define to header (diff) | |
| download | kernel-e93984ebc1c82bd34f7a1b3391efaceee0a8ae96.tar.gz kernel-e93984ebc1c82bd34f7a1b3391efaceee0a8ae96.zip | |
net: phy: aquantia: add firmware load support
Aquantia PHY-s require firmware to be loaded before they start operating.
It can be automatically loaded in case when there is a SPI-NOR connected
to Aquantia PHY-s or can be loaded from the host via MDIO.
This patch adds support for loading the firmware via MDIO as in most cases
there is no SPI-NOR being used to save on cost.
Firmware loading code itself is ported from mainline U-boot with cleanups.
The firmware has mixed values both in big and little endian.
PHY core itself is big-endian but it expects values to be in little-endian.
The firmware is little-endian but CRC-16 value for it is stored at the end
of firmware in big-endian.
It seems the PHY does the conversion internally from firmware that is
little-endian to the PHY that is big-endian on using the mailbox
but mailbox returns a big-endian CRC-16 to verify the written data
integrity.
Co-developed-by: Christian Marangi <[email protected]>
Signed-off-by: Robert Marko <[email protected]>
Signed-off-by: Christian Marangi <[email protected]>
Reviewed-by: Andrew Lunn <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'tools/testing/selftests/tc-testing/plugin-lib/nsPlugin.py')
0 files changed, 0 insertions, 0 deletions
