新手入门
- 积分
- 9
- 金钱
- 9
- 注册时间
- 2018-12-3
- 在线时间
- 4 小时
|
3金钱
本帖最后由 gliu1996 于 2018-12-5 10:52 编辑
在开发中使用lwip + ucos + F4的组合,上面设置了一个tcp_server,但是偶发性地会出现一些通信问题,具体描述如下:[mw_shl_code=c,true] while(1)
{
err_recv = netconn_recv(tcp_server,&recvbuf);
if(ERR_OK != err_recv)
{[/mw_shl_code]
1. 向tcp_server发送数据,发送一段数据(约917字节)后tcp_server的netconn_recv就再也接收不到数据,err_recv为TIME_OUT
2. 出现通信问题后,重新连接上tcp_server后,tcp_server也无法接收数据
3. 出现通信问题后,过一段时间后通信恢复
出现通信问题时的抓到的包如下,刚开始服务器接收7字节数据,并返回10字节数据,后来出现通信问题后tcp_server接收不到数据,
但抓包显示lwip确实接收了7字节的数据-------------------
更新一下现象
-------------------
tcp_server每次只能收到920个字节,收满这么多数据后这个链接就收不到数据了,过一会这个链接崩掉后再发起一个链接还可以继续通信,但是仍然只能收到920个字节。诡异的是从抓包分析来看再通信出问题后lwip仍然接受了上位机的数据包,但是这些数据没有被提交到应用层(即tcp_server)
|
|