【基础技能】Linux PHY驱动调试方法

https://gitee.com/lee790608/linuxPhyDriver

STEP1 准备硬件环境
1. 开发环境,可以修改内核代码,编译
2. 硬件开发板,可以进入系统调试,可以传送代码(常用的ADB打通即可)
3. PHY芯片,最好是贴在开发板上,如果飞线,对走线信号要求非常高(尤其是SGMII)
4. 示波器,方便抓取MDIO / SGMII总线信号
STEP2 获取VDD和VDDIO,修改设备树
1. 根据硬件原理图,如果需要GPIO控制电源使能,修改设备树GPIO部分(固定供电则不用修改)
2. 修改l5控制的MDIO输出,需要同硬件核对具体配置
--- 此时,将PHY器件配置为RGMII模式,可以看到芯片在TX_CLK输出稳定的25MHz,则说明PHY芯片可以正常工作
--- 如果时钟频率不稳或者波形较差,后续可能照成不工作或者丢包严重
STEP3 修改Makefile和Kconfig
可以将qcom_emac等在调试阶段作为模块编译,可以减少反复编译
STEP4 安装qcom_emac模块,出现QCA8337相关的符号缺少提示,模块安装失败
直接屏蔽所有出现QCA字样的代码,新基线代码默认支持自带的QCA8337芯片,屏蔽后只避免处理此芯片,不影响其他功能
STEP5 持续验证MDIO总线
1. 代码打点,一般在emac_phy_config_external配置外部PHY的时候,开始出现通过MDIO读取芯片ID
2. 如果读取不稳定,抓取MDIO信号分析
--- MDIO是基本操作通道,当此通道存在异常时,可能出现各种无法解释的现象
--- 可以多次验证,当芯片ID读取到的内容出错的时候,即使波形无明显异常也基本是硬件问题,多调整两次连接线
--- PHY器件允许的MDIO总线频率可能较宽,例如TI的最高可以允许25MHz MDC,但是调试出错的时候,还是要将时钟频率降低
--- 如果时间允许,可以在状态机(正常1s一次)中加入读取寄存器代码,特别关注BMSR寄存器的bit2,观察PHY是否link up
--- MDIO操作正常时,使用ifconfig / ethtool工具可以正常配置网卡eth0,网卡自动加入到网桥端口bridge0
--- MDIO操作正常时,不一定可以ping通对端,但是至少TX发送统计间隔一定时间持续增长,接收不增长
STEP6 调试SGMII端口
1. 代码打点,读取STRAP(0x467)寄存器,观察是否同当前配置的模式相同
2. 代码打点,观察SGMII_STAT(0x459)寄存器,观察bit0(SGMII自协商完成)是否为1,此端口是内部PHY和外部PHY同步接口
--- 0x0f以后的寄存器属于设备商自定义寄存器,需要通过mmd读写(如果支持c45可以通过长地址模式,TI芯片不支持),注意调用接口不同
--- 如果SGMII自协商完成,底层就满足可以ping通对端的要求了,但是软件上还可能出现各种不支持的情况
STEP6 ping测试
1. ADB连接开发板,使用brctl show观察eth0是否自动加入bridge0
2. 在不通的时候,为了持续向eth0发包,可以通过route添加路由
3. 不通也可能是iptables防火墙配置了,可以使用iptables工具查询是否允许
4. 如果ping到Windows侧无响应,可以查看Windows侧是否允许协议入栈
--- 一般在协议软件层不会出现阻止ping的情况,列在这里,不一定可以用到

  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Linux中,`phy_read`函数是定义在`linux-4.9.225\include\linux\phy.h`文件中的。该函数用于从物理设备中读取寄存器的值。具体的定义如下: ```c static inline int phy_read(struct phy_device *phydev, u32 regnum) { return mdiobus_read(phydev->mdio.bus, phydev->mdio.addr, regnum); } ``` 在该函数中,调用了`mdiobus_read`函数来实际执行读取操作。`phydev`参数是一个指向`struct phy_device`结构体的指针,表示物理设备。`regnum`参数表示要读取的寄存器的编号。函数返回读取到的寄存器值。 另外,`phy_write`函数也是定义在同样的文件中,用于向物理设备中写入寄存器的值。具体的定义如下: ```c static inline int phy_write(struct phy_device *phydev, u32 regnum, u16 val) { return mdiobus_write(phydev->mdio.bus, phydev->mdio.addr, regnum, val); } ``` 该函数调用了`mdiobus_write`函数来实际执行写入操作。`phydev`参数和`regnum`参数的含义与`phy_read`函数相同,`val`参数表示要写入的寄存器值。 综上所述,`phy_read`和`phy_write`函数是用于在Linux中读取和写入物理设备寄存器的函数。 #### 引用[.reference_title] - *1* [PHY驱动调试之 --- PHY控制器驱动(二)](https://blog.csdn.net/enlaihe/article/details/125172195)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Linux Phy 驱动解析](https://blog.csdn.net/pwl999/article/details/128339747)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值