1.问题描述
在使用正点原子lwip库函数工程调试过程中,发送接收数据都是没问题的,当开始ping的时候,会ping通固定的次数,会显示ping请求超时,同时通讯也会断开,只有重启才能恢复。
2.问题调查和解决方案
查看底层代码,发现ping通的次数和lwipopts.h中的#define PBUF_POOL_SIZE 20宏定义相关,将该宏定义改成10,就会ping通10次之后请求超时,当初想将这个宏定义改成很大,但是后来发现自协商会失败,所以还需要继续调查,最后通过wireshark抓协议,发现ping的功能函数和icmp相关,
所以开始调查icmp.c中的函数,发现正点原子例程中将pbuf_free()这个函数全部注释掉了(不太清楚为什么要全部注释掉),内存无法释放,导致请求超时,将pbuf_free()函数全部添加上,ping和通讯都可正常工作,并且通过了拷机测试,很稳定。