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

相关推荐
深耕AI9 小时前
【时钟周期 vs 指令】为什么51单片机需要12个时钟周期?
单片机·嵌入式硬件·51单片机
Arciab9 小时前
51单片机_LCD1602液晶显示
网络·嵌入式硬件·51单片机
清风66666612 小时前
基于单片机的多功能智能婴儿车设计
单片机·嵌入式硬件·毕业设计·课程设计·期末大作业
码咔吧咔12 小时前
STM32芯片简介,以及STM32的存储器映射是什么?
stm32·单片机·嵌入式硬件
别掩14 小时前
MOS防倒灌电路设计
单片机·嵌入式硬件
夜流冰15 小时前
EE - 电容电感电路中电流的变化
单片机·嵌入式硬件
橙露15 小时前
STM32中断配置全解析:从寄存器到HAL库的实战应用
stm32·单片机·嵌入式硬件
c-u-r-ry3015 小时前
ZYNQ7 Processing System各个配置界面介绍
嵌入式硬件
idcardwang16 小时前
esp32s3-pwm介绍与stm32的不同原理
单片机·嵌入式硬件
码咔吧咔16 小时前
Flash 是什么?SRAM 是什么?它们的作用、特点、区别、在 STM32 中如何使用?
stm32·嵌入式硬件