CPP 写嵌入式代码,有个中等概率复现的 Bug ,在怀疑的地方写了行 printf 调试输出,Bug 便再也不复现。删掉调试输出,Bug 又出来了……
![]() | 1 Takashi123 2022-03-01 15:36:42 +08:00 debug 版本合 release 版本不一样,还有内存越界这类如果破坏到堆栈了,可能加一行代码就结果不一样了。 |
![]() | 2 BeijingBaby 2022-03-01 15:44:52 +08:00 ![]() printf 一个不可见字符 -> fixed |
![]() | 3 villivateur OP @Takashi123 一直都是 debug 版本,确实怀疑堆栈问题,但这东西太难查了 |
![]() | 4 darkengine 2022-03-01 16:06:08 +08:00 要是硬件时序问题,那就难搞了。。。 |
5 nightwitch 2022-03-01 16:07:54 +08:00 编译器版本高的话可以试试看能不能链上 AddressSantinizer ,专治内存疑难杂症 |
6 anytk 2022-03-01 16:08:17 +08:00 一般都是堆栈问题,仔细看一些调用地方,尤其是参数是数组的,我最近也被坑过一次 |
7 hiliyg 2022-03-01 18:36:28 +08:00 很正常,我司很多驱动也会这样,加的 log 多就没问题,log 一去掉,就不行,跟硬件响应时间,时序啥的有关系 |
![]() | 8 janxin 2022-03-01 20:13:54 +08:00 @villivateur 一般这样子的 bug 确实很难查,于是我们就这么带了一个 printf |
9 duke807 2022-03-01 20:30:14 +08:00 via Android 不知道是裸跑,是小系,是 linux 用空 按照字查一遍:堆、越界、、dma 、cache 大多数人把藏起,越藏日后越遇到,就更加法查,只有找到解根本才能真正成高手 嵌入式一般不建用 c++,查底麻一些 |
![]() | 10 wjx0912 2022-03-01 21:15:57 +08:00 strip 之前导出符号表,异常的时候把内存镜像转储 |
![]() | 11 wjx0912 2022-03-01 21:20:59 +08:00 找到崩溃点,x86 是 esp ,arm 是 sp ,顺着栈里面找 callback 。开源的工具很多的 |
12 cppc 2022-03-01 23:08:43 +08:00 via iPhone 曾经在生产环境发生过程序崩溃问题,代码审查怎么也找不到可疑代码,崩溃转储出来的内存分析验尸也找不到导致问题的原因。 最后实在没办法了跟甲方摊牌,对方同意直接在 debugger 里面跑程序,这才把 bug 给灭了 |
![]() | 13 respawn 2022-03-01 23:11:16 +08:00 请贴码,无码言甚! |
![]() | 14 ShiaoQuR 2022-03-02 10:43:07 +08:00 把要打印的变量 传递到全局变量 换个地方打印试试呢 |
![]() | 15 654656413245 2022-03-02 13:22:31 +08:00 via iPhone 可能是内存踩踏。 添加的 print 语句可能刚好让指令或内存对象排布进入了一个调和状态,让漏洞无法再暴露 |
16 wty 2022-03-02 16:10:03 +08:00 是不是别处修改了这个变量,然后因为没有 volatile 就默认不会变化,优化掉了,加了 print 打破了优化 |