嵌入式技术论坛
直播中

h1654155275.5741

7年用户 1007经验值
私信 关注
[问答]

ec200T的4g模块的设备在运行一段时间后出现内存溢出的情况是为什么

简单描述下问题,我们用的是ec200T的4g模块,设备在现场运行的时候发现一段时间后会出现内存溢出的情况,后排查发现是在网络信号不稳定时at中的at_clnt线程申请了内存未释放如下图:

经过论坛大佬的指导,我们结合问题捋了一下at的代码,发现问题是这样出现的,离线情况下,at模块不知为何收到了1~2帧来自4g模块的数据,at模块接收到数据后通过at_clnt线程(client_parse函数)进行接收和解析,接收时就动态分配了内存,如果这时设备在线,那就会将动态分配的内存地址加入到接收链表中,可当前状态为离线,然后就直接return了,这就导致这块分配的内存无法被应用读取,也就无法被释放,下面是at_socket.c中对应的函数,请各位大佬帮忙看下,这块代码是否有问题;

回帖(1)

韩刚龙

2022-4-15 09:39:42
不知道你的 AT 组件是什么版本的,我的这部分代码如下所示,离线的时候已经把内存释放添加进去了。

下面的是 v2.0.4 或者最新版的AT组件的代码。你把你的 AT 组件的版本换成最新的再看一下。

/* rt-thread/components/net/at/at_socket/at_socket.c */

static void at_recv_notice_cb(struct at_socket *sock, at_socket_evt_t event, const char *buff, size_t bfsz)

{

    RT_ASSERT(buff);

    RT_ASSERT(event == AT_SOCKET_EVT_RECV);

    /* check the socket object status */

    if (sock->magic != AT_SOCKET_MAGIC || sock->state == AT_SOCKET_CLOSED)

    {

        rt_free((void *)buff);

        return;

    }

    /* put receive buffer to receiver packet list */

    rt_mutex_take(sock->recv_lock, RT_WAITING_FOREVER);

    if (at_recvpkt_put(&(sock->recvpkt_list), buff, bfsz) != RT_EOK)

    {

        rt_free((void *)buff);

        rt_mutex_release(sock->recv_lock);

        return;

    }

    rt_mutex_release(sock->recv_lock);

    rt_sem_release(sock->recv_notice);

    at_do_event_changes(sock, AT_EVENT_RECV, RT_TRUE);

}
举报

更多回帖

发帖
×
20
完善资料,
赚取积分