Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
RT-Thread一般讨论
最近的调程序总结
发布于 2008-09-08 15:55:41 浏览:7514
订阅该版
最近工作中调程序,调得很累。 新的芯片,因为和以前的版本改动比较大,多核通信方式变了,电源管理变了,外设的寄存器地址基本都变了。抢时间,急急忙忙的把以前的大工程代码往上套,结果出了很多问题,很多很难查,很伤心很劳累。[还好只是调一个核,如果两个核一起套,真的得跳楼了] 这里总结一下,顺带想想,如果是在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.5k
关于作者
bernard
这家伙很懒,什么也没写!
提问
414
回答
5949
被采纳
77
关注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
国产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中的time溢出问题,时间戳溢出,解决方法
2
ART-PI使用env驱动ETH网卡,pc和板子可以ping通
3
SystemView线程名字不显示
4
只用网页也能跑RT-Smart 无门槛腾讯Cloud studio + smart-build快速构建
5
免费申请 | FRDM-MCXA156评测活动发布!
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
cubemx
WIZnet_W5500
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
keil_MDK
ulog
SFUD
msh
C++_cpp
MicroPython
本月问答贡献
RTT_逍遥
8
个答案
2
次被采纳
三世执戟
7
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
winfeng
2
个答案
1
次被采纳
chenyaxing
2
个答案
1
次被采纳
本月文章贡献
catcatbing
2
篇文章
5
次点赞
swet123
1
篇文章
3
次点赞
YZRD
1
篇文章
2
次点赞
Days
1
篇文章
2
次点赞
阳光的掌控者
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部