[PATCH 0/5] imx8mn-var-som: fix ethernet for Variscite symphony board and imx8m nano SOM
hugo at hugovil.com
Mon May 1 22:01:16 CEST 2023
From: Hugo Villeneuve <hvilleneuve at dimonoff.com>
This patch series fixes bugs and add missing features related to the ethernet
PHY on Variscite symphony carrier board with an imx8m nano SOM
Ethernet functionality is currently broken for the VAR-SOM-MX8M-NANO.
Variscite imx8m nano SOM comes in multiple hardware configuration options.
One of this hardware configuration option is called EC:
EC: Ethernet Controller PHY assembled on SOM
For SOM with the EC configuration, the ethernet PHY is located on the
SOM itself, and connected to the CPU ethernet controller. It has a
reset line controlled via GPIO1_IO9. In this configuration, the PHY
located on the carrier board is not connected to anything and is
therefore not used.
For SOM without EC configuration, the ethernet PHY on the carrier
board is connected to the CPU ethernet controller. It has a reset line
controlled via the GPIO expander PCA9534_IO5.
Patch 1 add code to read and display the SOM configuration stored in the SOM
EEPROM. This patch is also submitted to the Linux kernel (section that adds
the EEPROM to the device tree), so that it will be easier to sync the DT between
kernel and U-Boot.
Patch 2 fixes bugs with the PHY reset properties.
Patch 3 fixes a bug with a missing PHY reset deassert delay (also submitted to
Patch 4 enables automatic read of PHY MAC address from the SOM EEPROM.
Patch 5 is used for auto-detecting at runtime the SOM hardware configuration
option related to the PHY (EC), and dynamically adjust the device tree to
support both SOM PHY options.
This series need the following patch to be applied first:
I have succesfully tested the changes on a Variscite symphony carrier board with
a VAR-SOM-MX8M-NANO having the EC configuration option.
Unfortunately, I do not have a VAR-SOM-MX8M-NANO with a non-EC configuration
option so I couldn't test it on real hardware, altough I simulated it and
confirmed that the device tree fixing seems to be correct by using debug/print
Hugo Villeneuve (5):
imx8mn-var-som: read and print SoM infos from eeprom on startup
imx8mn-var-som: fix non-applied PHY reset-gpios properties
arm: dts: imx8mn-var-som: fix PHY detection bug by adding deassert
imx8mn-var-som: read eth MAC address from EEPROM
imx8mn-var-som: adjust PHY reset gpios according to hardware
.../dts/imx8mn-var-som-symphony-u-boot.dtsi | 17 ++
arch/arm/dts/imx8mn-var-som-symphony.dts | 4 -
arch/arm/dts/imx8mn-var-som.dtsi | 18 +-
arch/arm/mach-imx/imx8m/Kconfig | 4 +
.../variscite/imx8mn_var_som/imx8mn_var_som.c | 214 ++++++++++++++++++
configs/imx8mn_var_som_defconfig | 4 +
6 files changed, 256 insertions(+), 5 deletions(-)
More information about the U-Boot