Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
easyflash作为ulog后端输出,在CmBacktrace中使用的注意点
发布于 2019-04-29 11:16:30 浏览:2236
订阅该版
1. 如题,我使用外部的W25Q128作为easyflash的存储,并已使用env配置ulog为异步输出,可以将ulog_example例程的运行结果保存到flash中,但是运行除零错误和对齐错误时在 CmBacktrace中无法正常输出,结果如下: ![cmb_test.png](/uploads/201904/29/105203zw4fzmzvzibwqfmq.png) **原因分析:** 由于我开启了SPI的DMA发送模式,而该模式下会有现成挂起等待,发生Hard Fault时是 不允许执行线程挂起操作的。 **解决办法:** 关闭SPI的DMA模式。测试结果如图: ![ulog_out.png](/uploads/201904/29/105203zhh283jj02h32z0b.png) 2.不要打开timestamp format for time功能,否则可能导致输出的堆栈调用信息不正确: ![ulog_timestamp.png](/uploads/201904/29/105204vu9cpa1ucca3a4pt.png) 具体原因还没有深入研究,可能timestamp format for time功能会影响错误现场的**函数调用栈**吧。 有谁知道的请解释一下。
查看更多
6
个回答
默认排序
按发布时间排序
z843757475
2019-07-31
这家伙很懒,什么也没写!
你好 你是怎么保存的 通过文件系统吗
flyboy
2019-07-31
Do my self();
在 cmd_port.c 文件里有下面的一段代码,可能是这里的问题。可以尝试改一下里面的偏移量 4*9/4*10 ``` /* the PSP is changed by RT-Thread HardFault_Handler, so restore it to HardFault context */ #if (defined (__VFP_FP__) && !defined(__SOFTFP__)) || (defined (__ARMVFP__)) || (defined(__ARM_PCS_VFP) || defined(__TARGET_FPU_VFP)) cmb_set_psp(cmb_get_psp() + 4 * 10); #else cmb_set_psp(cmb_get_psp() + 4 * 9); #endif ```
armink
2019-07-31
这家伙很懒,什么也没写!
“SPI的DMA发送模式,而该模式下会有现成挂起等待” :DMA 的时候尽可能使用 busy_wait ,轮训等待,而不要阻塞线程会更好些 时间戳的问题,我这里是好使的,确认下你那边的 CmBacktrace 是最新版吗 [attach]9811[/attach]
z843757475
2019-08-05
这家伙很懒,什么也没写!
你好 我开启了 ulog_easyflash 然后运行ulog_example 并没有发现有存储到flash 是哪里需要设置吗 我把保存的开始地址也设置了
yaomo718
2019-11-25
这家伙很懒,什么也没写!
>你好 我开启了 ulog_easyflash 然后运行ulog_example 并没有发现有存储到flash 是哪里需要设置吗 我把保存 ... --- 不好意思,最近没怎么上。你的问题解决了吗? 主要是easyflash里打开LOG:Save logs on flash,并设置flash的存储空间大小。 然后ulog配置项里会出现Enable the flash backend for ulog这一选项,确认一下是否打开就好了。
yaomo718
2019-11-28
这家伙很懒,什么也没写!
[i=s] 本帖最后由 yaomo718 于 2019-11-28 23:44 编辑 [/i] >“SPI的DMA发送模式,而该模式下会有现成挂起等待” :DMA 的时候尽可能使用 busy_wait ,轮训等待,而不要 ... --- 之前困扰我的问题今天又有新的进展了。我是用的是最新的CmBacktrace 和 ulog,在野火429核心板上进行的测试。 今天重新建立工程,一点点的添加模块和代码,发现最新的drv_rtc.c文件里有添加这么一段代码: ``` #ifndef HAL_RTCEx_BKUPRead #define HAL_RTCEx_BKUPRead(x1, x2) (~BKUP_REG_DATA) #endif #ifndef HAL_RTCEx_BKUPWrite #define HAL_RTCEx_BKUPWrite(x1, x2, x3) #endif #ifndef RTC_BKP_DR1 #define RTC_BKP_DR1 RT_NULL #endif ``` 因为这段代码屏蔽了一些库函数,如**HAL_RTCEx_BKUPRead**,导致一只提示"RTC hasn't been configured, please use
command to config.",所以我把它给屏蔽了,结果发现 CmBacktrace 输出的堆栈调用信息不正确。经反复测试,确定该问题。 只是为什么还没搞清楚!
撰写答案
登录
注册新账号
关注者
0
被浏览
2.2k
关于作者
yaomo718
这家伙很懒,什么也没写!
提问
8
回答
83
被采纳
0
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
最近的调程序总结
3
晕掉了,这么久都不见layer2的踪影啊
4
继续K9ii的历程
5
[GUI相关] FreeType 2
6
[GUI相关]嵌入式系统中文输入法的设计
7
20081101 RT-Thread开发者聚会总结
8
嵌入式系统基础
9
linux2.4.19在at91rm9200 上的寄存器设置
10
[转]基于嵌入式Linux的通用触摸屏校准程序
推荐文章
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
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
2
GD32F450 片内 flash驱动适配
3
STM32H7R7运行CherryUSB
4
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
5
使用RC522软件包驱动FM1722
热门标签
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
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部