Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
mo动态模块_Module
mo动态模块_Module
30
动态模块使用的疑惑,动态模块的子线程,mo文件运行一段时间后死机
发布于 2020-10-21 17:34:01 浏览:1576
订阅该版
在F4上面使用动态模块,按照教程做相应的配置,修改好链接脚本啥的, 最后msh下执行list_symbols可以看到所有的函数符号。 然后开始编写app模块 代码大致如下 ```c #include
#include
#include
#include "controller.h" static void thread_entry(void* parameter) { uint32_t index = 0; rt_thread_t now; struct tm* tm; time_t time_int; now = rt_thread_self(); rt_kprintf("this is app :%s\n",now->name); while (1) { time_int = time(RT_NULL); tm = localtime(&time_int); rt_kprintf("time %d %d %d\n",tm->tm_hour,tm->tm_min,tm->tm_sec); rt_thread_mdelay(30000); } } int main(int argc, char *argv[]) { rt_thread_t now; now = rt_thread_self(); rt_kprintf("this is app :%s\n",now->name); rt_kprintf("run %s\n",now->name); now = rt_thread_create("thread1",thread_entry, (void*)1,2048,22, 10); if (now != RT_NULL) rt_thread_startup(now); while(1) { read_wirte_data(); rt_thread_mdelay(300); } return 0; } ``` 运行效果正常一直在输出时间,但是msh下执行ps只能看到main所属的线程名字叫做rttapp(这是编译模块rttapp.mo的名字),却没有看到thread1线程的状态,但是这连个线程却在运行。 然后过了N久之后thread1线程突然因为pc地址错误而死机,效果如下: ``` psr: 0x21000000 r00: 0x0020019f r01: 0x08083ae4 r02: 0x00000002 r03: 0x00000003 r04: 0x00000002 r05: 0x200013bc r06: 0x08083ae4 r07: 0x20001200 r08: 0x20000c20 r09: 0x20024504 r10: 0x00000000 r11: 0x000007e0 r12: 0x00000190 lr: 0x08063a21 pc: 0x0805d918 hard fault on thread: thread1 thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- rttapp2 31 suspend 0x00000108 0x00000800 21% 0x00000006 000 tshell 12 suspend 0x00000184 0x00001000 30% 0x00000008 000 ntp_sync 26 suspend 0x000000a8 0x00000600 80% 0x00000002 000 sys_work 23 suspend 0x00000088 0x00000800 52% 0x0000000a 000 tidle0 31 ready 0x00000054 0x00000400 13% 0x0000001f 000 timer 10 suspend 0x00000080 0x00000400 17% 0x0000000a 000 main 10 suspend 0x00000148 0x00000800 57% 0x0000000a 000 bus fault: SCB_CFSR_BFSR:0x82 PRECISERR SCB->BFAR:0020019F ``` pc所指的: 0x0805d918我查了map文件,并无次函数地址 求大佬能解答一下
查看更多
3
个回答
默认排序
按发布时间排序
aozima
2020-10-21
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
> 查了map文件,并无次函数地址 那得刚好死在函数第1条指令才行,不然肯定不在函数地址啊,而是在函数里面。 你应该查反汇编,看这个地址在哪个函数里面。
文武斌
2020-10-22
这家伙很懒,什么也没写!
我重新编译后,运行了同样的程序,还是会过段时间就死机,然后我查了每次死机后的PC指针的范围 ``` psr: 0x21000000 r00: 0x002008be r01: 0x08103e08 r02: 0x00000002 r03: 0x00000002 r04: 0x00000002 r05: 0x200013dc r06: 0x08103e08 r07: 0x20001200 r08: 0x20000c20 r09: 0x20023434 r10: 0x00000000 r11: 0x000007e0 r12: 0x00000190 lr: 0x080e3c21 pc: 0x080ddb18 hard fault on thread: thread1 thread pri status sp stack size max used left tick error -------- --- ------- ---------- ---------- ------ ---------- --- rttapp2 31 suspend 0x00000108 0x00000800 21% 0x00000003 000 tshell 12 suspend 0x00000184 0x00001000 23% 0x00000009 000 tidle0 31 ready 0x0000007c 0x00000400 13% 0x00000005 000 timer 10 suspend 0x00000080 0x00000400 17% 0x0000000a 000 main 10 suspend 0x00000148 0x00000800 60% 0x00000011 000 bus fault: SCB_CFSR_BFSR:0x82 PRECISERR SCB->BFAR:002008BE ``` 因为这个固件重新编译了,所以死机的PC跟上面发生了变化,但是大体上可以锁定了一个确定的位置,就是在这些库函数里面 ![QQ图片20201022104928.png](/uploads/20201022/c9d3a5c04bf5caea771fcd02f0a7afba.png)
XNXH_6023
2021-10-11
嵌入式、bsp、
楼主问题是否解决了? 我这边也是使用动态模块创建子线程遇到了同样的问题
撰写答案
登录
注册新账号
关注者
0
被浏览
1.6k
关于作者
文武斌
这家伙很懒,什么也没写!
提问
27
回答
74
被采纳
2
关注TA
发私信
相关问题
1
貌似stm32f10x的应用模块在1.2.x版本不能正常编译
2
应用模块打开之后unload之后还在内存中
3
关于module.c的_load_shared_object的疑问
4
应用模块的rt_module_unload函数的bug
5
rtt 如何实现动态加载app
6
使用zmodem传输文件,应用模块文件传输完成,访问失败
7
RTT下应用模块编译具体方法
8
RTT应用模块编译出错
9
RTT应用模块编译问题
10
求问动态模块是什么意思呢
推荐文章
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
如何在master上的BSP中添加配置yml文件
2
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
3
RT-Thread 发布 EtherKit开源以太网硬件!
4
rt-thread使用cherryusb实现虚拟串口
5
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
热门标签
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
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
14
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
13
个答案
1
次被采纳
本月文章贡献
程序员阿伟
9
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
RTT_逍遥
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部