Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
heap_sem未初始化问题
发布于 2018-08-25 22:53:14 浏览:2788
订阅该版
函数rt_page_alloc中调用了以下函数: `rt_sem_take(&heap_sem, RT_WAITING_FOREVER);` 但是heap_sem尚未初始化,导致rt_sem_take函数以下行出现断言失败: ```c RT_ASSERT(rt_object_get_type(&sem->parent.parent) == RT_Object_Class_Semaphore); ``` 注: heap_sem唯一一处初始化在rt_system_heap_init函数中,但该函数是在vmm_entry中调用(未配置vmm).
查看更多
5
个回答
默认排序
按发布时间排序
aozima
2018-08-26
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
版本,BSP,代码位置。
漫漫朔雪
2018-08-26
这家伙很懒,什么也没写!
主线(master, 2018-08-13下载),`bsp\beaglebone`,出问题位置:`src\slab.c`的rt_page_alloc函数,以下行: ``` /* lock heap */ rt_sem_take(&heap_sem, RT_WAITING_FOREVER); ``` 这里heap_sem尚未初始化,导致rt_sem_take函数以下行出现断言失败: ``` RT_ASSERT(rt_object_get_type(&sem->parent.parent) == RT_Object_Class_Semaphore); ```
漫漫朔雪
2018-08-26
这家伙很懒,什么也没写!
rtconfig.h内容如下: ```c #ifndef RT_CONFIG_H__ #define RT_CONFIG_H__ /* Automatically generated file; DO NOT EDIT. */ /* RT-Thread Configuration */ /* RT-Thread Kernel */ #define RT_NAME_MAX 8 #define RT_ALIGN_SIZE 4 #define RT_THREAD_PRIORITY_32 #define RT_THREAD_PRIORITY_MAX 32 #define RT_TICK_PER_SECOND 100 #define RT_USING_OVERFLOW_CHECK #define RT_USING_HOOK #define RT_IDEL_HOOK_LIST_SIZE 4 #define IDLE_THREAD_STACK_SIZE 256 #define RT_USING_TIMER_SOFT #define RT_TIMER_THREAD_PRIO 4 #define RT_TIMER_THREAD_STACK_SIZE 512 #define RT_DEBUG /* Inter-Thread communication */ #define RT_USING_SEMAPHORE #define RT_USING_MUTEX #define RT_USING_EVENT #define RT_USING_MAILBOX #define RT_USING_MESSAGEQUEUE /* Memory Management */ #define RT_USING_MEMPOOL #define RT_USING_MEMHEAP #define RT_USING_SLAB #define RT_USING_HEAP /* Kernel Device Object */ #define RT_USING_DEVICE #define RT_USING_INTERRUPT_INFO #define RT_USING_CONSOLE #define RT_CONSOLEBUF_SIZE 128 #define RT_CONSOLE_DEVICE_NAME "uart" #define RT_USING_MODULE /* RT-Thread Components */ #define RT_USING_COMPONENTS_INIT #define RT_USING_USER_MAIN #define RT_MAIN_THREAD_STACK_SIZE 2048 #define RT_MAIN_THREAD_PRIORITY 10 /* C++ features */ #define RT_USING_CPLUSPLUS /* Command shell */ #define RT_USING_FINSH #define FINSH_THREAD_NAME "tshell" #define FINSH_USING_HISTORY #define FINSH_HISTORY_LINES 5 #define FINSH_USING_SYMTAB #define FINSH_USING_DESCRIPTION #define FINSH_THREAD_PRIORITY 20 #define FINSH_THREAD_STACK_SIZE 4096 #define FINSH_CMD_SIZE 80 #define FINSH_USING_MSH #define FINSH_USING_MSH_DEFAULT #define FINSH_ARG_MAX 10 /* Device virtual file system */ #define RT_USING_DFS #define DFS_USING_WORKDIR #define DFS_FILESYSTEMS_MAX 2 #define DFS_FILESYSTEM_TYPES_MAX 2 #define DFS_FD_MAX 16 #define RT_USING_DFS_ELMFAT /* elm-chan's FatFs, Generic FAT Filesystem Module */ #define RT_DFS_ELM_CODE_PAGE 936 #define RT_DFS_ELM_WORD_ACCESS #define RT_DFS_ELM_USE_LFN_3 #define RT_DFS_ELM_USE_LFN 3 #define RT_DFS_ELM_MAX_LFN 255 #define RT_DFS_ELM_DRIVES 2 #define RT_DFS_ELM_MAX_SECTOR_SIZE 512 #define RT_DFS_ELM_REENTRANT #define RT_USING_DFS_DEVFS #define RT_USING_DFS_ROMFS #define RT_USING_DFS_RAMFS #define RT_USING_DFS_UFFS #define RT_UFFS_ECC_MODE_3 #define RT_UFFS_ECC_MODE 3 /* Device Drivers */ #define RT_USING_DEVICE_IPC #define RT_PIPE_BUFSZ 512 #define RT_USING_SERIAL #define RT_USING_CAN #define RT_CAN_USING_HDR #define RT_USING_HWTIMER #define RT_USING_CPUTIME #define RT_USING_PIN #define RT_USING_MTD_NAND /* Using USB */ #define RT_USING_USB_HOST #define RT_USBH_MSTORAGE #define UDISK_MOUNTPOINT "/" #define RT_USING_USB_DEVICE #define RT_USBD_THREAD_STACK_SZ 4096 #define USB_VENDOR_ID 0x0FFE #define USB_PRODUCT_ID 0x0001 #define RT_USB_DEVICE_COMPOSITE #define RT_USB_DEVICE_CDC #define RT_USB_DEVICE_NONE #define RT_USB_DEVICE_MSTORAGE #define RT_USB_DEVICE_HID #define RT_USB_DEVICE_RNDIS #define RT_USB_DEVICE_ECM #define RT_USB_DEVICE_WINUSB #define RT_WINUSB_GUID "{6860DC3C-C05F-4807-8807-1CA861CC1D66}" #define RT_USB_MSTORAGE_DISK_NAME "flash0" #define RT_USB_DEVICE_HID_KEYBOARD #define RT_USB_DEVICE_HID_KEYBOARD_NUMBER 1 #define RT_USB_DEVICE_HID_MOUSE #define RT_USB_DEVICE_HID_GENERAL #define RT_USB_DEVICE_HID_GENERAL_OUT_REPORT_LENGTH 63 #define RT_USB_DEVICE_HID_GENERAL_IN_REPORT_LENGTH 63 #define RT_USB_DEVICE_HID_MEDIA /* POSIX layer and C standard library */ #define RT_USING_LIBC #define RT_USING_POSIX /* Network */ /* Socket abstraction layer */ #define RT_USING_SAL /* protocol stack implement */ #define SAL_USING_LWIP #define SAL_USING_POSIX #define SAL_PROTO_FAMILIES_NUM 4 /* light weight TCP/IP stack */ #define RT_USING_LWIP #define RT_USING_LWIP202 #define RT_LWIP_IGMP #define RT_LWIP_ICMP #define RT_LWIP_DNS #define RT_LWIP_DHCP #define IP_SOF_BROADCAST 1 #define IP_SOF_BROADCAST_RECV 1 /* Static IPv4 Address */ #define RT_LWIP_IPADDR "192.168.1.30" #define RT_LWIP_GWADDR "192.168.1.1" #define RT_LWIP_MSKADDR "255.255.255.0" #define RT_LWIP_UDP #define RT_LWIP_TCP #define RT_MEMP_NUM_NETCONN 8 #define RT_LWIP_PBUF_NUM 16 #define RT_LWIP_RAW_PCB_NUM 4 #define RT_LWIP_UDP_PCB_NUM 4 #define RT_LWIP_TCP_PCB_NUM 4 #define RT_LWIP_TCP_SEG_NUM 40 #define RT_LWIP_TCP_SND_BUF 8196 #define RT_LWIP_TCP_WND 8196 #define RT_LWIP_TCPTHREAD_PRIORITY 10 #define RT_LWIP_TCPTHREAD_MBOX_SIZE 8 #define RT_LWIP_TCPTHREAD_STACKSIZE 1024 #define RT_LWIP_ETHTHREAD_PRIORITY 12 #define RT_LWIP_ETHTHREAD_STACKSIZE 1024 #define RT_LWIP_ETHTHREAD_MBOX_SIZE 8 #define LWIP_NETIF_STATUS_CALLBACK 1 #define SO_REUSE 1 #define LWIP_SO_RCVTIMEO 1 #define LWIP_SO_SNDTIMEO 1 #define LWIP_SO_RCVBUF 1 #define LWIP_NETIF_LOOPBACK 0 /* Modbus master and slave stack */ /* AT commands */ /* VBUS(Virtual Software BUS) */ /* Utilities */ /* RT-Thread online packages */ /* IoT - internet of things */ /* Wi-Fi */ /* Marvell WiFi */ /* Wiced WiFi */ /* security packages */ /* language packages */ /* multimedia packages */ /* tools packages */ /* system packages */ #define PKG_USING_GUIENGINE #define PKG_USING_GUIENGINE_V200 #define GUIENGINE_NAME_MAX 16 #define GUIENGINE_USING_TTF #define GUIENGINE_TTF_UTF8 #define GUIENG_USING_FNT_FILE #define GUIENGINE_USING_FONT16 #define GUIENGINE_USING_FONT12 #define GUIENGINE_USING_FONTHZ #define GUIENGINE_USING_HZ_FILE #define GUIENGINE_IMAGE_XPM #define GUIENGINE_USING_JPG #define GUIENGINE_IMAGE_TJPGD #define GUIENGINE_USING_PNG #define GUIENGINE_IMAGE_LODEPNG #define GUIENGINE_IMAGE_BMP #define GUIENGINE_IMAGE_CONTAINER #define GUIENGINE_USING_DEMO /* peripheral libraries and drivers */ /* miscellaneous packages */ /* sample package */ /* example package: hello */ #define RT_USING_UART1 #endif ```
bernard
2018-08-26
这家伙很懒,什么也没写!
确保slab作为heap已经初始化了
漫漫朔雪
2018-09-09
这家伙很懒,什么也没写!
好的,谢谢bernard
撰写答案
登录
注册新账号
关注者
0
被浏览
2.8k
关于作者
漫漫朔雪
这家伙很懒,什么也没写!
提问
10
回答
26
被采纳
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
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
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
I2C_IIC
ESP8266
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
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
8
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
7
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
张世争
1
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
2
次点赞
Ghost_Girls
1
篇文章
6
次点赞
YZRD
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部