Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
rt_malloc多次分配后失败
发布于 2016-11-17 18:07:16 浏览:4120
订阅该版
在使用rt_malloc分配10次都可以,后面分配就失败了 但是用list_mem查看内存貌似还有很多,这种情况一般是什么原因导致的,CPU的RAM是64K的 ``` | / - RT - Thread Operating System / | 2.1.0 build Nov 17 2016 2006 - 2015 Copyright by rt-thread team finsh>>W25Q128BV detection flash0 mount to /. finsh>>list_mem() total memory: 59760 used memory : 7268 maximum allocated memory: 7268 0, 0x00000000 finsh>>mem_test(12) no mem 0, 0x00000000 finsh>>``` 跟踪到rt_malloc内部,发现mem->used的值为0xFFFF ```for (ptr = (rt_uint8_t *)lfree - heap_ptr; ptr < mem_size_aligned - size; ptr = ((struct heap_mem *)&heap_ptr[ptr])->next) { mem = (struct heap_mem *)&heap_ptr[ptr]; if ((!mem->used) && (mem->next - (ptr + SIZEOF_STRUCT_MEM)) >= size) { /* mem is not used and at least perfect fit is possible: * mem->next - (ptr + SIZEOF_STRUCT_MEM) gives us the 'user data size' of mem */ if (mem->next - (ptr + SIZEOF_STRUCT_MEM) >= (size + SIZEOF_STRUCT_MEM + MIN_SIZE_ALIGNED))``` ![mem.png](https://oss-club.rt-thread.org/uploads/9774_835a34300063ed88222998cff8879e22.png)
查看更多
7
个回答
默认排序
按发布时间排序
bernard
2016-11-17
这家伙很懒,什么也没写!
是否是哪里有内存越界了
aozima
2016-11-17
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
看到用了FLASH的FAT文件系统,需要定义最大扇区支持到4K。 rtconfig.h ``` #define RT_DFS_ELM_MAX_SECTOR_SIZE 4096 ``` 如果已经这样定义了,再继续查其它地方。
bernard
2016-11-17
这家伙很懒,什么也没写!
>看到用了FLASH的FAT文件系统,需要定义最大扇区支持到4K。 > >rtconfig.h > > >``` >#define RT_DFS_ELM_MAX_SECTOR_SIZE 4096 >``` > > > >如果已经这样定义了,再继续查其它地方。 --- 这你都能看得出来啊,b( ̄▽ ̄)d
new_os
2016-11-18
这家伙很懒,什么也没写!
这个已经是定义了的页面大小,确实加载了elm文件系统,mkfs提示成功,挂载文件系统成功 测试mkdir时出错,跟踪进去发现是内存分配失败,CPU是GD32F103,64K内存,现在没有加载很多程序,堆内存才分配了2K多 用list_thread看堆栈貌似没有溢出 ``` | / - RT - Thread Operating System / | 2.1.0 build Nov 18 2016 2006 - 2015 Copyright by rt-thread team finsh>>W25Q128BV detection flash0 mount to /. finsh>>mkdir("/my_dir") -1, 0xffffffff finsh>>list_thread() thread pri status sp stack size max used left tick error -------- ---- ------- ---------- ---------- ---------- ---------- --- tidle 0x1f ready 0x00000050 0x00000100 0x00000050 0x0000001b 000 tshell 0x14 ready 0x0000008c 0x00000400 0x000002a8 0x00000006 000 init 0x1d ready 0x00000088 0x00000400 0x00000208 0x00000012 -02 0, 0x00000000 finsh>> ``` init线程错误代码是-2,线程貌似又可以运行,这个是什么错误? ``` /* SECTION: DFS???????? */ #define RT_USING_DFS #define RT_USING_DFS_ELMFAT /* ?????????¨????°???????FatFs???é */ #define RT_DFS_ELM_REENTRANT /* ?????????í?¨?????????÷?????????? */ #define RT_DFS_ELM_DRIVES 1 #define RT_DFS_ELM_USE_LFN 0 #define RT_DFS_ELM_CODE_PAGE 437 #define RT_DFS_ELM_MAX_LFN 255 /* ?????í??×??ó?????ó?? */ #define RT_DFS_ELM_MAX_SECTOR_SIZE 4096 /* °?×°????????????×??ó???? */ #define DFS_FILESYSTEMS_MAX 1 /* ?ò????????×??ó???? */ #define DFS_FD_MAX 4 ```
new_os
2016-11-18
这家伙很懒,什么也没写!
经过程序跟踪,发现确实是自己代码问题,分配了一块内存,分配后做了4字节地址对齐操作,多分配8个字节做地址对齐就OK了,感谢“bernard ”及“aozima ”
bernard
2016-11-18
这家伙很懒,什么也没写!
这个东西还是得自己多调试,如果是100%复现的,这个倒是容易,特别是配合一些数据写断点,还是比较容易把内存越界的问题给找出来
撰写答案
登录
注册新账号
关注者
0
被浏览
4.1k
关于作者
new_os
这家伙很懒,什么也没写!
提问
3
回答
7
被采纳
0
关注TA
发私信
相关问题
1
请教cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
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
【NXP-MCXA153】 定时器驱动移植
2
GD32F450 看门狗驱动适配
3
【NXP-MCXA153】看门狗驱动移植
4
RT-Thread Studio V2.2.9 Release Note
5
CherryUSB的bootuf2配置
热门标签
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
15
个答案
1
次被采纳
Ryan_CW
5
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
本月文章贡献
YZRD
3
篇文章
6
次点赞
catcatbing
3
篇文章
6
次点赞
lizimu
2
篇文章
7
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部