11011|6

314

帖子

0

TA的资源

纯净的硅(初级)

楼主
 

lwip协议 连续两次调用tcp_write只执行一次? [复制链接]

while循环中连续调用了两个tcp_write函数,可是每次上位机只显示第一个tcp_write发送到的数据,第二个tcp_write发送的数据未显示。

下位机程序调试时,这两句tcp_write的代码都运行了。可是为什么网络调试助手只显示第一个tcp_write发送到的数据?

最新回复

还有一个方法找到原因就是启用 lwip_debug,输出调试信息,看看第二句执行到哪里停止了。  详情 回复 发表于 2013-6-7 08:44

点评

如果确定下位机两次都正常地发送了完整的以太网帧,那问题应该出现在你用的网络调试助手是没有正常响应的,是有问题的。  详情 回复 发表于 2013-6-6 13:50
 
点赞 关注

回复
举报

1803

帖子

0

TA的资源

五彩晶圆(高级)

沙发
 

回复 楼主 喜鹊王子 的帖子

如果确定下位机两次都正常地发送了完整的以太网帧,那问题应该出现在你用的网络调试助手是没有正常响应的,是有问题的。

点评

两个tcp_write任意注释掉一个,另外一个都能成功发给上位机显示。 我将开发板做服务器时,连续调用两个tcp_write,网络调试助手都能够正常显示。  详情 回复 发表于 2013-6-6 15:01
 
 

回复

314

帖子

0

TA的资源

纯净的硅(初级)

板凳
 

回复 沙发 Study_Stellaris 的帖子

两个tcp_write任意注释掉一个,另外一个都能成功发给上位机显示。
我将开发板做服务器时,连续调用两个tcp_write,网络调试助手都能够正常显示。

点评

确定客户端两个 tcp_write 都正常发送了数据了吗? 如果确定发送了,说明网络调试助手的客户端是有问题的。  详情 回复 发表于 2013-6-6 15:52
 
 
 

回复

1803

帖子

0

TA的资源

五彩晶圆(高级)

4
 

回复 板凳 喜鹊王子 的帖子

确定客户端两个 tcp_write 都正常发送了数据了吗?
如果确定发送了,说明网络调试助手的客户端是有问题的。

点评

static err_t TCP_Client_connected(void *arg,struct tcp_pcb *pcb,err_t err) { tcp_write(pcb,\"hello\",sizeof(\"hello\"),0); SysCtlDelay(SysCtlClockGet( )/3*1);//延时1秒 tcp_write(pcb,\"  详情 回复 发表于 2013-6-6 16:13
两个tcp_write函数的返回值都是ERR_OK ,这也只能说明数据被正确的放入到发送队列了吧。至于有没有发出去怎么看啊  详情 回复 发表于 2013-6-6 15:55
 
 
 

回复

314

帖子

0

TA的资源

纯净的硅(初级)

5
 

回复 4楼 Study_Stellaris 的帖子

两个tcp_write函数的返回值都是ERR_OK ,这也只能说明数据被正确的放入到发送队列了吧。至于有没有发出去怎么看啊
 
 
 

回复

314

帖子

0

TA的资源

纯净的硅(初级)

6
 

回复 4楼 Study_Stellaris 的帖子

static err_t
TCP_Client_connected(void *arg,struct tcp_pcb *pcb,err_t err)
{  
tcp_write(pcb,"hello",sizeof("hello"),0);
  SysCtlDelay(SysCtlClockGet( )/3*1);//延时1秒  
  tcp_write(pcb,"lwip",sizeof("lwip"),0);
  return ERR_OK;
}
这个函数是9B96作为客户端连接上上位机时的回调函数,在这个回调函数中的两个 tcp_write只有第一个正确的在上位机显示。

后来我测试了下,将两句 tcp_write放到main的while循环中,两句tcp_write都能发送到上位机显示,不知道是什么原因?
while(1)
    {
                TCP_Client_Init();
                SysCtlDelay(SysCtlClockGet( )/3*1);//延时1秒
                tcp_write(pcb1,"hello",sizeof("hello"),0);
                SysCtlDelay(SysCtlClockGet( )/3*1);//延时1秒  
                tcp_write(pcb1,"lwip",sizeof("lwip"),0);
               
    }

点评

还有一个方法找到原因就是启用 lwip_debug,输出调试信息,看看第二句执行到哪里停止了。  详情 回复 发表于 2013-6-7 08:44
 
 
 

回复

1803

帖子

0

TA的资源

五彩晶圆(高级)

7
 

回复 6楼 喜鹊王子 的帖子

还有一个方法找到原因就是启用 lwip_debug,输出调试信息,看看第二句执行到哪里停止了。
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表