大家好,我最近在用STM32F107的以太网接口,外接DM9161AEP PHY,LWIP (1.00版本)。仅使用UDP通信,程序运行了一段时间后,出现网络假死的情况。出错时间随机,长则几天,短则几分钟。 重现方法:用其他设备一直给该设备发送数据IP、端口发送数据,结果很快就出现网络假死的情况,但是单片机的程序还在跑,其他功能正常。
网络假死后只能通过断点重启单片机才能恢复。在网络假死的情况下,(设备定向给PC发数据)用Wireshark工具抓包,PC能收单片机发来的ARP请求。但是单片机收不到任何数据。没有跑系统,单片机裸跑,用查询方式接收数据,网络假死后查询ETH_GetRxPktSize()函数一直返回0。
每一个pbuf_alloc失败都会打印信息,但是在网络死机时并没有发现pbuf_alloc失败的信息。通过串口打印调试信息,正常的时候low_level_input 和low_level_output都有数据;异常时low_level_input没有数据,low_level_output还在发ARP请求数据。通过LWIP_DEBUG,一直有“etharp_timer”和“tcp_slowtmr: no active PCBs”信息输出。
参考了网友“老衲五木”的博客文章,修改了几天代码也没有解决。望各位大神指点迷津,谢谢!
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
好的,谢谢
一周热门 更多>