两天时间解决了一个BUG,函数再入引起,不要忽视警告信息

2020-01-12 17:12发布

本帖最后由 makesoft 于 2019-12-1 20:58 编辑

没想到51的小程序调试起来这么麻烦,花了整整两天时间,让俺这老江湖汗颜。

其实就是偷懒造成的,一个函数在程序初始化时使用,这个时候系统任何中断并没有打开,另外这个函数在定时中断中也有使用,天真的认为不存在同时调用的可能,所以不可能存在再入的问题,就是没理会重复调用的告警信息。

后来程序不定时的出现问题,因为开始已经有了不可能同时调用再入这个函数的场合,所以就没有检查这个问题。

实在没有办法,刚才检查MAP信息,TNND才发现,其实不仅仅有再入的问题,这个函数使用的局域变量占用的地址,有一个是和其他函数是重复覆盖使用的,真相大白了,两天时间就是不想写一个reentrant,因为会增加一点点代码。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
43条回答
security
1楼-- · 2020-01-16 19:51
takashiki 发表于 2019-12-2 10:30
首先要在Device选项卡中设置使用LX51代替BL51,此时C51选项卡才会出现优化等级10和11,并且尽量使用AJMP/ ...


可以了,多谢赐教。
弄到 11 级,果然省了 1.8 K 的空间,不敢相信,就是不知道程序还能不能正常跑。
makesoft
2楼-- · 2020-01-16 20:07
 精彩回答 2  元偷偷看……
hell-prototypes
3楼-- · 2020-01-16 21:12
涨知识了
zxq6
4楼-- · 2020-01-17 02:42
printf是不是可重入的呢?我到处都在用printf,看各位的描述,担心ing
xiaoxiaobaiyu52
5楼-- · 2020-01-17 08:11
zxq6 发表于 2019-12-16 14:50
printf是不是可重入的呢?我到处都在用printf,看各位的描述,担心ing

我上网查了,是不可重入的,涉及IO的都是
funnynypd
6楼-- · 2020-01-17 08:38
>gcc编译的代码在超过8kb之后会产生各种莫名其妙的问题,死机,执行异常,中断异常,等等。。。貌似是同一类问题。汇编都查了,始终无解,最后放弃avr了
What is the size of the AVR (<=8K Bytes)?

一周热门 更多>