OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4155|回复: 2

lwip tcp 数据接收异常问题

[复制链接]

1

主题

1

帖子

0

精华

新手入门

积分
9
金钱
9
注册时间
2018-12-3
在线时间
4 小时
发表于 2018-12-3 10:57:14 | 显示全部楼层 |阅读模式
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)


D3A2ABDE-BF1C-4236-B2BD-B3A35AFC16E8.png
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

109

主题

5562

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10541
金钱
10541
注册时间
2017-2-18
在线时间
1908 小时
发表于 2018-12-3 21:59:05 | 显示全部楼层
回复

使用道具 举报

11

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2018-11-26
在线时间
26 小时
发表于 2018-12-17 16:56:48 | 显示全部楼层
会不会是接收端的缓存区不够大
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-24 18:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表