1

假设函数

void foo(uint8_t value)
{
    somearray[some_idx] = value;
}

CodeVision 产生以下

ST   -Y,R26    // the parameter "value" is in R26
;   value -> Y+0

LDS  R30,_some_idx
LDI  R31,0
SUBI R30,LOW(-_somearray)
SBCI R31,HIGH(-_somearray)    

LD   R26,Y
STD  Z+0,R26

R26 到 Y 和从 Y 的存储和加载是完全没有必要的,而且是 2+2 个循环。我只是想了解 CodeVision 为什么这样做,因为它通常非常聪明。

4

0 回答 0