Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Network
内存泄漏leak
20
内存泄露导致崩溃的问题
发布于 2020-06-30 23:32:33 浏览:2206
订阅该版
4g模块AIR720标准驱动+MYMQTT,用的是AT_DEVICE组件直接连的,没有用PPP组件,联网后时间长了就会导致内存溢出,短时间看不出来,尤其把天线拔下来去掉手机卡强制设备重联(重联使用的是网卡的SET DOWN,SET UP接口),运行几天就会出现内存占用越来越多无法释放,看起来应该是系统不断重联,每次重联内存释放不干净所致,谁有这方面经验可以解决。这样的结果最后就崩溃了死机了,崩溃时提示: ``` assertion failed at function:rt_mutex_take [23:29:40.881]收←◆unction[rt_malloc] shall not be used in ISR thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- mqttt0 20 suspend 0x00000168 0x00000a8c 62% 0x00000001 000 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。 timer 4 suspend 0x000000a8 0x00000200 32% 0x00000009 000 main 10 suspend 0x000000e4 0x000006bc 57% 0x0000000b 000 [31m06-20 23:29:39.527 E/cmb ISR: [0m[31m06-20 23:29:39.527 E/cmb ISR: (0) has assert failed at rt_malloc:280. [0m[31m06-20 23:29:39.527 E/cmb ISR: [0m[31m06-20 23:29:39.527 E/cmb ISR: Firmware name: testff, hardware version: v1.01, software version: v1.02 [0m[31m06-20 23:29:39.527 E/cmb ISR: Assert on thread at_clnt [0m[31m06-20 23:29:39.527 E/cmb ISR: ===== Thread stack information ===== [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009300 data: 0803f654 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009304 data: 0804bdc4 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009308 data: 00000118 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 2000930c data: 08001a8d [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009310 data: 0000002d [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009314 data: 00000118 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009318 data: 0804bdc4 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 2000931c data: 0803f654 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009320 data: 00000009 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009324 data: 01008af0 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009328 data: 20009330 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 2000932c data: 20008af0 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009330 data: 20009338 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009334 data: 080044a1 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009338 data: 014b2638 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 2000933c data: 00000118 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009340 data: 0804bdc4 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009344 data: 0803f654 [0m[31m06-20 23:29:39.527 E/cmb ISR: addr: 20009348 data: 0803f62c ``` 经过分析,这个崩溃是由at_clnt(AT CLIENT组件)线程导致的,经过仔细分析发现运行一段时候后(至少1天以上,短时时间内看不出来)有内存泄露,如图: ``` [0x20009b60 - 12] at_c [0x20009b7c - 20] mqtt [0x20009ba0 - 64] mqtt [0x20009bf0 - 24] [0x20009c18 - 628] at_c [0x20009e9c - 568] at_c [0x2000a0e4 - 64] mqtt [0x2000a134 - 48] mqtt [0x2000a174 - 64] mqtt [0x2000a1c4 - 60] at_c [0x2000a210 - 60] at_c [0x2000a25c - 28] mqtt [0x2000a288 - 1K] main [0x2000a698 - 1K] main [0x2000aaa8 - 56] main [0x2000aaf0 - 36] main [0x2000ab24 - 60] main [0x2000ab70 - 64] main [0x2000abc0 - 128] main [0x2000ac50 - 2K] main [0x2000b6ec - 36] Make [0x2000b720 - 44] Make [0x2000b75c - 36] Timi [0x2000b790 - 60] at_c [0x2000b7dc - 92] at_c [0x2000b848 - 64] [0x2000b898 - 32] mqtt [0x2000b8c8 - 36] mqtt [0x2000b8fc - 12] [0x2000b918 - 36] mqtt [0x2000b94c - 128] [0x2000b9dc - 64] mqtt [0x2000ba2c - 44] [0x2000ba68 - 44] Equi [0x2000baa4 - 44] Equi [0x2000bae0 - 44] Equi [0x2000bb1c - 568] at_c [0x2000bd64 - 568] at_c [0x2000bfac - 568] at_c [0x2000c1f4 - 2K] [0x2000ca04 - 64] mqtt ``` 里面明显看到at_c(也就是at_clnt)不断增多,而且不释放,就算后面正常联网了也不释放,这里推测,这里正常设备经常掉线重联导致内存泄露越来越多最后崩溃
查看更多
6
个回答
默认排序
按发布时间排序
JYFP_3506
2020-06-30
这家伙很懒,什么也没写!
用其他的4G模块也是一样有这个问题,使用的AT 组件版本和配置是: ```c #define PKG_USING_AT_DEVICE #define AT_DEVICE_USING_AIR720 #define AT_DEVICE_AIR720_INIT_ASYN #define AT_DEVICE_AIR720_SAMPLE #define AIR720_SAMPLE_POWER_PIN 16 #define AIR720_SAMPLE_STATUS_PIN -1 #define AIR720_SAMPLE_CLIENT_NAME "uart2" #define AIR720_SAMPLE_RECV_BUFF_LEN 512 #define PKG_USING_AT_DEVICE_LATEST_VERSION #define PKG_AT_DEVICE_VER_NUM 0x99999 #define RT_USING_AT #define AT_USING_CLIENT #define AT_CLIENT_NUM_MAX 1 #define AT_USING_SOCKET #define AT_USING_CLI #define AT_CMD_MAX_LEN 128 #define AT_SW_VERSION_NUM 0x10300 ``` 那个崩溃提示,表面看起来是在中断内调用rt_mutex_take,但是实际上看了代码程序里面所有中断都没有调用rt_mutex_take,如果调用的话早就崩溃了,不可能运行5,6天才崩溃
JYFP_3506
2020-06-30
这家伙很懒,什么也没写!
有时候崩溃提示下面的内容: ``` Function[rt_mutex_take] shall not be used in ISR thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- sim0_li 10 suspend 0x000000d8 0x0000052c 80% 0x00000004 000 mqttt0 20 suspend 0x0000016c 0x00000a8c 73% 0x00000002 000 at_clnt 9 suspend 0x00000104 0x00000600 72% 0x00000005 000 ................................................. .............................................. timer 4 suspend 0x000000a8 0x00000200 32% 0x00000009 000 main 10 suspend 0x000000e0 0x000006bc 60% 0x00000001 000 [31m05-19 04:43:09.053 E/cmb ISR: [0m[31m05-19 04:43:09.053 E/cmb ISR: (0) has assert failed at rt_mutex_take:662. [0mtotal memory: 47020 used memory : 38108 maximum allocated memory: 38188 [31m05-19 04:43:09.053 E/cmb ISR: [0m[31m05-19 04:43:09.053 E/cmb ISR: Firmware name: testff, hardware version: v1.01, software version: v1.02 [0m[31m05-19 04:43:09.053 E/cmb ISR: Assert on thread Communic [0m[31m05-19 04:43:09.053 E/cmb ISR: ===== Thread stack information ===== [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d88 data: 08040abc [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d8c data: 0804dccc [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d90 data: 00000296 [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d94 data: 08001a8d [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d98 data: 00000031 [0m[31m05-19 04:43:09.053 E/cmb ISR: addr: 20008d9c data: 00000296 ```
踩姑娘的小蘑菇
2020-07-01
这家伙很懒,什么也没写!
[http://packages.rt-thread.org/detail.html?package=kawaii-mqtt](KAWAII-MQTT) 这个mqtt软件包好用,官方的umqtt也好用,但功能还不完善
Cheney_Chen
2020-07-02
这家伙很懒,什么也没写!
1. `Function[rt_mutex_take] shall not be used in ISR` 确定是否开始了软件定时器功能支持 2. 因为涉及到 at_device 和 mymqtt 软件包,所以不太确定是那个软件包导致的重连的时候内存泄露,建议单独测试功能; 3. 建议单独使用 at_device 软件包,编写简单的网卡 UP 和 DOWM 操作测试接口,多次调用后看是否存在内存泄露问题;单独测试 mymqtt 软件包重连功能是是否存在内存泄露问题;
红枫
认证专家
2020-08-05
这家伙很懒,什么也没写!
### at_device_air720.c文件air720_netdev_add函数中,在 ```c RT_ASSERT(netdev_name); ``` ### 下面加入代码 ```c netdev = netdev_get_by_name(netdev_name); if (netdev != RT_NULL) { return (netdev); } ``` ### 应该就能解决问题。
fhqmcu
认证专家
2020-08-12
个人博客:https://blog.csdn.net/fhqlongteng
at组件使用4G模块联网,已经在正式产品上使用过,组件未发现有内存泄漏的。应用层程序使用过非阻塞socket编程的示例程序,这段程序有内存泄漏的代码,修改后就可以。
撰写答案
登录
注册新账号
关注者
0
被浏览
2.2k
关于作者
JYFP_3506
这家伙很懒,什么也没写!
提问
13
回答
9
被采纳
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
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
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
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
张世争
8
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
a1012112796
13
个答案
1
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部