有个习惯,新的C环境我都会测一下对于数据运算的支持,最怕的是类型隐式转换,这次第一个测试就出了问题,
PIC16F887, PICC16 v9.70(用的是坛里的破解)
void main(void)
{
unsigned int a,b;
a=258;
a -=256;
b=a>>1;
while(b);
}
仿真结果如下:
(原文件名:test.JPG)
a -= 256, 结果应当是2,但窗口中出现了0xff02!
有几点都不妥当:
1. clrf 0x3. 这条指令应该不妥吧? 据说操作status得不到预期结果
2.a-=256汇编出来的结果 btfss 0x3,0 这是有什么根据呢? 就是前面clrf 0x3结果正确, 但我只减256,没要求减C啊?
另外, a-=257是不会有错的,因为它编译出来如下:
;a -= 257;
07EF 3001 MOVLW 0x1
07F0 02F2 SUBWF 0x72, F
07F1 1C03 BTFSS 0x3, 0
07F2 03F3 DECF 0x73, F
07F3 02F3 SUBWF 0x73, F
好像这个问题是编译器太聪明了,但是也没优化成直接赋值
是不是也是9.70
-----------------------------------------------------------------------
呵呵,我预期的效果是认为 clrf 0x3 它应该清掉C(现在看来它的目的不是这样,可能只是切换BANK而已), 因为后面没做可以改变C标记的操作就直接进行 BTFSS 0X3,0 了这条指令,那你认为它是判断谁的借位呢?
所以我得出的结论是for PIC10/12/16 MCUs (PRO Mode)V9.70(和谐版)不妥(感觉有点太聪明了), 其实45天版得出的也是这个结果,如果不优化太高等级就不会出错
一周热门 更多>