Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
AT
EC20
堆_heap_动态内存管理
ec20的AT驱动导致内存泄漏?
发布于 2021-11-16 17:29:03 浏览:1422
订阅该版
[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.4k
关于作者
忧伤还是快乐
这家伙什么也没写,不是懒
提问
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
使用百度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
UART
ota在线升级
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
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
7
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
3
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部