|
CCS3.3下28XXDSP代碼編譯問(wèn)題
DelayMs(Uint16 t)是利用2812定時(shí)器進(jìn)行延時(shí)的函數(shù),定時(shí)中斷每1ms對(duì)全局變量timedelay進(jìn)行減1處理(為0則不減)。當(dāng)timedelay由t變?yōu)?則跳出函數(shù)返回。但程序總是停到這個(gè)循環(huán)里無(wú)法跳出。
原函數(shù)為:
void DelayMs(Uint16 t)
{
timedelay = t;
while (timedelay != 0) {
}
}
下面是編譯結(jié)果:

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

可見(jiàn)每次比較前都通過(guò)MOV AL,@10對(duì)AL進(jìn)行了更新,當(dāng)timedelay降到0后可以正常跳出。
|
|