|
CCS3.3下28XXDSP代碼編譯問題
DelayMs(Uint16 t)是利用2812定時器進行延時的函數,定時中斷每1ms對全局變量timedelay進行減1處理(為0則不減)。當timedelay由t變為0則跳出函數返回。但程序總是停到這個循環里無法跳出。
原函數為:
void DelayMs(Uint16 t)
{
timedelay = t;
while (timedelay != 0) {
}
}
下面是編譯結果:

因為timedelay在中斷中更改后AL會隨中斷的返回而進行出棧,所以在比較判斷的時候AL的值是不變的,因此函數會陷入死循環。
下圖看到timedelay對應的RAM中數據已經為0。
利用 for(timedelay = t; timedelay > 0;){} 也是相同的編譯結果。甚至在while(1)中嵌入if (timedelay == 0) ... 也是相同的編譯結果。對AL的值不重加裁。
這應當是CCS3.3中28XX DSP編譯器的問題,在使用的時候需注意。
可以在while語句的判斷條件中加一個額外無用的條件來強迫AL進行一次操作,這樣再判斷timedelay的時候就會對AL進行重新加載。
如改為
void DelayMs(Uint16 t)
{
timedelay = t;
while (dmtimeren.bit15 == 1 && timedelay != 0) {
}
}
編譯結果如下:

可見每次比較前都通過MOV AL,@10對AL進行了更新,當timedelay降到0后可以正常跳出。
|
|