Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
lpc2478+lwip TCP通信问题
发布于 2011-03-10 09:32:21 浏览:12417
订阅该版
我现在是LPC2478+LWIP+(KSZ8041)环境下 测试下RT-THREAD, 怎么发现TCP发送速度快了以后,只能正常通信一会 ,然后就进入一种 每1-2秒才通信的状态,观察MEM SEM MAILBOX 好像没发现什么异常情况, lwip 也没输出什么 异常情况的调试信息。请问从哪里地方着手 才能解决问题呢。 这个测试任务的优先级别是138 网络接收任务的优先级别是129 TCP/IP的 是128 默认的 LWIPOPTS.H 没有修改参数 ```{ int err; int Cnt = 0; int txlen; while (1) { rt_thread_delay(RT_TICK_PER_SECOND); memset(&dest, 0, sizeof(dest)); dest.sin_len = sizeof(dest); dest.sin_family = AF_INET; dest.sin_addr.s_addr = addr_ser.addr; // 对方IP dest.sin_port = htons(10001); // 对方端口 sockClient = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (sockClient == -1) { // shutdown(sockClient, SHUT_RDWR); closesocket(sockClient); sockClient = -1; continue; } err = connect(sockClient, (struct sockaddr *)&dest, sizeof(dest)); if (err == -1) { // shutdown(sockClient, SHUT_RDWR); closesocket(sockClient); sockClient = -1; continue; } #if 0 { int optval; optval = 1; err = setsockopt(sockClient, IPPROTO_TCP, TCP_NODELAY, &optval, sizeof(optval) ); if (err == -1) { // shutdown(sockClient, SHUT_RDWR); closesocket(sockClient); sockClient = -1; continue; } } #endif // shutdown(sockClient, SHUT_RD); while (1) { rt_thread_delay(RT_TICK_PER_SECOND/200); memset(DatBuf, 0, sizeof(DatBuf)); sprintf(DatBuf, "TcpSendCnt:%d ", Cnt++); txlen = send(sockClient, DatBuf, sizeof(DatBuf), 0); if (txlen == 0) { break; } if ( txlen < 0 ) { // shutdown(sockClient, SHUT_RDWR); closesocket(sockClient); sockClient = -1; break; } if ((Cnt % 5000) == 0) { rt_kprintf("tcp client cnt=%d ", Cnt); // closesocket(sockClient); // sockClient = -1; // break; } } } }``` ![tcptt.jpg](https://oss-club.rt-thread.org/uploads/2953_123a4ee02638f28764264a8ea0921735.jpg) 下载附件 [port.rar](https://oss-club.rt-thread.org/uploads/2953_3108b1253ce338fbed9498bc2d768827.rar)
查看更多
14
个回答
默认排序
按发布时间排序
bernard
2011-03-10
这家伙很懒,什么也没写!
关于lwip TCP速度调优是一门学问,只能不停的试
kf118
2011-03-10
这家伙很懒,什么也没写!
多谢版主,只是这个调试 主要从那几个方面着手呢, 总不能盲目的。。。。 我查了一些资料 也包括 一些涉及到TCP通信的调试,但是感觉用到这里就失效了。 看来 还得下点功夫了 呵呵。
kf118
2011-03-10
这家伙很懒,什么也没写!
以前的应用 都是基于UDP的,所以TCP的通信一直没有测试 更加没有去用了, 以前的环境是LPC2214+8019 现在有时间了 想测试下TCP通信 结果 几种RTOS环境下 都是差不多 一样的情况 这个就伤了我的脑筋了。
bernard
2011-03-10
这家伙很懒,什么也没写!
你可以先加个netio测试下速度如何。
kf118
2011-03-10
这家伙很懒,什么也没写!
``` /** * This function should be called when a packet is ready to be read * from the interface. It uses the function low_level_input() that * should handle the actual reception of bytes from the network * interface. Then the type of the received packet is determined and * the appropriate input function is called. * * @param netif the lwip network interface structure for this ethernetif */ void ethernetif_input (struct netif *netif) { struct pbuf *p; err_t ucErr; do { p = low_level_input(netif); // 读取一帧数据 if (p != NULL) { // 为空? ucErr = netif->input(p, netif); // 向LWIP中注入数据帧 if (ucErr == ERR_OK) { // 注入OK? IP_STATS_INC(link.recv); // } else { pbuf_free(p); // 注入不成功 释放RAM p = NULL; // } } else { break; // 申请不了RAM 退出? } } while (EMAC_RxGetProduce() != 0); // RX FIFO 中还有数据? ----这里加了就OK了 原来只想最后加的 没想到 还是这里的问题 } void emacTask (void *arg) { rt_err_t err; while (1) { err = rt_sem_take(EthSemRx, RT_WAITING_FOREVER); // 等待接收完成信号 if (err == RT_EOK) { // 接收到信号量? ethernetif_input(netif_ksz8041); // 正确收到完成信号 向LWIP注入数据 continue; // 继续等待 } LWIP_ASSERT("emac wait_rxsem fail", err != RT_EOK); } } ``` RTT非常好 哈哈 才接触2天 就发现 爱上啦。。。。。。
kf118
2011-03-10
这家伙很懒,什么也没写!
``` /******************************************************************************************************** * 功 能 : 测试TCP 向PC发数据 * 入 口 : * 返 回 : * 说 明 : ********************************************************************************************************/ char DatBuf[1450]; void TcpClientTask (void *arg) { int err; int Cnt = 0; int txlen; while (1) { rt_thread_delay(RT_TICK_PER_SECOND); memset(&dest, 0, sizeof(dest)); dest.sin_len = sizeof(dest); dest.sin_family = AF_INET; dest.sin_addr.s_addr = addr_ser.addr; // 对方IP dest.sin_port = htons(10001); // 对方端口 sockClient = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (sockClient == -1) { closesocket(sockClient); sockClient = -1; continue; } err = connect(sockClient, (struct sockaddr *)&dest, sizeof(dest)); if (err == -1) { closesocket(sockClient); sockClient = -1; continue; } #if 0 { int optval; optval = 1; err = setsockopt(sockClient, IPPROTO_TCP, TCP_NODELAY, &optval, sizeof(optval) ); if (err == -1) { closesocket(sockClient); sockClient = -1; continue; } } #endif while (1) { // rt_thread_delay(RT_TICK_PER_SECOND/500); memset(DatBuf, 0, sizeof(DatBuf)); sprintf(DatBuf, "TcpSendCnt:%d ", Cnt++); txlen = send(sockClient, DatBuf, sizeof(DatBuf), 0); if (txlen == 0) { break; } if ( txlen < 0 ) { closesocket(sockClient); sockClient = -1; break; } if ((Cnt % 5000) == 0) { rt_kprintf("tcp client cnt=%d ", Cnt); } } } } ``` 这个程序去掉了延时部分, 现在100M网络测试 可以到8% 然后 我再开2个PC PING 每个PING 间隔10MS 1300字节做死的PING LPC2478 下面包都不掉一个 调整TCP/IP优先级别 都是一样 看来RT-THREAD真的比较强大啊。 严重支持中。。。 LWIP 就是0.4.0中的文件 没动一个字 全默认配置。
kf118
2011-03-10
这家伙很懒,什么也没写!
不晓得图片能不能看到
kf118
2011-03-10
这家伙很懒,什么也没写!
这个版本的 也还没十分完善,就是刚才这个测试用的版本。 目前是在ZLG的24XX的板子上测试,我看测试一个晚上TCP有没有问题。 顺便 也测试下0.4.0.
bernard
2011-03-10
这家伙很懒,什么也没写!
不对啊,你的驱动写的方式并不是按照RT-Thread定的方式编写的。目前0.3.x/0.4.x上的lpc2478都没有以太网接口,能否按照RT-Thread定义的方式把驱动编写得规范些,并做相应的测试? 如果能够这样,就可以把你的代码提交到svn上了,在RT-Thread发布时也能够受惠于大家。
kf118
2011-03-10
这家伙很懒,什么也没写!
rt的规范 我还不是很懂,还在看手册, 等完善点再上传上来。 是不是看UART 那个 作为参考啊。
撰写答案
登录
注册新账号
关注者
0
被浏览
12.4k
关于作者
kf118
这家伙很懒,什么也没写!
提问
1
回答
7
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
7
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部