Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
AT
EC20
堆_heap_动态内存管理
ec20的AT驱动导致内存泄漏?
发布于 2021-11-16 17:29:03 浏览:1559
订阅该版
[tocm] ## 问题现象 ec20使用at驱动下载文件,有的时候导致stm32内存爆满。且内存无法回收,一直会持续到下次重启。 之前发布过一次ec20下载大文件会导致stm32内存爆满的问题。一直以为是写文件的速度不够快,导致内存被全部申请,但查看底层代码之后,发现关闭client的时候最终会释放申请的内存。所以这不是导致本次问题的原因。 ## 问题分析 * 1. 在下载文件开始时,打印出来的urc中connectid为1. * 2. 下载文件过程中,由于某些原因(暂时判断为硬件原因),单片机没有收到ec20下发的数据,到了一定时间后,驱动会返回超时,从而关闭下载文件的client。 * 3. 但是过了几秒后,ec20又开始下发,connectid为1的urc,驱动层又开始不断的申请内存。导致内存爆满,此时已经无法再释放内存了。 下载文件函数部分代码(删除了没必要的部分) ```c int webclient_get_file(const char* URI, const char* filename) { session = webclient_session_create(WEBCLIENT_HEADER_BUFSZ); fd = open(filename, O_WRONLY | O_CREAT | O_TRUNC, 0); if (session->content_length < 0) { while (1) { length = webclient_read(session, ptr, WEBCLIENT_RESPONSE_BUFSZ); if (length > 0) { write(fd, ptr, length); total_length += length; LOG_RAW(">"); } else { break; } } } close(fd); webclient_close(session); web_free(ptr); } ``` 关闭socket源代码 ```c /** * close socket by AT commands. * * @param current socket * * @return 0: close socket success * -1: send AT commands error * -2: wait socket event timeout * -5: no memory */ static int ec20_socket_close(struct at_socket *socket) { int result = RT_EOK; at_response_t resp = RT_NULL; int device_socket = (int) socket->user_data; struct at_device *device = (struct at_device *) socket->device; resp = at_create_resp(64, 0, 5 * RT_TICK_PER_SECOND); if (resp == RT_NULL) { LOG_E("no memory for resp create."); return -RT_ENOMEM; } /* default connection timeout is 10 seconds, but it set to 1 seconds is convenient to use.*/ result = at_obj_exec_cmd(device->client, resp, "AT+QICLOSE=%d,1", device_socket); if (resp) { at_delete_resp(resp); } return result; } ``` ## 结论 由于电平转换电路存在问题。在发送关闭socket的at指令时,ec20没有收到。导致上层webclient已经关闭,但ec20又继续下发connectid为1的urc,这时申请的内存无人释放。 在关闭socket的函数中,是否需要判断resp的内容,或者是加一些其他的逻辑来保护。 ```c if (resp) { at_delete_resp(resp); } ```
查看更多
1
个回答
默认排序
按发布时间排序
xiangxistu
2021-11-17
这家伙很懒,什么也没写!
关闭的 connectid 里面出现了数据,那么对应的`at_device->sockets[connectid]`应当为空,这时候尽快到了 `at_recv_notice_cb` 中,也会因为对应的 sockets 已经被`close<状态清空, magic 对不上>`而被删除,不会有挂载到数据链上的机会,应用层就更不会有机会得到数据了。 ---- 驱动里没有将 `at_recv_notice_cb` 这个回调入口重新注册为 NULL 的步骤;讲道理,不会在 close 后,出现新到达数据,导致无法处理而引起的内存泄漏问题。 * 有且仅有 at socket 没有使用,即 socket 接口未申请时,模块端传来 connectid 数据,会出现内存泄漏。不过这个逻辑本身就不正常。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.6k
关于作者
忧伤还是快乐
这家伙什么也没写,不是懒
提问
17
回答
7
被采纳
0
关注TA
发私信
相关问题
1
rt-thread 2g/3g/4g通信模块的教程有吗?
2
基于AT指令,用esp8266如何连接mqtt?
3
AT组件使用问题
4
官方AT客户端应用笔记的几个小tip
5
RTT的SAL能够判断使用LWIP或者AT?
6
rt_therad AT组件移植不成功(结贴)
7
AT组件在哪个版本的?
8
AT组件 连接 Onenet 连接失败
9
esp8266 AT指令 MQTT连接问题
10
AT组件使用问题之模块主动上报【已解决】
推荐文章
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项目助手v0.2.0 - 支持Env Windows
2
RttreadV5.10上,GD32F450Z RTC时间显示问题
3
rt-smart启动流程分析
4
EtherKit快速上手PROFINET
5
RTThread USB转串口无法接收数据
热门标签
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
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部