完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我在雅特力的 AT32f403vgt7调试一个多线程程序 有个很诡异的现象, 当我删除一个线程其中的一条LOG_I语句编译下载后,系统就会当掉: psr: 0x01000200 r00: 0xffffffff r01: 0x00000008 r02: 0x40022000 r03: 0x00000001 r04: 0x00000000 r05: 0x00000000 r06: 0x00000000 r07: 0x20011b9c r08: 0x00000000 r09: 0x00000000 r10: 0x00000000 r11: 0x00000000 r12: 0x00000000 lr: 0x0806128d pc: 0x08061290 hard fault on handler usage fault: SCB_CFSR_UFSR:0x01 UNDEFINSTR 而我这个LOG_I就是个普通打印一行调试信息而已… LOG_I("rec_time::%s", ctime(cur_time)); 注意。。是删掉这个LOG_I会导致 hard fault... 求教这是什么原因 另外还想求教,rtthread studio 如何从程序入口处开始单步调试。。我现在点调试,程序直接就飞了。。 谢谢 |
|
相关推荐
3个回答
|
|
应该是存在内存溢出(如数组越界操作)引起的,这个LOG_I 的内存占位,改了它也刚好不会造成死机,删了它,map表内存地址改变,修改了引起触发死机的内存数据,这个问题之前遇到过。
|
|
|
|
的确有此可能;可以对比一下前后的MAP文件;必要的话,可以再比对下删除这行代码的函数的反汇编代码。
|
|
|
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1039 浏览 0 评论
AI模型部署边缘设备的奇妙之旅:如何在边缘端部署OpenCV
3425 浏览 0 评论
tms320280021 adc采样波形,为什么adc采样频率上来波形就不好了?
1465 浏览 0 评论
2146 浏览 0 评论
1640 浏览 0 评论
75345 浏览 21 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-28 16:27 , Processed in 0.602615 second(s), Total 73, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号