ENET_INIT卡死在DMA_MODE判断
在ENET_INIT中有一段代码是判断DMA_MODE的SWR是否被清零,在调试时候发现始终会卡死在while循环,于是查阅芯片手册:
位 0:SWR(软件复位)
当该位置 1 时,MAC 和 DMA 控制器会复位内部逻辑,以及 DMA、MTL(媒体访问控制传输层)和 MAC 的所有内部寄存器。复位操作在 DWC_ether_qos 的所有时钟域完成后,该位会自动清零。在重新编程任何 DWC_ether_qos 寄存器前,需确认该位已读回 0。
向该位写入 1 后,至少需等待 4 个 CSR 时钟周期才能读取其值。
注意:仅当所有活动时钟域中的复位信号均已释放时,复位操作才算完成。因此,所有 PHY 输入时钟(与所选 PHY 接口对应)必须存在,以确保软件复位完成。复位操作的完成时间取决于最慢活动时钟的频率。
访问限制:置 1 时触发复位(自清零),置 0 无效果。
- 0b:软件复位禁用
- 1b:软件复位使能
发现这一位是和时钟使能相关,逐个确认ENET_125M_REF_CLK(参考时钟源)
、 总线时钟、CSR_CLK时钟源正确配置后,问题解决。