问题现象
硬件环境:
- CPU FT2000-4
- CPU 直出的两个RGMII接口外接网络phy 模块转换成 1000Base-KX
相同硬件环境下,客户发现 定制桌面版系统A(内核 4.4.131)gmac 网口可以正常使用,换成 定制桌面版系统B(内核 5.4.18)后,在终端 ifconfig 输出中看不到 gmac 网口,手 动 ifconfig up 会 报 错 : stmmaceth PHYT0004:00 enaphyt4i0: stmmac_open: Cannot attach to PHY (error: -22)
由此报错,怀疑是 5.4.18内核phy与mac的交互出了问题。
问题定位
gmac 网卡使用的驱动是 st_gmac,内核中源码目录位于:driver/net/ethernet/stmicro。
已知报错发生在 stmmac_open 里,跟踪 5.4.18 代码得知函数调用流程如下:

phylink_bringup_phy 内调用代码如下:

phylink_validate 代码如下:

经测试得知,由于 phylink_is_empty_linkmode 返回值不为 0,导致的 phylink_validate返 回 -22

文章讨论了在不同内核版本(4.4.131和5.4.18)下,gmac网卡在硬件环境中遇到的问题。5.4.18内核引入的phylink机制要求PHY驱动配置features,而Marvell88E1111驱动缺少配置导致错误。解决方法是为驱动添加PHY_GBIT_FEATURES。
最低0.47元/天 解锁文章
2316





