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时钟源正确配置后,问题解决。

相关推荐
普中科技2 小时前
【普中STM32F1xx开发攻略--标准库版】-- 第 13 章 STM32 位带操作
stm32·单片机·嵌入式硬件·arm·gpio·普中科技·位带操作
河南博为智能科技有限公司3 小时前
RS485转以太网串口服务器-串口设备联网的理想选择
大数据·服务器·人工智能·单片机·嵌入式硬件·物联网
国科安芯4 小时前
抗辐照MCU芯片在无人叉车领域的性能评估与选型建议
网络·人工智能·单片机·嵌入式硬件·安全
国科安芯4 小时前
抗辐照MCU芯片在激光雷达领域的适配性分析
网络·人工智能·单片机·嵌入式硬件·fpga开发
日更嵌入式的打工仔5 小时前
<RT1176系列14>CCM(Clock Controller Module)解读
单片机·嵌入式硬件
云山工作室5 小时前
基于单片机的环境监测智能报警系统的设计(论文+源码)
stm32·单片机·嵌入式硬件·毕业设计·毕设
齐落山大勇5 小时前
STM32的串口(上位机控制下位机)
stm32·单片机·嵌入式硬件
小尧嵌入式5 小时前
STM32启动汇编文件详解及启动逻辑
汇编·arm开发·stm32·单片机
m0_598250006 小时前
电源完整性07-如何确定PDN网络中的大电容
笔记·单片机·嵌入式硬件·硬件工程
广东小67 小时前
【海思】在Ubuntu20.04上搭建可以成功编译Hi3559AV100的环境_20251104
嵌入式硬件