Phy with reset-gpio fails to read phy id during kexec -e

From: Xiaolei Wang
Date: Wed Jul 16 2025 - 04:20:59 EST


Hi

During kexec -e, I found that the network card did not work when loading the kernel.

I found that some phys used reset-gpios. When kexec -e is running,

the network port will do_ifdown, and phy_detach() will be called at

this time, which will call phy_device_reset(phydev, 1); to keep phy in

reset state.

After loading the kernel, since phy is always in reset state, the mdio

controller fails to access phy id. Therefore, if phy uses reset-gpios

during kexec -e, the network port will not work. However, I have not

found a better solution. Can anyone give some suggestions?


kexec -e:

phy is always in reset state

  pca953x_gpio_set_value+0x8c/0xf8
  gpiochip_set+0x60/0x12c
  gpiod_set_raw_value_commit+0xe8/0x1e4
  gpiod_set_value_nocheck+0x58/0xe4
  gpiod_set_value_cansleep+0x4c/0xa8
  mdio_device_reset+0x48/0x158
  phy_detach+0x144/0x258
  phy_disconnect+0x54/0x74
  fec_enet_close+0x58/0x218

After loading kernel, reading phy id will report an error:

     mdio_bus 42890000.ethernet-1: MDIO device at address 2 is missing

  __of_mdiobus_parse_phys+0x260/0x338
  __of_mdiobus_register+0x118/0x28c
  fec_probe+0x173c/0x199c


thanks

xiaolei