Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Network
LWIP协议栈测试中遇到pbuf_free出断言的问题
发布于 2017-08-17 00:19:09 浏览:3948
订阅该版
【问题描述】: 设备的程序作为TCP服务端,将一些信息上报上位机,每秒钟上报数据量大约有10KBYTE,上位机有一个TCP客户端的软件,负责接收服务端上报的数据,长时间可靠性测试过程中,在代码如下位置调用pbuf_free出现p = NULL的断言。 ```ip_input(struct pbuf *p, struct netif *inp) { struct ip_hdr *iphdr; struct netif *netif; u16_t iphdr_hlen; u16_t iphdr_len; #if IP_ACCEPT_LINK_LAYER_ADDRESSING int check_ip_src=1; #endif /* IP_ACCEPT_LINK_LAYER_ADDRESSING */ #if IP_NAT extern u8_t ip_nat_input(struct pbuf *p); extern u8_t ip_nat_out(struct pbuf *p); #endif IP_STATS_INC(ip.recv); snmp_inc_ipinreceives(); /* identify the IP header */ iphdr = (struct ip_hdr *)p->payload; if (IPH_V(iphdr) != 4) { LWIP_DEBUGF(IP_DEBUG | LWIP_DBG_LEVEL_WARNING, ("IP packet dropped due to bad version number %"U16_F" ", IPH_V(iphdr))); ip_debug_print(p); pbuf_free(p);// 出错时,p为NULL IP_STATS_INC(ip.err); IP_STATS_INC(ip.drop); snmp_inc_ipinhdrerrors(); return ERR_OK; }``` 从代码的字面意思理解,应该是这个包IP头数据有问题,但是不明白p指针怎么回事NULL呢,并且释放之前也没有去判断是不是NULL??? 不知道具体原因,可能还需要抓包看一下,但是这个地方是不是可以直接改一下,改成 if(p != NULL)pbuf_free(p)呢? ![0817_3.jpg](https://oss-club.rt-thread.org/uploads/10093_6ec8101f5e32bd544a2c5ff63cdc4c3d.jpg) ![0817_4.jpg](https://oss-club.rt-thread.org/uploads/10093_e32e62f44e51b3c0fc75876fd8deb335.jpg)
查看更多
5
个回答
默认排序
按发布时间排序
aozima
2017-08-17
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
在 pbuf_free(p) 之前,还对 p 有多次引用。 要加的话,也需要在更前面加。 这里可以更深入分析下,看为什么会有空指针传入,问题应该在更上层就产生了。
zhanglei23941@f
2017-08-17
这家伙很懒,什么也没写!
tcpip_thread(void *arg) { struct tcpip_msg *msg; LWIP_UNUSED_ARG(arg); if (tcpip_init_done != NULL) { tcpip_init_done(tcpip_init_done_arg); } LOCK_TCPIP_CORE(); while (1) { /* MAIN Loop */ UNLOCK_TCPIP_CORE(); LWIP_TCPIP_THREAD_ALIVE(); /* wait for a message, timeouts are processed while waiting */ sys_timeouts_mbox_fetch(&mbox, (void **)&msg); LOCK_TCPIP_CORE(); switch (msg->type) { #if LWIP_NETCONN case TCPIP_MSG_API: LWIP_DEBUGF(TCPIP_DEBUG, ("tcpip_thread: API message %p ", (void *)msg)); msg->msg.apimsg->function(&(msg->msg.apimsg->msg)); break; #endif /* LWIP_NETCONN */ #if !LWIP_TCPIP_CORE_LOCKING_INPUT case TCPIP_MSG_INPKT: LWIP_DEBUGF(TCPIP_DEBUG, ("tcpip_thread: PACKET %p ", (void *)msg)); #if LWIP_ETHERNET if (msg->msg.inp.netif->flags & (NETIF_FLAG_ETHARP | NETIF_FLAG_ETHERNET)) { ethernet_input(msg->msg.inp.p, msg->msg.inp.netif); } else #endif /* LWIP_ETHERNET */ { ** ip_input(msg->msg.inp.p, msg->msg.inp.netif);** } memp_free(MEMP_TCPIP_MSG_INPKT, msg); break; #endif /* LWIP_TCPIP_CORE_LOCKING_INPUT */ 当出现问题时,代码会从红色的代码进入ip_input,正常会进入ethernet_input,数据抓包没有发现异常,但是发现了下面的问题,指针p的值为零,是因为局部变量指针msg的值变了,由正常的0x68000eec变成了出问题时的0x200080c0,这个地址是一个线程栈空间的一个地址,那个线程的栈空间为2K大小,地址范围0x20007a84~0x20008283..。出问题时msg和mbox的如下两图所示: [attach]2812[/attach] [attach]2811[/attach] 于是去看代码,msg的值是怎么来的,是在tcpip_thread中,调用函数sys_timeouts_mbox_fetch(&mbox, (void **)&msg)时,从mbox中获取到的,在rt_mb_recv()函数中有如下的代码, *value = mb->msg_pool[mb->out_offset]; 这里的value就是msg的指针。也就是说,是由于mbox->msg_pool中存入的地址不对导致的,或者说,msg_pool中的内容被异常改掉了,现在再往下查也不知道该怎么查了,如果是msg_pool所在的内存被异常踩到了,那怎么去查是谁踩的呢,有什么方法吗?
silverz
2017-08-22
这家伙很懒,什么也没写!
楼主,pbuf_free里就有p== NULL的判断啊,如果为NULL就返回0,为何还会异常。这和外面加判断有区别吗?
zhanglei23941@f
2017-08-23
这家伙很懒,什么也没写!
楼上,不是异常,是出断言,pbuff_free里面是对p = NULL做了断言的处理了
撰写答案
登录
注册新账号
关注者
0
被浏览
3.9k
关于作者
zhanglei23941@f
这家伙很懒,什么也没写!
提问
5
回答
12
被采纳
0
关注TA
发私信
相关问题
1
lwip1.4.1连接经常会断开无法连接上,可以ping通
2
LPC1768:RTT+LWIP+webserver用IE刷网页出现硬件中断错误(已经解决)
3
求一些LWIP开发的经验,目前ping一直不稳定。
4
stm32f207+dp83848无法ping通
5
RTT下的LWIP传递机制
6
rtt内lwip的socket是否是线程安全?
7
Lwip+enc28j60无法ping通
8
坑爹的rtconfig.h lwip关掉了checksum
9
花了一个晚上,把RT2.0的LWIP、网卡驱动、文件系统整合起来了,发现一点小问题
10
lwip例程中udp发送时如何指定源端口发送到指定目的地端口
推荐文章
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 Studio V2.2.9 Release Note
2
CherryUSB的bootuf2配置
3
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
4
GD32F450 片内 flash驱动适配
5
STM32H7R7运行CherryUSB
热门标签
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
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
踩姑娘的小蘑菇
7
个答案
2
次被采纳
a1012112796
12
个答案
1
次被采纳
Ryan_CW
5
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
lizimu
2
篇文章
7
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部