Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
最近的调程序总结
发布于 2008-09-08 15:55:41 浏览:7142
订阅该版
最近工作中调程序,调得很累。 新的芯片,因为和以前的版本改动比较大,多核通信方式变了,电源管理变了,外设的寄存器地址基本都变了。抢时间,急急忙忙的把以前的大工程代码往上套,结果出了很多问题,很多很难查,很伤心很劳累。[还好只是调一个核,如果两个核一起套,真的得跳楼了] 这里总结一下,顺带想想,如果是在RT-Thread环境中,应该如何调比较好。 调试的过程中,以下问题出现比较多: - ASSERT,一般意义的assert也就算了,一般的assert总归有文件名,有行号,出现了进去一查就知道是哪个文件哪行出了问题,大不了在出现assert的地方断一个断点,然后看寄存器,反推出上一个调用函数的地方(RealView Debugger的栈回溯不可信的)。最关键的是,如果出现了assert,文件名和行号都被冲掉了怎么办?什么都看不到。 - 程序飞掉了。。。 - 数据冲掉了。。。 - Log不能打印 其中最难调的应该是程序飞掉了,而且还不知道是哪里飞掉了(当工程是一个百万级代码的工程时,这种感觉是很明显的) 方法: - 在OS切换到一个任务时,把任务的名字打印出来 - 当一个中断到来时,把中断号打印出来 因为有些中断是比较多的,所以在打印前可以做做过滤,例如os的timer中断。但系统的定时器一般是和os timer挂钩的,如果怀疑也可以打开。 通过这样,至少可以找出出现问题时,就近的上下文环境是什么,然后就去怀疑吧。 工作中用的是Nucleus Plus,OS切换到一个任务打印名称需要自己写,在它的汇编中。RT-Thread中,只需要把SCHEDULER_DEBUG宏打开就可以了。ASSERT的问题也可以参照这样的解决方法。 数据冲掉的问题,一般有两种情况: - 全局数据被冲,那么就找找全局数据地址附近有什么东西,很可能是越界访问了。 - 中断向量表被冲;ARM的向量表放在0地址,也就是NULL,谁操作了空指针呢?这个比较难查,猜吧。 Log不能打印 一般来说在 ISR 中是不能打印的,因为很可能打印log会引起另一个中断(这个是以前vxWorks一直嘱咐的)。可以考虑用非中断方式的打印,RT-Thread的串口打印默认是非中断方式。但有的时候在ISR中打印很可能会影响到整个系统的时序,所以也可以考虑把打印输出到一个buffer中,然后在一个空闲任务中打印出来;RT-Thread可以在idle thread中挂一个hook函数,在里面进行打印,不过如何做好任务间的同步是需要自己考虑好的。
查看更多
3
个回答
默认排序
按发布时间排序
bernard
2008-09-09
这家伙很懒,什么也没写!
>我们现在的做法是把任务切换,进入中断处理,进入深度睡眠时候的一些信息,包括系统计时等,输出到了一个buffer中,等系统Assert,或者手动Assert的时候就把这块buffer导出来成一个mem文件,然后用工具对这段mem文件进行分析,由此得到系统运行信息。 --- 类似的也有一个,但是要跨越到另外核上,所以这次整合把它给先砍掉了
shaolin
2008-09-09
这家伙很懒,什么也没写!
>Log不能打印 >一般来说在 ISR 中是不能打印的,因为很可能打印log会引起另一个中断(这个是以前vxWorks一直嘱咐的)。可以考虑用非中断方式的打印,RT-Thread >的串口打印默认是非中断方式。但有的时候在ISR中打印很可能会影响到整个系统的时序,所以也可以考虑把打印输出到一个buffer中,然后在一 >个空闲任务中打印出来;RT-Thread可以在idle thread中挂一个hook函数,在里面进行打印,不过如何做好任务间的同步是需要自己考虑好的。 我们现在的做法是把任务切换,进入中断处理,进入深度睡眠时候的一些信息,包括系统计时等,输出到了一个buffer中,等系统Assert,或者手动Assert的时候就把这块buffer导出来成一个mem文件,然后用工具对这段mem文件进行分析,由此得到系统运行信息。
撰写答案
登录
注册新账号
关注者
0
被浏览
7.1k
关于作者
bernard
这家伙很懒,什么也没写!
提问
414
回答
5934
被采纳
75
关注TA
发私信
相关问题
1
有关动态模块加载的一篇论文
2
晕掉了,这么久都不见layer2的踪影啊
3
继续K9ii的历程
4
[GUI相关] FreeType 2
5
[GUI相关]嵌入式系统中文输入法的设计
6
20081101 RT-Thread开发者聚会总结
7
嵌入式系统基础
8
linux2.4.19在at91rm9200 上的寄存器设置
9
[转]基于嵌入式Linux的通用触摸屏校准程序
10
下载了0.23版本,编译s3ceb2410出错,提示lowlevel_init函数没实现
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
国产MCU移植系列教程汇总,欢迎查看!
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 全球电子设计大赛】基于vision board 的巡检除冰机器人
2
新手教程-Pin设备使用
3
基于嵌入式的智能关怀系统#24嵌入式设计大赛
4
基于机器视觉识别自动跟踪器
5
[24嵌入式设计大赛]基于Vision-Board的智能应急环境监测控制小车
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
ART-Pi
FinSH
USB
文件系统
DMA
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
ESP8266
I2C_IIC
ota在线升级
WIZnet_W5500
UART
flash
packages_软件包
cubemx
PWM
freemodbus
BSP
潘多拉开发板_Pandora
定时器
ADC
中断
flashDB
socket
Debug
GD32
编译报错
msh
keil_MDK
at_device
MicroPython
rt_mq_消息队列_msg_queue
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
5
个答案
2
次被采纳
rv666
6
个答案
1
次被采纳
用户名由3_15位
5
个答案
1
次被采纳
xiaorui
2
个答案
1
次被采纳
张世争
2
个答案
1
次被采纳
本月文章贡献
jaffer
1
篇文章
5
次点赞
rtt_dmx
1
篇文章
4
次点赞
flytianya2010
1
篇文章
2
次点赞
BRICK PORTER
1
篇文章
2
次点赞
不灬忘初心
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部