OpenEdv-开源电子网

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

UCOSIII+LWIP服务端长时间发送数据失败

[复制链接]

2

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2016-5-3
在线时间
9 小时
发表于 2018-11-12 14:54:41 | 显示全部楼层 |阅读模式
本帖最后由 Alimu 于 2018-11-12 14:54 编辑

现在用的是UCOSIII+LWIP,用STM32做服务端,定时向客户端发送25个字节数据,测试发现3个小时候左右,数据会发不过去,有时候半个小时就会出现,用PC也ping不通服务端,但是其他进程还在正常工作。
添加打印找问题位置,定位在
                                

[mw_shl_code=c,true]                                        err = netconn_write(newconn ,tcp_server_sendbuf,25,NETCONN_COPY); //发送tcp_server_sendbuf中数据
                                        printf("发送数据错误代码为:%d\r\n",err);
                                        if(err != ERR_OK)
                                        {
                                                printf("发送失败\r\n");
                                        }
[/mw_shl_code]

打印出发送数据错误代码为:-6
         发送失败
下一次发送数据的时候,程序卡死在 netconn_write函数里、
添加打印,发现是在tcpip_apimsg(struct api_msg *apimsg)函数里的
sys_arch_sem_wait(&apimsg->msg.conn->op_completed, 0);一直等待信号,所以卡住了
修改了等待时间为200个时钟节拍,也就是5ms*200=1s将        OSSemPend(sem,timeout,OS_OPT_PEND_NON_BLOCKING,0,&err);
中修改了OS_OPT_PEND_BLOCKING为OS_OPT_PEND_NON_BLOCKING后,能一直接收到前面的打印信息了
有没有人比较清楚是哪里的信号量没有释放吗,求助!




正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

109

主题

5564

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10571
金钱
10571
注册时间
2017-2-18
在线时间
1914 小时
发表于 2018-11-12 21:59:15 | 显示全部楼层
回复 支持 反对

使用道具 举报

2

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2016-5-3
在线时间
9 小时
 楼主| 发表于 2018-11-14 22:00:19 | 显示全部楼层
帮忙顶一顶,沉下去了
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 17:59

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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