实验环境:
Keil MDK 5.23 + stm32f103vct6 + 未开启优化。
实验缘由:
实验中需要用到一个数据,该数据参与运算,并通过lcd进行显示。
实验描述:
1》该数据是一个只读数据,并不会被修改。
2》该数据出现在2个地方:1》定时时间为1秒的l中断服务函数中(通过
snprintf()将该数据转换为字符串送给lcd显示)。 2》while(1)计算函数中(该数据仅仅作为右值参与计算)。
实验现象:
lcd显示该数据现象为:随机情况下正确,随机情况为0(我通过串口printf()该数据现象也是如此)。
调试经过:
前面的各种debug过程我就略过。最终我考虑到是否为函数重入问题。以下是我的解决办法:
使用MDK自带的microLIB库中的snprintf()取代defaultC库中的
snprintf()。问题最终解决。
请教问题:
问题虽然解决,但是我感觉还有很多疑惑,如下:
1》如何查找snprintf()在defaultC下的源码,难道defaultC库并不确保所有库函数都是可重入的?microLIB中的所有库函数确保都是可重入的?
2》microLIB和defaultC还有哪些差别(下图是MDK手册对microLIB的相关说明,其中根本没有提到reentrant相关问题)?
000.png (16.22 KB, 下载次数: 0)
下载附件
2018-3-12 12:53 上传
恳请大神指教,不胜感激!
我想这个问题,你去查阅一下双字栈对齐的历史变迁,或许可以窥视一二。
后面的版本,都是默认打开的。编译器自然不会去增加什么代码,而且你的 snprintf 就是这么认为已经是双字栈(编辑:双字节 -> 双字栈)对齐的。
对于早期的硬件,相应配套的编译器套件,就要主动去增加什么。
一周热门 更多>