_laki_

  • 2025-01-07
  • 发表了主题帖: gd32f470网络例程中enet_software_reset卡死无法复位

    我在gd32f470IKH芯片上移植gd官方enet例程,使用的PHY芯片为DP83848IVV 修改部分: 1.修改了一下时钟,例程中的时钟使用的__SYSTEM_CLOCK_240M_PLL_25M_HXTAL,如果是240M分频后到PHY时钟输入不是50M,所以我将原始中注释并修改成了__SYSTEM_CLOCK_200M_PLL_25M_HXTAL如下:   2.修改了PLL的时钟输入源,原始宏定义是 #define __SYS_OSC_CLK     (__IRC16M) 修改后如下,修改完成后用示波器测了最终到PHY的时钟输入为50M没有问题:   问题描述: 在程序调试过程中发现卡在enet_software_reset()函数,具体是因为ENET_DMA_BCTL寄存器的软复位无法置为,导致等待超时返回ERROR卡在了while中,如下:   问题分析: 查看了一下网上的一些帖子,说的是时钟配置可能出现问题,但是实际打了频率确实是50M没有问题,如果跳过这里的检测,后面依然会运行不了   求大佬们解答一下!!!    

最近访客

现在还没有访客

< 1/0 >

统计信息

已有--人来访过

  • 芯积分:8
  • 好友:--
  • 主题:1
  • 回复:0

留言

你需要登录后才可以留言 登录 | 注册


现在还没有留言